add_modeling_region#

Layer.add_modeling_region(project, modeling_regions)#

Add one or more modeling regions to a specific project.

Parameters:
project: str

Name of the Sherlock project.

modeling_regions: list[dict[str, bool | float | str | dict[str, bool | float | str] | dict[str, float | str]]]

Modeling regions to add. Each dictionary should contain:

  • cca_name: str

    Name of the CCA.

  • region_id: str

    Unique region ID of the modeling region.

  • region_units: str

    Units of the modeling region.

  • model_mode: str

    Mode that specifies how the region is used. Valid values are Enabled, Disabled and Excluded.

  • shape: PolygonalShape|RectangularShape|SlotShape|CircularShape|PCBShape

    The shape of the modeling region.

  • pcb_model_props: dict[str, bool | float | str]

    PCB model parameters consisting of these properties:

    • export_model_type: str

      The type of model to be generated for a given modeling region. Valid values are Default, Sherlock, Sweep and None.

    • elem_order: str

      The type of 3D elements to be created for the PCB in the modeling region. Valid values are First_Order, Second_Order and Solid_Shell.

    • max_mesh_size: float

      The maximum size of the mesh to be used in the region.

    • max_mesh_size_units: str

      Units for the maximum mesh size.

    • quads_preferred: bool

      Whether to generate quad-shaped elements when creating the mesh if true.

  • trace_model_props: dict[str, float | str]

    Trace model parameters consisting of these properties:

    • trace_model_typestr

      The specification of whether trace modeling should be performed within the region. Valid values are Default, Enabled and Disabled.

    • elem_order: str, optional

      The type of 3D elements to be created for the PCB in the modeling region. Valid values are First_Order, Second_Order and Solid_Shell.

    • trace_mesh_sizefloat, optional

      The maximum mesh size to be used in the region when trace modeling is enabled.

    • trace_mesh_size_units: str, optional

      Units for the maximum mesh size when trace modeling is enabled.

Returns:
:
int

Status code of the response. 0 for success.

Return type:

int

Examples

>>> from ansys.sherlock.core.launcher import launch_sherlock
>>> sherlock = launch_sherlock()
>>> sherlock.project.import_odb_archive(
>>>     "ODB++ Tutorial.tgz",
>>>     True,
>>>     True,
>>>     True,
>>>     True,
>>>     project="Tutorial Project",
>>>     cca_name="Card",
>>> )
>>> modeling_regions = [
>>> {
>>>     "cca_name": "Card",
>>>     "region_id": "Region001",
>>>     "region_units": "mm",
>>>     "model_mode": "Enabled",
>>>     "shape": PolygonalShape(points=[
>>>         (0, 0),
>>>         (0, 6.35),
>>>         (9.77, 0)
>>>     ], rotation=87.8),
>>>     "pcb_model_props": {
>>>         "export_model_type": "Sherlock",
>>>         "elem_order": "First_Order",
>>>         "max_mesh_size": 0.5,
>>>         "max_mesh_size_units": "mm",
>>>         "quads_preferred": True
>>>     },
>>>     "trace_model_props": {
>>>         "trace_model_type": "Enabled",
>>>         "elem_order": "Second_Order",
>>>         "trace_mesh_size": 0.3,
>>>         "trace_mesh_size_units": "mm"
>>>     }
>>> }
>>> ]
>>> result = sherlock.layer.add_modeling_region("Tutorial Project", modeling_regions)