Download this example

Download this example as a Jupyter Notebook or as a Python script.


External delta circuit#

This example shows how to create an external delta circuit and connect it with a Maxwell 2D design.

Keywords: Maxwell 2D, Circuit, netlist

Perform imports and define constants#

[1]:
import os
import tempfile
import time
[2]:
import ansys.aedt.core

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 and Maxwell 2D#

Launch AEDT and Maxwell 2D providing the version, path to the project, and the graphical mode.

[5]:
project_name = os.path.join(temp_folder.name, "Maxwell_circuit_example.aedt")
design_name = "1 Maxwell"
circuit_name = "2 Delta circuit"
[6]:
m2d = ansys.aedt.core.Maxwell2d(
    version=AEDT_VERSION,
    new_desktop=False,
    design=design_name,
    project=project_name,
    solution_type="TransientXY",
    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_3e0701f2-a82f-47cb-b3cc-b4a49f947a2f.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 64649
PyAEDT INFO: AEDT installation Path C:\Program Files\AnsysEM\v242\Win64
PyAEDT INFO: Ansoft.ElectronicsDesktop.2024.2 version started with process ID 5524.
PyAEDT INFO: Project Maxwell_circuit_example has been created.
PyAEDT INFO: Added design '1 Maxwell' of type Maxwell 2D.
PyAEDT INFO: Aedt Objects correctly read

Initialize dictionaries and define variables#

Initialize dictionaries that contain all design variable definitions.

[7]:
voltage = "230V"
frequency = "50Hz"
[8]:
transient_parameters = {
    "voltage": voltage,
    "frequency": frequency,
    "electric_period": "1 / frequency s",
    "stop_time": "2 * electric_period s",
    "time_step": "electric_period / 20 s",
}
[9]:
circuit_parameters = {
    "voltage": voltage,
    "frequency": frequency,
    "resistance_value": "1Ohm",
}
[10]:
for k, v in transient_parameters.items():
    m2d[k] = v

Create geometry#

Create copper coils and a vacuum region. Assign mesh operations, and then assign a balloon boundary to the region edges.

[11]:
coil1_id = m2d.modeler.create_circle(
    orientation="Z", origin=[0, 0, 0], radius=10, name="coil1", material="copper"
)
coil2_id = m2d.modeler.create_circle(
    orientation="Z", origin=[25, 0, 0], radius=10, name="coil2", material="copper"
)
coil3_id = m2d.modeler.create_circle(
    orientation="Z", origin=[50, 0, 0], radius=10, name="coil3", material="copper"
)
PyAEDT INFO: Modeler2D class has been initialized!
PyAEDT INFO: Modeler class has been initialized! Elapsed time: 0m 1sec
PyAEDT INFO: Materials class has been initialized! Elapsed time: 0m 0sec
[12]:
region = m2d.modeler.create_region(pad_value=[200, 400, 200, 400])
[13]:
m2d.mesh.assign_length_mesh(
    assignment=[coil1_id, coil2_id, coil3_id, region], maximum_length=5
)
PyAEDT INFO: Mesh class has been initialized! Elapsed time: 0m 0sec
PyAEDT INFO: Mesh class has been initialized! Elapsed time: 0m 0sec
[13]:
<ansys.aedt.core.modules.mesh.MeshOperation at 0x2e108bbf7f0>
[14]:
m2d.assign_vector_potential(assignment=region.edges, vector_value=0)
PyAEDT INFO: Boundary Vector_IC7HUP has been correctly created.
[14]:
<ansys.aedt.core.modules.boundary.common.BoundaryObject at 0x2e10a83ad10>

Assign excitations#

Assign external windings

[15]:
wdg1 = m2d.assign_winding(
    assignment=["coil1"],
    is_solid=False,
    winding_type="External",
    name="winding1",
    current=0,
)
wdg2 = m2d.assign_winding(
    assignment=["coil2"],
    is_solid=False,
    winding_type="External",
    name="winding2",
    current=0,
)
wdg3 = m2d.assign_winding(
    assignment=["coil3"],
    is_solid=False,
    winding_type="External",
    name="winding3",
    current=0,
)
PyAEDT INFO: Boundary winding1 has been correctly created.
PyAEDT INFO: Boundary Coil_4KUGBN has been correctly created.
PyAEDT INFO: Boundary winding2 has been correctly created.
PyAEDT INFO: Boundary Coil_1XCI73 has been correctly created.
PyAEDT INFO: Boundary winding3 has been correctly created.
PyAEDT INFO: Boundary Coil_BX8TR6 has been correctly created.

Create simulation setup#

Create the simulation setup, defining the stop time and time step.

[16]:
setup = m2d.create_setup()
setup["StopTime"] = "stop_time"
setup["TimeStep"] = "time_step"

Create external circuit#

Create the circuit design, including all windings of type External in the Maxwell design.

[17]:
circuit = m2d.create_external_circuit(circuit_design=circuit_name)
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: Returning found Desktop session with PID 5524!
PyAEDT INFO: No project is defined. Project Maxwell_circuit_example exists and has been read.
PyAEDT INFO: Added design '2 Delta circuit' of type Maxwell Circuit.
PyAEDT INFO: Aedt Objects correctly read
PyAEDT INFO: ModelerCircuit class has been initialized! Elapsed time: 0m 0sec
PyAEDT INFO: ModelerMaxwellCircuit class has been initialized!

Define variables from dictionaries#

Define design variables from the created dictionaries.

[18]:
for k, v in circuit_parameters.items():
    circuit[k] = v
[19]:
windings = [
    circuit.modeler.schematic.components[k]
    for k in list(circuit.modeler.schematic.components.keys())
    if circuit.modeler.schematic.components[k].parameters["Info"] == "Winding"
]

Finalize external circuit#

Draw these other components: resistors, voltage sources, and grounds

[20]:
circuit.modeler.schematic_units = "mil"
[21]:
resistors = []
v_sources = []
ground = []
[22]:
for i in range(len(windings)):
    r = circuit.modeler.schematic.create_resistor(
        name="R" + str(i + 1), value="resistance_value", location=[1000, i * 1000]
    )
    resistors.append(r)

    v = circuit.modeler.schematic.create_component(
        component_library="Sources",
        component_name="VSin",
        location=[2000, i * 1000],
        angle=90,
    )
    v_sources.append(v)

    v.parameters["Va"] = "voltage"
    v.parameters["VFreq"] = "frequency"
    v.parameters["Phase"] = str(i * 120) + "deg"

    g = circuit.modeler.schematic.create_gnd([2300, i * 1000], angle=90)
    ground.append(g)

Connect components#

Connect the components by drawing wires.

[23]:
windings[2].pins[1].connect_to_component(resistors[2].pins[0], use_wire=True)
windings[1].pins[1].connect_to_component(resistors[1].pins[0], use_wire=True)
windings[0].pins[1].connect_to_component(resistors[0].pins[0], use_wire=True)
[23]:
True
[24]:
resistors[2].pins[1].connect_to_component(v_sources[2].pins[1], use_wire=True)
resistors[1].pins[1].connect_to_component(v_sources[1].pins[1], use_wire=True)
resistors[0].pins[1].connect_to_component(v_sources[0].pins[1], use_wire=True)
[24]:
True
[25]:
circuit.modeler.schematic.create_wire(
    points=[
        resistors[2].pins[1].location,
        [1200, 2500],
        [-600, 2500],
        [-600, 0],
        windings[0].pins[0].location,
    ]
)
circuit.modeler.schematic.create_wire(
    points=[
        resistors[1].pins[1].location,
        [1200, 1500],
        [-300, 1500],
        [-300, 2000],
        windings[2].pins[0].location,
    ]
)
circuit.modeler.schematic.create_wire(
    points=[
        resistors[0].pins[1].location,
        [1200, 500],
        [-300, 500],
        [-300, 1000],
        windings[1].pins[0].location,
    ]
)
[25]:
<ansys.aedt.core.modeler.circuits.object_3d_circuit.Wire at 0x2e11ff93850>

Export and import netlist#

Export the netlist file and then import it to Maxwell 2D.

[26]:
netlist_file = os.path.join(temp_folder.name, "_netlist.sph")
circuit.export_netlist_from_schematic(netlist_file)
[26]:
'C:\\Users\\ansys\\AppData\\Local\\Temp\\tmp91vu3w3a.ansys\\_netlist.sph'
[27]:
m2d.edit_external_circuit(
    netlist_file_path=netlist_file, schematic_design_name=circuit_name
)
[27]:
True

Analyze setup#

[28]:
setup.analyze(cores=NUM_CORES)
PyAEDT INFO: Key Desktop/ActiveDSOConfigurations/Maxwell 2D correctly changed.
PyAEDT INFO: Solving design setup MySetupAuto
PyAEDT INFO: Key Desktop/ActiveDSOConfigurations/Maxwell 2D correctly changed.
PyAEDT INFO: Design setup MySetupAuto solved correctly in 0.0h 0.0m 24.0s

Create rectangular plot#

Plot winding currents

[29]:
m2d.post.create_report(
    expressions=["Current(winding1)", "Current(winding2)", "Current(winding3)"],
    domain="Sweep",
    primary_sweep_variable="Time",
    plot_name="Winding Currents",
)
PyAEDT INFO: Parsing C:/Users/ansys/AppData/Local/Temp/tmp91vu3w3a.ansys/Maxwell_circuit_example.aedt.
PyAEDT INFO: File C:/Users/ansys/AppData/Local/Temp/tmp91vu3w3a.ansys/Maxwell_circuit_example.aedt correctly loaded. Elapsed time: 0m 0sec
PyAEDT INFO: aedt file load time 0.015625476837158203
PyAEDT INFO: PostProcessor class has been initialized! Elapsed time: 0m 0sec
PyAEDT INFO: Post class has been initialized! Elapsed time: 0m 0sec
[29]:
<ansys.aedt.core.visualization.report.standard.Standard at 0x2e11c7fa560>

Release AEDT#

[30]:
m2d.save_project()
m2d.release_desktop()
# Wait 3 seconds to allow AEDT to shut down before cleaning the temporary directory.
time.sleep(3)
PyAEDT INFO: Project Maxwell_circuit_example Saved correctly
PyAEDT INFO: Desktop has been released and closed.

Clean up#

All project files are saved in the folder temp_dir.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.

[31]:
temp_folder.cleanup()

Download this example

Download this example as a Jupyter Notebook or as a Python script.