power-grid-model-ds 1.3.3__py3-none-any.whl → 1.3.4__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- power_grid_model_ds/_core/fancypy.py +3 -19
- power_grid_model_ds/_core/model/arrays/base/array.py +8 -0
- power_grid_model_ds/_core/model/grids/base.py +18 -0
- power_grid_model_ds/_core/utils/misc.py +21 -0
- {power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/METADATA +1 -1
- {power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/RECORD +9 -9
- {power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/WHEEL +0 -0
- {power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/licenses/LICENSE +0 -0
- {power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/top_level.txt +0 -0
@@ -8,6 +8,8 @@ from typing import TYPE_CHECKING, Union
|
|
8
8
|
|
9
9
|
import numpy as np
|
10
10
|
|
11
|
+
from power_grid_model_ds._core.utils.misc import array_equal_with_nan
|
12
|
+
|
11
13
|
if TYPE_CHECKING:
|
12
14
|
from power_grid_model_ds._core.model.arrays.base.array import FancyArray
|
13
15
|
|
@@ -44,23 +46,5 @@ def sort(array: "FancyArray", axis=-1, kind=None, order=None) -> "FancyArray":
|
|
44
46
|
def array_equal(array1: "FancyArray", array2: "FancyArray", equal_nan: bool = True) -> bool:
|
45
47
|
"""Return True if two arrays are equal."""
|
46
48
|
if equal_nan:
|
47
|
-
return
|
49
|
+
return array_equal_with_nan(array1.data, array2.data)
|
48
50
|
return np.array_equal(array1.data, array2.data)
|
49
|
-
|
50
|
-
|
51
|
-
def _array_equal_with_nan(array1: "FancyArray", array2: "FancyArray") -> bool:
|
52
|
-
# np.array_equal does not work with NaN values in structured arrays, so we need to compare column by column.
|
53
|
-
# related issue: https://github.com/numpy/numpy/issues/21539
|
54
|
-
|
55
|
-
if array1.columns != array2.columns:
|
56
|
-
return False
|
57
|
-
|
58
|
-
for column in array1.columns:
|
59
|
-
column_dtype = array1.dtype[column]
|
60
|
-
if np.issubdtype(column_dtype, np.str_):
|
61
|
-
if not np.array_equal(array1[column], array2[column]):
|
62
|
-
return False
|
63
|
-
continue
|
64
|
-
if not np.array_equal(array1[column], array2[column], equal_nan=True):
|
65
|
-
return False
|
66
|
-
return True
|
@@ -323,3 +323,11 @@ class FancyArray(ABC):
|
|
323
323
|
if pandas is None:
|
324
324
|
raise ImportError("pandas is not installed")
|
325
325
|
return pandas.DataFrame(self._data)
|
326
|
+
|
327
|
+
@classmethod
|
328
|
+
def from_extended(cls: Type[Self], extended: Self) -> Self:
|
329
|
+
"""Create an instance from an extended array."""
|
330
|
+
if not isinstance(extended, cls):
|
331
|
+
raise TypeError(f"Extended array must be of type {cls.__name__}, got {type(extended).__name__}")
|
332
|
+
dtype = cls.get_dtype()
|
333
|
+
return cls(data=np.array(extended[list(dtype.names)], dtype=dtype))
|
@@ -440,6 +440,24 @@ class Grid(FancyArrayContainer):
|
|
440
440
|
set_is_feeder(grid=self)
|
441
441
|
set_feeder_ids(grid=self)
|
442
442
|
|
443
|
+
@classmethod
|
444
|
+
def from_extended(cls, extended: "Grid") -> "Grid":
|
445
|
+
"""Create a grid from an extended Grid object."""
|
446
|
+
new_grid = cls.empty()
|
447
|
+
|
448
|
+
# Add nodes first, so that branches can reference them
|
449
|
+
new_grid.append(new_grid.node.__class__.from_extended(extended.node))
|
450
|
+
|
451
|
+
for field in dataclasses.fields(cls):
|
452
|
+
if field.name == "node":
|
453
|
+
continue # already added
|
454
|
+
if issubclass(field.type, FancyArray):
|
455
|
+
extended_array = getattr(extended, field.name)
|
456
|
+
new_array = field.type.from_extended(extended_array)
|
457
|
+
new_grid.append(new_array, check_max_id=False)
|
458
|
+
|
459
|
+
return new_grid
|
460
|
+
|
443
461
|
|
444
462
|
def _add_branch_array(branch: BranchArray | Branch3Array, grid: Grid):
|
445
463
|
"""Add a branch array to the grid"""
|
@@ -39,3 +39,24 @@ def get_inherited_attrs(cls: Type, *private_attributes):
|
|
39
39
|
retrieved_attributes[private_attr] = attr_dict
|
40
40
|
|
41
41
|
return retrieved_attributes
|
42
|
+
|
43
|
+
|
44
|
+
def array_equal_with_nan(array1: np.ndarray, array2: np.ndarray) -> bool:
|
45
|
+
"""Compare two structured arrays for equality, treating NaN values as equal.
|
46
|
+
|
47
|
+
np.array_equal does not work with NaN values in structured arrays, so we need to compare column by column.
|
48
|
+
related issue: https://github.com/numpy/numpy/issues/21539
|
49
|
+
"""
|
50
|
+
if array1.dtype.names != array2.dtype.names:
|
51
|
+
return False
|
52
|
+
|
53
|
+
columns: Sequence[str] = array1.dtype.names
|
54
|
+
for column in columns:
|
55
|
+
column_dtype = array1.dtype[column]
|
56
|
+
if np.issubdtype(column_dtype, np.str_):
|
57
|
+
if not np.array_equal(array1[column], array2[column]):
|
58
|
+
return False
|
59
|
+
continue
|
60
|
+
if not np.array_equal(array1[column], array2[column], equal_nan=True):
|
61
|
+
return False
|
62
|
+
return True
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: power-grid-model-ds
|
3
|
-
Version: 1.3.
|
3
|
+
Version: 1.3.4
|
4
4
|
Summary: Power Grid Model extension which provides a grid data structure for simulation and analysis
|
5
5
|
Author-email: Contributors to the Power Grid Model project <powergridmodel@lfenergy.org>
|
6
6
|
License: MPL-2.0
|
@@ -8,7 +8,7 @@ power_grid_model_ds/generators.py,sha256=suQCHIzLOXjJj3tLn1-vuzR9m6V-bhFZQWEukTp
|
|
8
8
|
power_grid_model_ds/graph_models.py,sha256=so5niaXJqtuL0hUmtSPxV6Bven5c8DfAlF3MM4I1d28,348
|
9
9
|
power_grid_model_ds/visualizer.py,sha256=W9GfWuM-CrDTnniCj1y-lxSt6IQkLJViW5aPC4syauw,411
|
10
10
|
power_grid_model_ds/_core/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
11
|
-
power_grid_model_ds/_core/fancypy.py,sha256=
|
11
|
+
power_grid_model_ds/_core/fancypy.py,sha256=EKH1gIACBPF9lUFI4kUPZJ_peS6B_udsLTs-PysdIns,2065
|
12
12
|
power_grid_model_ds/_core/load_flow.py,sha256=2XKWHwhwvDa6hRgmlrv9XAKIZmTac4BGfpu9cZ1f_to,5832
|
13
13
|
power_grid_model_ds/_core/data_source/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
14
14
|
power_grid_model_ds/_core/data_source/generator/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -29,7 +29,7 @@ power_grid_model_ds/_core/model/arrays/base/_filters.py,sha256=68DBuliTADfp2VNKp
|
|
29
29
|
power_grid_model_ds/_core/model/arrays/base/_modify.py,sha256=TP8LojFMcZnyzhmshzNQnjlEVSZjE_xJ6BNQ4SpIBvA,2476
|
30
30
|
power_grid_model_ds/_core/model/arrays/base/_optional.py,sha256=zEEaE5z7bjLiARb8WTYsgZhbtJYAT6BTd61IUdv_YTA,288
|
31
31
|
power_grid_model_ds/_core/model/arrays/base/_string.py,sha256=H66DBYq8RHQHj6Gfn2tdEXKoL3ND64iVkZCt-Fwjdn0,3568
|
32
|
-
power_grid_model_ds/_core/model/arrays/base/array.py,sha256=
|
32
|
+
power_grid_model_ds/_core/model/arrays/base/array.py,sha256=4PyIoKF4hrKbrBSy6167glg0qI1ZtXheuj11rGZHb8s,13156
|
33
33
|
power_grid_model_ds/_core/model/arrays/base/errors.py,sha256=M62aA2pv9AlSJSvniU1IJTtRC0jvBlMYRxv2SchTdDA,475
|
34
34
|
power_grid_model_ds/_core/model/containers/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
35
35
|
power_grid_model_ds/_core/model/containers/base.py,sha256=O-GoE2oN-WJl5wKXCl3fUHbvW5qc0oZ2-oY-zUWBGbs,9037
|
@@ -51,10 +51,10 @@ power_grid_model_ds/_core/model/graphs/models/base.py,sha256=OyhSN4Vn3otM20HDBt0
|
|
51
51
|
power_grid_model_ds/_core/model/graphs/models/rustworkx.py,sha256=jccM7MUhNqH2215mk_X8ihQ-Q8IkjjRhUk4jSruaxy8,6158
|
52
52
|
power_grid_model_ds/_core/model/grids/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
53
53
|
power_grid_model_ds/_core/model/grids/_text_sources.py,sha256=3CWn0zjaUkFhrnSEIqAas52xeW0EX3EWXIXyo8XSQgw,4229
|
54
|
-
power_grid_model_ds/_core/model/grids/base.py,sha256=
|
54
|
+
power_grid_model_ds/_core/model/grids/base.py,sha256=JzM4pbDr8NwvTIe-lAjGVRGZVYWmM_3BzgWVpIJazKk,17294
|
55
55
|
power_grid_model_ds/_core/model/grids/helpers.py,sha256=lMUEER6l5MfdgLBIesSo_KnqK_K1CyRtu1dj33q924c,4244
|
56
56
|
power_grid_model_ds/_core/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
57
|
-
power_grid_model_ds/_core/utils/misc.py,sha256=
|
57
|
+
power_grid_model_ds/_core/utils/misc.py,sha256=fPjpczUr3IZ7EnAYI2darLzN2O8NJwhxgnOx7s-vU8w,2044
|
58
58
|
power_grid_model_ds/_core/utils/pickle.py,sha256=LGeTc7nu9RY1noOzLJzYaSHSWIgqzHy2xhmueKGuipc,1445
|
59
59
|
power_grid_model_ds/_core/utils/zip.py,sha256=9RtJYhjlgNZOtxr4iI-CpsjT1axw5kCCqprfTjaIsiI,2197
|
60
60
|
power_grid_model_ds/_core/visualizer/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -74,8 +74,8 @@ power_grid_model_ds/_core/visualizer/layout/header.py,sha256=el-5SlWIPeEbZZLbi3v
|
|
74
74
|
power_grid_model_ds/_core/visualizer/layout/legenda.py,sha256=8JTrMRgaYRaSIXAEoM0b3PgX7AYvW0_fHuYg8nY4y0g,2161
|
75
75
|
power_grid_model_ds/_core/visualizer/layout/search_form.py,sha256=4LPU6MjD3QEIeBEOOWBvV5-GyLMqNYWyKcUa_oWScCs,2002
|
76
76
|
power_grid_model_ds/_core/visualizer/layout/selection_output.py,sha256=fuPAdG5XmTj2E0oQ8w_tp9PGbB8bJ5fguteLtnM1EDg,534
|
77
|
-
power_grid_model_ds-1.3.
|
78
|
-
power_grid_model_ds-1.3.
|
79
|
-
power_grid_model_ds-1.3.
|
80
|
-
power_grid_model_ds-1.3.
|
81
|
-
power_grid_model_ds-1.3.
|
77
|
+
power_grid_model_ds-1.3.4.dist-info/licenses/LICENSE,sha256=GpbnG1pNl-ORtSP6dmHeiZvwy36UFli6MEZy1XlmBqo,14906
|
78
|
+
power_grid_model_ds-1.3.4.dist-info/METADATA,sha256=v75WOuMLCD-YxQdwPTYP3216PeLRyjSvgYV3c9Y38wI,8873
|
79
|
+
power_grid_model_ds-1.3.4.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
80
|
+
power_grid_model_ds-1.3.4.dist-info/top_level.txt,sha256=nJa103Eqvm5TESYEKPFVImfLg_ugGOBznikrM-rZQZg,20
|
81
|
+
power_grid_model_ds-1.3.4.dist-info/RECORD,,
|
File without changes
|
{power_grid_model_ds-1.3.3.dist-info → power_grid_model_ds-1.3.4.dist-info}/licenses/LICENSE
RENAMED
File without changes
|
File without changes
|