Download this example
Download this example as a Jupyter Notebook or as a Python script.
Electro DC analysis#
This example shows how to use PyAEDT to create a Maxwell DC analysis, compute mass center, and move coordinate systems.
Keywords: Maxwell 3D, DC.
Perform imports and define constants#
Perform required imports.
[1]:
import os
import tempfile
import time
[2]:
from ansys.aedt.core import Maxwell3d
Define constants.
[3]:
AEDT_VERSION = "2024.2"
NUM_CORES = 4
NG_MODE = False # Open AEDT UI when it is launched.
Create temporary directory#
Create a temporary directory where downloaded data or dumped data can be stored. If you’d like to retrieve the project data for subsequent use, the temporary folder name is given by temp_folder.name
.
[4]:
temp_folder = tempfile.TemporaryDirectory(suffix=".ansys")
Launch AEDT#
Create an instance of the Maxwell3d
class named m3d
by providing the project name, the version, and the graphical mode.
[5]:
project_name = os.path.join(temp_folder.name, "conductor_example.aedt")
m3d = Maxwell3d(
project=project_name,
version=AEDT_VERSION,
new_desktop=True,
non_graphical=NG_MODE,
)
PyAEDT INFO: Python version 3.10.11 (tags/v3.10.11:7d4cc5a, Apr 5 2023, 00:38:17) [MSC v.1929 64 bit (AMD64)]
PyAEDT INFO: PyAEDT version 0.14.dev0.
PyAEDT INFO: Initializing new Desktop session.
PyAEDT INFO: Log on console is enabled.
PyAEDT INFO: Log on file C:\Users\ansys\AppData\Local\Temp\pyaedt_ansys_ae576466-7d87-4c80-88ec-55e7b0bd3c9a.log is enabled.
PyAEDT INFO: Log on AEDT is enabled.
PyAEDT INFO: Debug logger is disabled. PyAEDT methods will not be logged.
PyAEDT INFO: Launching PyAEDT with gRPC plugin.
PyAEDT INFO: New AEDT session is starting on gRPC port 64144
PyAEDT INFO: AEDT installation Path C:\Program Files\AnsysEM\v242\Win64
PyAEDT INFO: Ansoft.ElectronicsDesktop.2024.2 version started with process ID 2664.
PyAEDT INFO: Project conductor_example has been created.
PyAEDT INFO: No design is present. Inserting a new design.
PyAEDT INFO: Added design 'Maxwell 3D_17E' of type Maxwell 3D.
PyAEDT INFO: Aedt Objects correctly read
Set up Maxwell solution#
Set up the Maxwell solution to DC.
[6]:
m3d.solution_type = m3d.SOLUTIONS.Maxwell3d.ElectroDCConduction
Create conductor#
Create a conductor using copper, a predefined material in the Maxwell material library.
[7]:
conductor = m3d.modeler.create_box(
origin=[7, 4, 22], sizes=[10, 5, 30], name="Conductor", material="copper"
)
PyAEDT INFO: Modeler class has been initialized! Elapsed time: 0m 1sec
PyAEDT INFO: Materials class has been initialized! Elapsed time: 0m 0sec
Create setup and assign voltage#
[8]:
m3d.assign_voltage(assignment=conductor.faces, amplitude=0)
m3d.create_setup()
PyAEDT INFO: Boundary Voltage_I6ONKF has been correctly created.
PyAEDT INFO: Parsing C:/Users/ansys/AppData/Local/Temp/tmpavuj27fa.ansys/conductor_example.aedt.
PyAEDT INFO: File C:/Users/ansys/AppData/Local/Temp/tmpavuj27fa.ansys/conductor_example.aedt correctly loaded. Elapsed time: 0m 0sec
PyAEDT INFO: aedt file load time 0.0
[8]:
SetupName MySetupAuto with 0 Sweeps
Solve setup#
[9]:
m3d.analyze(cores=NUM_CORES)
PyAEDT INFO: Key Desktop/ActiveDSOConfigurations/Maxwell 3D correctly changed.
PyAEDT INFO: Solving all design setups.
PyAEDT INFO: Key Desktop/ActiveDSOConfigurations/Maxwell 3D correctly changed.
PyAEDT INFO: Design setup None solved correctly in 0.0h 0.0m 15.0s
[9]:
True
Compute mass center#
Compute mass center using PyAEDT advanced fields calculator.
[10]:
scalar_function = ""
mass_center = {
"name": "",
"description": "Mass center computation",
"design_type": ["Maxwell 3D"],
"fields_type": ["Fields"],
"primary_sweep": "distance",
"assignment": "",
"assignment_type": ["Solid"],
"operations": [
scalar_function,
"EnterVolume('assignment')",
"Operation('VolumeValue')",
"Operation('Mean')",
],
"report": ["Data Table"],
}
mass_center["name"] = "CM_X"
scalar_function = "Scalar_Function(FuncValue='X')"
mass_center["operations"][0] = scalar_function
m3d.post.fields_calculator.add_expression(mass_center, conductor.name)
mass_center["name"] = "CM_Y"
scalar_function = "Scalar_Function(FuncValue='Y')"
mass_center["operations"][0] = scalar_function
m3d.post.fields_calculator.add_expression(mass_center, conductor.name)
mass_center["name"] = "CM_Z"
scalar_function = "Scalar_Function(FuncValue='Z')"
mass_center["operations"][0] = scalar_function
m3d.post.fields_calculator.add_expression(mass_center, conductor.name)
PyAEDT INFO: PostProcessor class has been initialized! Elapsed time: 0m 0sec
PyAEDT INFO: Post class has been initialized! Elapsed time: 0m 0sec
[10]:
'CM_Z'
Get mass center#
Get mass center using the fields calculator.
[11]:
xval = m3d.post.get_scalar_field_value(quantity="CM_X")
yval = m3d.post.get_scalar_field_value(quantity="CM_Y")
zval = m3d.post.get_scalar_field_value(quantity="CM_Z")
PyAEDT INFO: Exporting CM_X field. Be patient
PyAEDT INFO: Quantity CM_X not present. Trying to get it from Stack
PyAEDT INFO: Exporting CM_Y field. Be patient
PyAEDT INFO: Quantity CM_Y not present. Trying to get it from Stack
PyAEDT INFO: Exporting CM_Z field. Be patient
PyAEDT INFO: Quantity CM_Z not present. Trying to get it from Stack
Create variables#
Create variables with mass center values.
[12]:
m3d[conductor.name + "x"] = str(xval * 1e3) + "mm"
m3d[conductor.name + "y"] = str(yval * 1e3) + "mm"
m3d[conductor.name + "z"] = str(zval * 1e3) + "mm"
Create coordinate system#
Create a parametric coordinate system.
[13]:
cs1 = m3d.modeler.create_coordinate_system(
origin=[conductor.name + "x", conductor.name + "y", conductor.name + "z"],
reference_cs="Global",
name=conductor.name + "CS",
)
Release AEDT#
[14]:
m3d.save_project()
m3d.release_desktop()
# Wait 3 seconds to allow AEDT to shut down before cleaning the temporary directory.
time.sleep(3)
PyAEDT INFO: Project conductor_example Saved correctly
PyAEDT INFO: Desktop has been released and closed.
Clean up#
All project files are saved in the folder temp_folder.name
. If you’ve run this example as a Jupyter notebook, you can retrieve those project files. The following cell removes all temporary files, including the project folder.
[15]:
temp_folder.cleanup()
Download this example
Download this example as a Jupyter Notebook or as a Python script.