Skip to content

Commit

Permalink
Add multiple faces option to impedance boundary (#4446)
Browse files Browse the repository at this point in the history
  • Loading branch information
Samuelopez-ansys authored Apr 3, 2024
1 parent 42f0ff1 commit 728c5a9
Show file tree
Hide file tree
Showing 2 changed files with 151 additions and 15 deletions.
29 changes: 23 additions & 6 deletions _unittest/test_20_HFSS.py
Original file line number Diff line number Diff line change
Expand Up @@ -667,7 +667,9 @@ def test_12_create_perfects_on_objects(self):
def test_13_create_impedance_on_objects(self):
box1 = self.aedtapp.modeler.create_box([0, 0, 0], [10, 10, 5], "imp1", "Copper")
box2 = self.aedtapp.modeler.create_box([0, 0, 10], [10, 10, 5], "imp2", "copper")
imp = self.aedtapp.create_impedance_between_objects("imp1", "imp2", self.aedtapp.AxisDir.XPos, "TL2", 50, 25)
imp = self.aedtapp.create_impedance_between_objects(
box1.name, box2.name, self.aedtapp.AxisDir.XPos, "TL1", 50, 25
)
assert imp.name in self.aedtapp.modeler.get_boundaries_name()
assert imp.update()

Expand All @@ -677,14 +679,14 @@ def test_14_create_lumpedrlc_on_objects(self):
box1 = self.aedtapp.modeler.create_box([0, 0, 0], [10, 10, 5], "rlc1", "Copper")
box2 = self.aedtapp.modeler.create_box([0, 0, 10], [10, 10, 5], "rlc2", "copper")
imp = self.aedtapp.create_lumped_rlc_between_objects(
"rlc1", "rlc2", self.aedtapp.AxisDir.XPos, Rvalue=50, Lvalue=1e-9
box1.name, box2.name, self.aedtapp.AxisDir.XPos, Rvalue=50, Lvalue=1e-9
)
assert imp.name in self.aedtapp.modeler.get_boundaries_name()
assert imp.update()

box3 = self.aedtapp.modeler.create_box([0, 0, 20], [10, 10, 5], "rlc3", "copper")
lumped_rlc2 = self.aedtapp.create_lumped_rlc_between_objects(
"rlc2", "rlc3", self.aedtapp.AxisDir.XPos, Rvalue=50, Lvalue=1e-9, Cvalue=1e-9
box2.name, box3.name, self.aedtapp.AxisDir.XPos, Rvalue=50, Lvalue=1e-9, Cvalue=1e-9
)
assert lumped_rlc2.name in self.aedtapp.modeler.get_boundaries_name()
assert lumped_rlc2.update()
Expand All @@ -710,9 +712,24 @@ def test_16_create_impedance_on_sheets(self):
rect = self.aedtapp.modeler.create_rectangle(
self.aedtapp.PLANE.XY, [0, 0, 0], [10, 2], name="ImpBound", matname="Copper"
)
imp = self.aedtapp.assign_impedance_to_sheet("imp1", "TL2", 50, 25)
assert imp.name in self.aedtapp.modeler.get_boundaries_name()
assert imp.update()
imp1 = self.aedtapp.assign_impedance_to_sheet(rect.name, "TL2", 50, 25)
assert imp1.name in self.aedtapp.modeler.get_boundaries_name()
assert imp1.update()

impedance_box = self.aedtapp.modeler.create_box([0, -100, 0], [200, 200, 200], "ImpedanceBox")
ids = self.aedtapp.modeler.get_object_faces(impedance_box.name)[:3]

imp2 = self.aedtapp.assign_impedance_to_sheet(ids, sourcename="ImpedanceToFaces", resistance=60, reactance=-20)
assert imp2.name in self.aedtapp.modeler.get_boundaries_name()

rect2 = self.aedtapp.modeler.create_rectangle(
self.aedtapp.PLANE.XY, [0, 0, 0], [10, 2], name="AniImpBound", matname="Copper"
)
assert not self.aedtapp.assign_impedance_to_sheet(rect2.name, "TL3", [50, 20, 0, 0], [25, 0, 5])
imp2 = self.aedtapp.assign_impedance_to_sheet(rect2.name, "TL3", [50, 20, 0, 0], [25, 0, 5, 0])
assert imp2.name in self.aedtapp.modeler.get_boundaries_name()
imp3 = self.aedtapp.assign_impedance_to_sheet(impedance_box.top_face_z.id, "TL4", [50, 20, 0, 0], [25, 0, 5, 0])
assert imp3.name in self.aedtapp.modeler.get_boundaries_name()

def test_17_create_lumpedrlc_on_sheets(self):
rect = self.aedtapp.modeler.create_rectangle(
Expand Down
137 changes: 128 additions & 9 deletions pyaedt/hfss.py
Original file line number Diff line number Diff line change
Expand Up @@ -226,9 +226,18 @@ def field_setup_names(self):
class BoundaryType(object):
"""Creates and manages boundaries."""

(PerfectE, PerfectH, Aperture, Radiation, Impedance, LayeredImp, LumpedRLC, FiniteCond, Hybrid, FEBI) = range(
0, 10
)
(
PerfectE,
PerfectH,
Aperture,
Radiation,
Impedance,
LayeredImp,
LumpedRLC,
FiniteCond,
Hybrid,
FEBI,
) = range(0, 10)

@property
def hybrid(self):
Expand Down Expand Up @@ -3633,8 +3642,8 @@ def assign_impedance_to_sheet(self, sheet_name, sourcename=None, resistance=50,
Parameters
----------
sheet_name : str
Name of the sheet to apply the boundary to.
sheet_name : str or list
Name of the sheet or list to apply the boundary to.
sourcename : str, optional
Name of the impedance. The default is ``None``.
resistance : optional
Expand Down Expand Up @@ -3675,17 +3684,127 @@ def assign_impedance_to_sheet(self, sheet_name, sourcename=None, resistance=50,
sourcename = generate_unique_name("Imped")
elif sourcename in self.modeler.get_boundaries_name():
sourcename = generate_unique_name(sourcename)

objects = self.modeler.convert_to_selections(sheet_name, True)

props = OrderedDict(
{
"Objects": [sheet_name],
"Resistance": str(resistance),
"Reactance": str(reactance),
"InfGroundPlane": is_infground,
"Faces": objects,
}
)
if isinstance(objects[0], str):
props = OrderedDict(
{
"Objects": objects,
}
)
props["Resistance"] = str(resistance)
props["Reactance"] = str(reactance)
props["InfGroundPlane"] = is_infground

return self._create_boundary(sourcename, props, "Impedance")
return False

@pyaedt_function_handler()
def assign_impedance_to_sheet(
self, sheet_name, sourcename=None, resistance=50.0, reactance=0.0, is_infground=False, reference_cs="Global"
):
"""Create an impedance taking one sheet.
Parameters
----------
sheet_name : str or list
Name of the sheet or list to apply the boundary to.
sourcename : str, optional
Name of the impedance. The default is ``None``.
resistance : float or list, optional
Resistance value in ohms. The default is ``50.0``.
If a list of four elements is passed, an anisotropic impedance is assigned with the following order,
[``Zxx``, ``Zxy``, ``Zyx``, ``Zyy``].
reactance : optional
Reactance value in ohms. The default is ``0.0``.
If a list of four elements is passed, an anisotropic impedance is assigned with the following order,
[``Zxx``, ``Zxy``, ``Zyx``, ``Zyy``].
is_infground : bool, optional
Whether the impedance is an infinite ground. The default is ``False``.
reference_cs : str, optional
Name of the coordinate system for the XY plane. The default is ``"Global"``.
This parameter is only used for anisotropic impedance assignment.
Returns
-------
:class:`pyaedt.modules.Boundary.BoundaryObject`
Boundary object if successful, ``False`` otherwise.
References
----------
>>> oModule.AssignImpedance
Examples
--------
Create a sheet and use it to create an impedance.
>>> sheet = hfss.modeler.create_rectangle(hfss.PLANE.XY,
... [0, 0, -90], [10, 2], name="ImpedanceSheet",
... matname="Copper")
>>> impedance_to_sheet = hfss.assign_impedance_to_sheet(sheet.name, "ImpedanceFromSheet", 100, 50)
Create a sheet and use it to create an anisotropic impedance.
>>> sheet = hfss.modeler.create_rectangle(hfss.PLANE.XY,
... [0, 0, -90], [10, 2], name="ImpedanceSheet",
... matname="Copper")
>>> anistropic_impedance_to_sheet = hfss.assign_impedance_to_sheet(sheet.name, "ImpedanceFromSheet",
... [377, 0, 0, 377], [0, 50, 0, 0])
"""

if self.solution_type in ["Modal", "Terminal", "Transient Network"]:
if not sourcename:
sourcename = generate_unique_name("Imped")
elif sourcename in self.modeler.get_boundaries_name():
sourcename = generate_unique_name(sourcename)

objects = self.modeler.convert_to_selections(sheet_name, True)

props = OrderedDict(
{
"Faces": objects,
}
)
if isinstance(objects[0], str):
props = OrderedDict(
{
"Objects": objects,
}
)

if isinstance(resistance, list) and isinstance(reactance, list):
if len(resistance) == 4 and len(reactance) == 4:
props["UseInfiniteGroundPlane"] = is_infground
props["CoordSystem"] = reference_cs
props["HasExternalLink"] = False
props["ZxxResistance"] = str(resistance[0])
props["ZxxReactance"] = str(reactance[0])
props["ZxyResistance"] = str(resistance[1])
props["ZxyReactance"] = str(reactance[1])
props["ZyxResistance"] = str(resistance[2])
props["ZyxReactance"] = str(reactance[2])
props["ZyyResistance"] = str(resistance[3])
props["ZyyReactance"] = str(reactance[3])
else:
self.logger.error("Number of elements in resistance and reactance must be four.")
return False
return self._create_boundary(sourcename, props, "Anisotropic Impedance")
else:
props["Resistance"] = str(resistance)
props["Reactance"] = str(reactance)
props["InfGroundPlane"] = is_infground
return self._create_boundary(sourcename, props, "Impedance")
return False

@pyaedt_function_handler()
def create_circuit_port_from_edges(
self,
Expand Down

0 comments on commit 728c5a9

Please sign in to comment.