Create a pool of Mechanical servers#

The LocalMechanicalPool class simplifies creating and connecting to multiple servers of the Mechanical class for batch processing. You can use this class for batch processing a set of input files or other batch-related processes.

This code shows how to create a pool with 10 instances:

>>> from ansys.mechanical.core import LocalMechanicalPool
>>> pool = LocalMechanicalPool(10, version="251")
'Mechanical Pool with 10 active instances'

When you are creating a pool, you can supply additional keyword arguments. For example, to restart failed instances, you can set restart_failed=True:

>>> import os
>>> my_path = os.getcmd()
>>> pool = LocalMechanicalPool(10, version="251", restart_failed=True)
Creating Pool: 100%|########| 10/10 [00:01<00:00,  1.43it/s]

You can access each individual instance of Mechanical with this code:

>>> pool[0]
<ansys.mechanical.core.mechanical.Mechanical at 0x7fabf0230d90>

Because this is a self-healing pool, if an instance of Mechanical stops during a batch process, this instance is automatically restarted. When creating the pool, you can disable this behavior by setting restart_failed=False.

Run a set of input files#

You can use the pool to run a set of pre-generated input files using the run_batch() method.

For example, you can run the first set of 20 verification files with this code:

>>>>>> from ansys.mechanical.core import examples
>>> files = [f"test{index}.py" for index in range(1, 21)]
>>> outputs = pool.run_batch(files)
>>> len(outputs)
20

Run a user-defined function#

While the previous example uses the run_batch() method to run a set of inputs files, you can also use the map() method to run a custom user-defined function on each instance of Mechanical over a set of input files.

>>> completed_indices = []
>>> def func(mechanical, input_file, index):
...     # input_file, index = args
...     mechanical.clear()
...     output = mechanical.run_python_script_from_file(input_file)
...     completed_indices.append(index)
...     return output
...
>>> inputs = [("test{index}.py", i) for i in range(1, 10)]
>>> output = pool.map(func, inputs, progress_bar=True, wait=True)
['result1',
 'result2',
 'result3',
 'result4',
 'result5',
 'result6',
 'result7',
 'result8',
 'result9']