Note
Go to the end to download the full example code.
Maxwell 2D: transient winding analysis#
This example shows how you can use PyAEDT to create a project in Maxwell 2D and run a transient simulation. It runs only on Windows using CPython.
The following libraries are required for the advanced postprocessing features used in this example:
Install these libraries with:
pip install numpy pyvista matplotlib
Perform required imports#
Perform required imports.
import os
import pyaedt
import tempfile
Set AEDT version#
Set AEDT version.
aedt_version = "2024.1"
Create temporary directory#
Create temporary directory.
temp_dir = tempfile.TemporaryDirectory(suffix=".ansys")
Set non-graphical mode#
Set non-graphical mode.
You can set non_graphical
either to True
or False
.
non_graphical = False
Insert Maxwell 2D design and save project#
Insert a Maxwell 2D design and save the project.
maxwell_2d = pyaedt.Maxwell2d(solution_type="TransientXY", specified_version=aedt_version, non_graphical=non_graphical,
new_desktop_session=True, projectname=pyaedt.generate_unique_project_name())
C:\actions-runner\_work\_tool\Python\3.10.9\x64\lib\subprocess.py:1072: ResourceWarning: subprocess 5924 is still running
_warn("subprocess %s is still running" % self.pid,
C:\actions-runner\_work\pyaedt\pyaedt\.venv\lib\site-packages\pyaedt\generic\settings.py:383: ResourceWarning: unclosed file <_io.TextIOWrapper name='D:\\Temp\\pyaedt_ansys.log' mode='a' encoding='cp1252'>
self._logger = val
Create rectangle and duplicate it#
Create a rectangle and duplicate it.
Create air region#
Create an air region.
region = maxwell_2d.modeler.create_region([100, 100, 100, 100])
Assign windings and balloon#
Assigns windings to the sheets and a balloon to the air region.
maxwell_2d.assign_winding([rect1.name, rect2.name], name="PHA")
maxwell_2d.assign_balloon(region.edges)
<pyaedt.modules.Boundary.BoundaryObject object at 0x0000022602D10670>
Plot model#
Plot the model.
maxwell_2d.plot(show=False, export_path=os.path.join(temp_dir.name, "Image.jpg"), plot_air_objects=True)

<pyaedt.generic.plot.ModelPlotter object at 0x0000022602D11180>
Create setup#
Create the transient setup.
setup = maxwell_2d.create_setup()
setup.props["StopTime"] = "0.02s"
setup.props["TimeStep"] = "0.0002s"
setup.props["SaveFieldsType"] = "Every N Steps"
setup.props["N Steps"] = "1"
setup.props["Steps From"] = "0s"
setup.props["Steps To"] = "0.002s"
Create rectangular plot#
Create a rectangular plot.
maxwell_2d.post.create_report("InputCurrent(PHA)", domain="Time", primary_sweep_variable="Time",
plot_name="Winding Plot 1")
<pyaedt.modules.report_templates.Standard object at 0x0000022601023A00>
Solve model#
Solve the model.
maxwell_2d.analyze(use_auto_settings=False)
True
Create output and plot using PyVista#
Create the output and plot it using PyVista.
cutlist = ["Global:XY"]
face_lists = rect1.faces
face_lists += rect2.faces
timesteps = [str(i * 2e-4) + "s" for i in range(11)]
id_list = [f.id for f in face_lists]
gif = maxwell_2d.post.plot_animated_field(quantity="Mag_B", assignment=id_list, plot_type="Surface",
intrinsics={"Time": "0s"}, variation_variable="Time",
variations=timesteps, show=False, export_gif=False)
gif.isometric_view = False
gif.camera_position = [15, 15, 80]
gif.focal_point = [15, 15, 0]
gif.roll_angle = 0
gif.elevation_angle = 0
gif.azimuth_angle = 0
# Set off_screen to False to visualize the animation.
# gif.off_screen = False
gif.animate()

C:\actions-runner\_work\pyaedt\pyaedt\.venv\lib\site-packages\pyvista\plotting\plotter.py:4644: PyVistaDeprecationWarning: This method is deprecated and will be removed in a future version of PyVista. Directly modify the scalars of a mesh in-place instead.
warnings.warn(
True
Generate plot outside AEDT#
Generate the same plot outside AEDT.
solutions = maxwell_2d.post.get_solution_data("InputCurrent(PHA)", primary_sweep_variable="Time")
solutions.plot()

No artists with labels found to put in legend. Note that artists whose label start with an underscore are ignored when legend() is called with no argument.
<Figure size 2000x1000 with 1 Axes>
Close AEDT#
Close AEDT.
maxwell_2d.release_desktop()
temp_dir.cleanup()
Total running time of the script: (1 minutes 21.365 seconds)