From 1df26cb37e45d6e0a1094b64733854e5d4ef062d Mon Sep 17 00:00:00 2001 From: svandenb-dev Date: Fri, 21 Jun 2024 15:40:33 +0200 Subject: [PATCH 1/5] hfsspi SimsetupInfo bug fixed --- .../edb_core/edb_data/hfss_pi_simulation_setup_data.py | 2 +- src/pyedb/dotnet/edb_core/utilities/simulation_setup.py | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py b/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py index 299f839c7f..8d7e5d9e10 100644 --- a/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py +++ b/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py @@ -39,7 +39,7 @@ def __init__(self, pedb, edb_object=None): def create(self, name=None): """Create an HFSS setup.""" self._name = name - self._create(name) + self._create(name=name, simulation_setup_type=self._setup_type) return self @property diff --git a/src/pyedb/dotnet/edb_core/utilities/simulation_setup.py b/src/pyedb/dotnet/edb_core/utilities/simulation_setup.py index 4408f14fab..4bf44e4a78 100644 --- a/src/pyedb/dotnet/edb_core/utilities/simulation_setup.py +++ b/src/pyedb/dotnet/edb_core/utilities/simulation_setup.py @@ -100,7 +100,11 @@ def __init__(self, pedb, edb_object=None): @property def sim_setup_info(self): - return SimSetupInfo(self._pedb, sim_setup=self, edb_object=self._edb_object.GetSimSetupInfo()) + if self.type not in ["hfss_pi", "raptor_x"]: + return SimSetupInfo(self._pedb, sim_setup=self, edb_object=self._edb_object.GetSimSetupInfo()) + else: + if self._edb_setup_info: + return SimSetupInfo(self._pedb, sim_setup=self, edb_object=self._edb_setup_info) @sim_setup_info.setter def sim_setup_info(self, sim_setup_info): From 19355561b973aa5de048dc47d0e27c105b858932 Mon Sep 17 00:00:00 2001 From: svandenb-dev Date: Tue, 25 Jun 2024 20:12:45 +0200 Subject: [PATCH 2/5] temp --- .../dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py | 0 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py diff --git a/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py b/src/pyedb/dotnet/edb_core/edb_data/hfss_pi_simulation_setup_data.py deleted file mode 100644 index e69de29bb2..0000000000 From 7471fa1934daf85a8ac42a9e2629f5dc06d4b994 Mon Sep 17 00:00:00 2001 From: svandenb-dev Date: Tue, 20 Aug 2024 16:06:52 +0200 Subject: [PATCH 3/5] create port in pin exception handling --- src/pyedb/dotnet/edb_core/components.py | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/pyedb/dotnet/edb_core/components.py b/src/pyedb/dotnet/edb_core/components.py index 0c2a22b684..d2bd66de62 100644 --- a/src/pyedb/dotnet/edb_core/components.py +++ b/src/pyedb/dotnet/edb_core/components.py @@ -848,12 +848,14 @@ def create_port_on_pins(self, refdes, pins, reference_pins, impedance=50.0, port if len([pin for pin in pins if isinstance(pin, str)]) == len(pins): cmp_pins = [] for pin_name in pins: - cmp_pin = [pin for pin in list(refdes_pins.values()) if pin_name == pin.name] - if not cmp_pin: - cmp_pin = [pin for pin in list(refdes_pins.values()) if pin_name == pin.name.split("-")[1]] - if cmp_pin: - cmp_pins.append(cmp_pin[0]) + cmp_pins = [pin for pin in list(refdes_pins.values()) if pin_name == pin.name] + if not cmp_pins: + for pin in list(refdes_pins.values()): + if pin.name and "-" in pin.name: + if pin_name == pin.name.split("-")[1]: + cmp_pins.append(pin) if not cmp_pins: + self._logger.warning("No pin found for creating port, skipping.") return pins = cmp_pins if not len([pin for pin in pins if isinstance(pin, EDBPadstackInstance)]) == len(pins): @@ -869,6 +871,7 @@ def create_port_on_pins(self, refdes, pins, reference_pins, impedance=50.0, port elif "-" in ref_pin_name and ref_pin_name.split("-")[1] in refdes_pins: ref_cmp_pins.append(refdes_pins[ref_pin_name.split("-")[1]]) if not ref_cmp_pins: + self._logger.warning("No reference pins found during port creation. Port is not defined.") return reference_pins = ref_cmp_pins if not reference_pins: From 49d939b7657fdd7d99af07717b9ac926ad57be00 Mon Sep 17 00:00:00 2001 From: svandenb-dev Date: Tue, 14 Jan 2025 09:25:46 +0100 Subject: [PATCH 4/5] meshing error fix --- src/pyedb/dotnet/edb.py | 1 + tests/legacy/system/test_edb.py | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/pyedb/dotnet/edb.py b/src/pyedb/dotnet/edb.py index 6562606753..9d91d6c78d 100644 --- a/src/pyedb/dotnet/edb.py +++ b/src/pyedb/dotnet/edb.py @@ -4564,6 +4564,7 @@ def create_model_for_arbitrary_wave_ports( port_poly = cloned_edb.modeler.create_polygon( main_shape=void_info[0].polygon_data._edb_object, layer_name="ref", net_name="GND" ) + port_poly.scale(1.05) pec_poly = cloned_edb.modeler.create_polygon( main_shape=port_poly.polygon_data._edb_object, layer_name="port_pec", net_name="GND" ) diff --git a/tests/legacy/system/test_edb.py b/tests/legacy/system/test_edb.py index 7971e0aed7..211440484d 100644 --- a/tests/legacy/system/test_edb.py +++ b/tests/legacy/system/test_edb.py @@ -1723,7 +1723,7 @@ def test_workflow(self, edb_examples): assert path_bom.exists() edbapp.close() - def test_create_port_ob_component_no_ref_pins_in_component(self, edb_examples): + def test_create_port_on_component_no_ref_pins_in_component(self, edb_examples): from pyedb.generic.constants import SourceType edbapp = edb_examples.get_no_ref_pins_component() From db8f027de2aff40705f9e84b251618589c30f6d7 Mon Sep 17 00:00:00 2001 From: svandenb-dev Date: Tue, 14 Jan 2025 09:41:56 +0100 Subject: [PATCH 5/5] meshing error fix --- src/pyedb/dotnet/edb.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pyedb/dotnet/edb.py b/src/pyedb/dotnet/edb.py index 9d91d6c78d..eb7b7ac4f4 100644 --- a/src/pyedb/dotnet/edb.py +++ b/src/pyedb/dotnet/edb.py @@ -4564,7 +4564,7 @@ def create_model_for_arbitrary_wave_ports( port_poly = cloned_edb.modeler.create_polygon( main_shape=void_info[0].polygon_data._edb_object, layer_name="ref", net_name="GND" ) - port_poly.scale(1.05) + port_poly.scale(1.1) pec_poly = cloned_edb.modeler.create_polygon( main_shape=port_poly.polygon_data._edb_object, layer_name="port_pec", net_name="GND" )