Download this example

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


Flex cable CPWG#

This example shows how to use PyAEDT to create a flex cable CPWG (coplanar waveguide with ground).

Keywords: HFSS, flex cable, CPWG.

Perform imports and define constants#

Perform required imports.

[1]:
import os
import tempfile
from math import cos, radians, sin, sqrt
[2]:
import ansys.aedt.core
from ansys.aedt.core.generic.general_methods import generate_unique_name

Define constants.

[3]:
AEDT_VERSION = "2024.2"

Set non-graphical mode#

Set non-graphical mode. You can set non_graphical either to True or False.

[4]:
non_graphical = False

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.

[5]:
temp_folder = tempfile.TemporaryDirectory(suffix=".ansys")

Launch AEDT#

Launch AEDT, create an HFSS design, and save the project.

[6]:
hfss = ansys.aedt.core.Hfss(
    version=AEDT_VERSION,
    solution_type="DrivenTerminal",
    new_desktop=True,
    non_graphical=non_graphical,
)
hfss.save_project(
    os.path.join(temp_folder.name, generate_unique_name("example") + ".aedt")
)
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_9147058a-75b1-44a9-84b5-2eafbd598260.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 57765
PyAEDT INFO: AEDT installation Path C:\Program Files\AnsysEM\v242\Win64
PyAEDT INFO: Ansoft.ElectronicsDesktop.2024.2 version started with process ID 612.
PyAEDT INFO: Project Project19 has been created.
PyAEDT INFO: No design is present. Inserting a new design.
PyAEDT INFO: Added design 'HFSS_CI6' of type HFSS.
PyAEDT INFO: Aedt Objects correctly read
PyAEDT INFO: Project example_SGA0IG Saved correctly
[6]:
True

Modify design settings#

Modify some design settings.

[7]:
hfss.change_material_override(True)
hfss.change_automatically_use_causal_materials(True)
hfss.create_open_region("100GHz")
hfss.modeler.model_units = "mil"
hfss.mesh.assign_initial_mesh_from_slider(applycurvilinear=True)
PyAEDT INFO: Enabling Material Override
PyAEDT INFO: Enabling Automatic use of causal materials
PyAEDT INFO: Open Region correctly created.
PyAEDT INFO: Project example_SGA0IG Saved correctly
PyAEDT INFO: Modeler class has been initialized! Elapsed time: 0m 1sec
PyAEDT INFO: Mesh class has been initialized! Elapsed time: 0m 0sec
PyAEDT INFO: Mesh class has been initialized! Elapsed time: 0m 0sec
PyAEDT WARNING: Argument `applycurvilinear` is deprecated for method `assign_initial_mesh_from_slider`; use `curvilinear` instead.
[7]:
True

Create variables#

Create input variables for creating the flex cable CPWG.

[8]:
total_length = 300
theta = 120
r = 100
width = 3
height = 0.1
spacing = 1.53
gnd_width = 10
gnd_thickness = 2

xt = (total_length - r * radians(theta)) / 2

Create bend#

The create_bending() method creates a list of points for the bend based on the curvature radius and extension.

[9]:
def create_bending(radius, extension=0):
    points = [(-xt, 0, -radius), (0, 0, -radius)]

    for i in [radians(i) for i in range(theta)] + [radians(theta + 0.000000001)]:
        points.append((radius * sin(i), 0, -radius * cos(i)))

    x1, y1, z1 = points[-1]
    x0, y0, z0 = points[-2]

    scale = (xt + extension) / sqrt((x1 - x0) ** 2 + (z1 - z0) ** 2)
    x, y, z = (x1 - x0) * scale + x0, 0, (z1 - z0) * scale + z0

    points[-1] = (x, y, z)
    return points

Draw signal line#

Draw a signal line to create a bent signal wire.

[10]:
points = create_bending(r, 1)
line = hfss.modeler.create_polyline(
    points=points,
    xsection_type="Rectangle",
    xsection_width=height,
    xsection_height=width,
    material="copper",
)
PyAEDT INFO: Materials class has been initialized! Elapsed time: 0m 0sec

Draw ground line#

Draw a ground line to create two bent ground wires.

[11]:
gnd_r = [(x, spacing + width / 2 + gnd_width / 2, z) for x, y, z in points]
gnd_l = [(x, -y, z) for x, y, z in gnd_r]

gnd_objs = []
for gnd in [gnd_r, gnd_l]:
    x = hfss.modeler.create_polyline(
        points=gnd,
        xsection_type="Rectangle",
        xsection_width=height,
        xsection_height=gnd_width,
        material="copper",
    )
    x.color = (255, 0, 0)
    gnd_objs.append(x)

Draw dielectric#

Draw a dielectric to create a dielectric cable.

[12]:
points = create_bending(r + (height + gnd_thickness) / 2)

fr4 = hfss.modeler.create_polyline(
    points=points,
    xsection_type="Rectangle",
    xsection_width=gnd_thickness,
    xsection_height=width + 2 * spacing + 2 * gnd_width,
    material="FR4_epoxy",
)

Create bottom metals#

Create the bottom metals.

[13]:
points = create_bending(r + height + gnd_thickness, 1)

bot = hfss.modeler.create_polyline(
    points=points,
    xsection_type="Rectangle",
    xsection_width=height,
    xsection_height=width + 2 * spacing + 2 * gnd_width,
    material="copper",
)

Create port interfaces#

Create port interfaces (PEC enclosures).

[14]:
port_faces = []
for face, blockname in zip([fr4.top_face_z, fr4.bottom_face_x], ["b1", "b2"]):
    xc, yc, zc = face.center
    positions = [i.position for i in face.vertices]

    port_sheet_list = [
        ((x - xc) * 10 + xc, (y - yc) + yc, (z - zc) * 10 + zc) for x, y, z in positions
    ]
    s = hfss.modeler.create_polyline(
        port_sheet_list, close_surface=True, cover_surface=True
    )
    center = [round(i, 6) for i in s.faces[0].center]

    port_block = hfss.modeler.thicken_sheet(s.name, -5)
    port_block.name = blockname
    for f in port_block.faces:

        if [round(i, 6) for i in f.center] == center:
            port_faces.append(f)

    port_block.material_name = "PEC"

    for i in [line, bot] + gnd_objs:
        i.subtract([port_block], True)

    print(port_faces)
PyAEDT INFO: Parsing design objects. This operation can take time
PyAEDT INFO: Refreshing objects from AEDT file
PyAEDT INFO: Parsing C:/Users/ansys/AppData/Local/Temp/tmpc2syuak5.ansys/example_SGA0IG.aedt.
PyAEDT INFO: File C:/Users/ansys/AppData/Local/Temp/tmpc2syuak5.ansys/example_SGA0IG.aedt correctly loaded. Elapsed time: 0m 0sec
PyAEDT INFO: aedt file load time 0.0
PyAEDT INFO: 3D Modeler objects parsed. Elapsed time: 0m 0sec
[7391]
[7391, 7586]

Create boundary condition#

Creates a Perfect E boundary condition.

[15]:
boundary = []
for face in [fr4.top_face_y, fr4.bottom_face_y]:
    s = hfss.modeler.create_object_from_face(face)
    boundary.append(s)
    hfss.assign_perfecte_to_sheets(s)
PyAEDT INFO: Boundary Perfect E PerfE_A5I5DF has been correctly created.
PyAEDT INFO: Boundary Perfect E PerfE_QU26WY has been correctly created.

Create ports#

Create ports.

[16]:
for s, port_name in zip(port_faces, ["1", "2"]):
    reference = [i.name for i in gnd_objs + boundary + [bot]] + ["b1", "b2"]

    hfss.wave_port(s.id, name=port_name, reference=reference)
PyAEDT INFO: Boundary AutoIdentify 1 has been correctly created.
PyAEDT INFO: Boundary AutoIdentify 2 has been correctly created.

Create setup and sweep#

Create the setup and sweep.

[17]:
setup = hfss.create_setup("setup1")
setup["Frequency"] = "2GHz"
setup.props["MaximumPasses"] = 10
setup.props["MinimumConvergedPasses"] = 2
hfss.create_linear_count_sweep(
    setup="setup1",
    units="GHz",
    start_frequency=1e-1,
    stop_frequency=4,
    num_of_freq_points=101,
    name="sweep1",
    save_fields=False,
    sweep_type="Interpolating",
)
PyAEDT INFO: Linear count sweep sweep1 has been correctly created.
[17]:
<ansys.aedt.core.modules.solve_sweeps.SweepHFSS at 0x181943bead0>

Release AEDT#

[18]:
hfss.release_desktop()
PyAEDT INFO: Desktop has been released and closed.
[18]:
True

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.

[19]:
temp_folder.cleanup()

Download this example

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