phylogenie 1.0.2__tar.gz → 1.0.3__tar.gz

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.
Files changed (38) hide show
  1. {phylogenie-1.0.2 → phylogenie-1.0.3}/PKG-INFO +1 -1
  2. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/factories.py +10 -14
  3. {phylogenie-1.0.2 → phylogenie-1.0.3}/pyproject.toml +1 -1
  4. {phylogenie-1.0.2 → phylogenie-1.0.3}/LICENSE.txt +0 -0
  5. {phylogenie-1.0.2 → phylogenie-1.0.3}/README.md +0 -0
  6. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/__init__.py +0 -0
  7. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/backend/__init__.py +0 -0
  8. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/backend/remaster/__init__.py +0 -0
  9. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/backend/remaster/generate.py +0 -0
  10. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/backend/remaster/reactions.py +0 -0
  11. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/backend/treesimulator.py +0 -0
  12. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/configs.py +0 -0
  13. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/__init__.py +0 -0
  14. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/configs.py +0 -0
  15. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/context/__init__.py +0 -0
  16. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/context/configs.py +0 -0
  17. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/context/distributions.py +0 -0
  18. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/context/factories.py +0 -0
  19. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/dataset.py +0 -0
  20. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/msas/__init__.py +0 -0
  21. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/msas/alisim.py +0 -0
  22. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/msas/base.py +0 -0
  23. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/__init__.py +0 -0
  24. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/base.py +0 -0
  25. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/remaster/__init__.py +0 -0
  26. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/remaster/configs.py +0 -0
  27. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/remaster/factories.py +0 -0
  28. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/remaster/generator.py +0 -0
  29. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/trees/treesimulator.py +0 -0
  30. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/core/typeguards.py +0 -0
  31. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/main.py +0 -0
  32. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/py.typed +0 -0
  33. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/skyline/__init__.py +0 -0
  34. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/skyline/matrix.py +0 -0
  35. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/skyline/parameter.py +0 -0
  36. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/skyline/vector.py +0 -0
  37. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/typeguards.py +0 -0
  38. {phylogenie-1.0.2 → phylogenie-1.0.3}/phylogenie/typings.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: phylogenie
3
- Version: 1.0.2
3
+ Version: 1.0.3
4
4
  Summary: Generate phylogenetic datasets with minimal setup effort
5
5
  Author: Gabriele Marino
6
6
  Author-email: gabmarino.8601@gmail.com
@@ -1,4 +1,4 @@
1
- from typing import Any, overload
1
+ from typing import Any, Literal, overload
2
2
 
3
3
  import numpy as np
4
4
 
@@ -23,10 +23,9 @@ def _eval_expression(expression: str, data: pgt.Data) -> Any:
23
23
  expression,
24
24
  {
25
25
  "__builtins__": __builtins__,
26
- # "np": np,
27
- # **{k: np.array(v) for k, v in data.items()},
26
+ "np": np,
27
+ **{k: np.array(v) for k, v in data.items()},
28
28
  },
29
- {k: np.array(v) for k, v in data.items()},
30
29
  )
31
30
  ).tolist()
32
31
 
@@ -101,20 +100,17 @@ def skyline_parameter_like_factory(
101
100
  )
102
101
 
103
102
 
104
- from typing import Literal
105
-
106
-
107
103
  @overload
108
104
  def _parse_skyline_vector_value_model(
109
105
  x: cfg.SkylineVectorValueModel, data: pgt.Data, coercible: Literal[True]
110
- ) -> SkylineVector | SkylineParameter: ...
106
+ ) -> SkylineVectorCoercible: ...
111
107
  @overload
112
108
  def _parse_skyline_vector_value_model(
113
109
  x: cfg.SkylineVectorValueModel, data: pgt.Data, coercible: Literal[False]
114
- ) -> SkylineVector: ...
110
+ ) -> SkylineVectorLike: ...
115
111
  def _parse_skyline_vector_value_model(
116
112
  x: cfg.SkylineVectorValueModel, data: pgt.Data, coercible: bool
117
- ) -> SkylineVector | SkylineParameter:
113
+ ) -> SkylineVectorCoercible:
118
114
  change_times = many_scalars_factory(x.change_times, data)
119
115
  if isinstance(x.value, str):
120
116
  e = _eval_expression(x.value, data)
@@ -132,13 +128,13 @@ def _parse_skyline_vector_value_model(
132
128
  return SkylineParameter(value=value, change_times=change_times)
133
129
  else:
134
130
  raise ValueError(
135
- f"Parsing SkylineVector value {x.value} yielded a sequence of scalars ({value}) when a nested (2D) sequence of scalars was expected."
131
+ f"Parsing SkylineVector config {x.value} yielded a sequence of scalars {value} when a nested (2D) sequence of scalars was expected."
136
132
  )
137
133
 
138
134
  Ns = {len(elem) for elem in value if tg.is_many(elem)}
139
135
  if len(Ns) > 1:
140
136
  raise ValueError(
141
- f"All elements in the value of a SkylineVector config must be scalars or have the same length (got value={value} with inconsistent lengths {Ns})."
137
+ f"All elements in the value of a SkylineVector config must be scalars or have the same length (config {x.value} yielded value={value} with inconsistent lengths {Ns})."
142
138
  )
143
139
  (N,) = Ns
144
140
  value = [[p] * N if isinstance(p, pgt.Scalar) else p for p in value]
@@ -238,13 +234,13 @@ def skyline_matrix_coercible_factory(
238
234
  n_rows = len(elem)
239
235
  if any(len(row) != n_rows for row in elem):
240
236
  raise ValueError(
241
- f"All elements in the value of a SkylineMatrix config must be scalars or square matrices (got non-square matrix: {elem})."
237
+ f"All elements in the value of a SkylineMatrix config must be scalars or square matrices (config {x.value} yeilded a non-square matrix: {elem})."
242
238
  )
243
239
  Ns.add(n_rows)
244
240
 
245
241
  if len(Ns) > 1:
246
242
  raise ValueError(
247
- f"All elements in the value of a SkylineMatrix config must be scalars or have the same square shape (got value={value} with inconsistent lengths {Ns})."
243
+ f"All elements in the value of a SkylineMatrix config must be scalars or have the same square shape (config {x.value} yielded value={value} with inconsistent lengths {Ns})."
248
244
  )
249
245
  (N,) = Ns
250
246
  value = [[[p] * N] * N if isinstance(p, pgt.Scalar) else p for p in value]
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "phylogenie"
3
- version = "1.0.2"
3
+ version = "1.0.3"
4
4
  description = "Generate phylogenetic datasets with minimal setup effort"
5
5
  authors = ["Gabriele Marino <gabmarino.8601@gmail.com>"]
6
6
  readme = "README.md"
File without changes
File without changes