phylogenie 2.0.8__tar.gz → 2.0.10__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 (27) hide show
  1. {phylogenie-2.0.8 → phylogenie-2.0.10}/PKG-INFO +1 -1
  2. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/configs.py +10 -3
  3. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/dataset.py +8 -6
  4. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/factories.py +6 -1
  5. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/treesimulator/gillespie.py +3 -2
  6. {phylogenie-2.0.8 → phylogenie-2.0.10}/pyproject.toml +1 -1
  7. {phylogenie-2.0.8 → phylogenie-2.0.10}/LICENSE.txt +0 -0
  8. {phylogenie-2.0.8 → phylogenie-2.0.10}/README.md +0 -0
  9. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/__init__.py +0 -0
  10. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/__init__.py +0 -0
  11. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/alisim.py +0 -0
  12. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/trees.py +0 -0
  13. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/generators/typeguards.py +0 -0
  14. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/io.py +0 -0
  15. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/main.py +0 -0
  16. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/msa.py +0 -0
  17. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/py.typed +0 -0
  18. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/skyline/__init__.py +0 -0
  19. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/skyline/matrix.py +0 -0
  20. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/skyline/parameter.py +0 -0
  21. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/skyline/vector.py +0 -0
  22. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/tree.py +0 -0
  23. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/treesimulator/__init__.py +0 -0
  24. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/treesimulator/events.py +0 -0
  25. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/treesimulator/model.py +0 -0
  26. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/typeguards.py +0 -0
  27. {phylogenie-2.0.8 → phylogenie-2.0.10}/phylogenie/typings.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: phylogenie
3
- Version: 2.0.8
3
+ Version: 2.0.10
4
4
  Summary: Generate phylogenetic datasets with minimal setup effort
5
5
  Author: Gabriele Marino
6
6
  Author-email: gabmarino.8601@gmail.com
@@ -1,6 +1,9 @@
1
1
  from pydantic import BaseModel, ConfigDict
2
2
 
3
3
  import phylogenie.typings as pgt
4
+ from phylogenie.skyline import SkylineMatrix as _SkylineMatrix
5
+ from phylogenie.skyline import SkylineParameter as _SkylineParameter
6
+ from phylogenie.skyline import SkylineVector as _SkylineVector
4
7
 
5
8
 
6
9
  class Distribution(BaseModel):
@@ -34,6 +37,10 @@ class SkylineMatrixModel(StrictBaseModel):
34
37
  change_times: ManyScalars
35
38
 
36
39
 
37
- SkylineParameter = Scalar | SkylineParameterModel
38
- SkylineVector = str | pgt.Scalar | list[SkylineParameter] | SkylineVectorModel
39
- SkylineMatrix = str | pgt.Scalar | list[SkylineVector] | SkylineMatrixModel | None
40
+ SkylineParameter = Scalar | SkylineParameterModel | _SkylineParameter
41
+ SkylineVector = (
42
+ str | pgt.Scalar | list[SkylineParameter] | SkylineVectorModel | _SkylineVector
43
+ )
44
+ SkylineMatrix = (
45
+ str | pgt.Scalar | list[SkylineVector] | SkylineMatrixModel | None | _SkylineMatrix
46
+ )
@@ -41,19 +41,21 @@ class DatasetGenerator(ABC, cfg.StrictBaseModel):
41
41
  self._generate_one(filename=filename, rng=default_rng(seed), data=data)
42
42
 
43
43
  def _generate(self, rng: Generator, n_samples: int, output_dir: str) -> None:
44
- data_dir = os.path.join(output_dir, DATA_DIRNAME)
45
- if os.path.exists(data_dir):
46
- print(f"Output directory {data_dir} already exists. Skipping.")
47
- return
48
- os.makedirs(data_dir)
49
-
50
44
  data: list[dict[str, Any]] = [{} for _ in range(n_samples)]
51
45
  if self.context is not None:
46
+ data_dir = os.path.join(output_dir, DATA_DIRNAME)
52
47
  for d, (k, v) in product(data, self.context.items()):
53
48
  args = v.model_extra if v.model_extra is not None else {}
54
49
  d[k] = np.array(getattr(rng, v.type)(**args)).tolist()
55
50
  df = pd.DataFrame([{"file_id": str(i), **d} for i, d in enumerate(data)])
56
51
  df.to_csv(os.path.join(output_dir, METADATA_FILENAME), index=False)
52
+ else:
53
+ data_dir = output_dir
54
+
55
+ if os.path.exists(data_dir):
56
+ print(f"Output directory {data_dir} already exists. Skipping.")
57
+ return
58
+ os.makedirs(data_dir)
57
59
 
58
60
  joblib.Parallel(n_jobs=self.n_jobs)(
59
61
  joblib.delayed(self.generate_one)(
@@ -80,6 +80,8 @@ def one_or_many_scalars(
80
80
  def skyline_parameter(
81
81
  x: cfg.SkylineParameter, data: dict[str, Any]
82
82
  ) -> SkylineParameterLike:
83
+ if isinstance(x, SkylineParameter):
84
+ return x
83
85
  if isinstance(x, cfg.Scalar):
84
86
  return scalar(x, data)
85
87
  return SkylineParameter(
@@ -91,6 +93,8 @@ def skyline_parameter(
91
93
  def skyline_vector(
92
94
  x: cfg.SkylineVector, data: dict[str, Any]
93
95
  ) -> SkylineVectorCoercible:
96
+ if isinstance(x, SkylineVector):
97
+ return x
94
98
  if isinstance(x, str):
95
99
  e = _eval_expression(x, data)
96
100
  if tg.is_one_or_many_scalars(e):
@@ -151,7 +155,8 @@ def skyline_matrix(
151
155
  ) -> SkylineMatrixCoercible | None:
152
156
  if x is None:
153
157
  return None
154
-
158
+ if isinstance(x, SkylineMatrix):
159
+ return x
155
160
  if isinstance(x, str):
156
161
  e = _eval_expression(x, data)
157
162
  if tg.is_one_or_many_2D_scalars(e):
@@ -6,7 +6,7 @@ from numpy.random import default_rng
6
6
  from phylogenie.skyline import SkylineParameterLike
7
7
  from phylogenie.tree import Tree
8
8
  from phylogenie.treesimulator.events import Event, get_contact_tracing_events
9
- from phylogenie.treesimulator.model import Model, is_CT_state
9
+ from phylogenie.treesimulator.model import Model
10
10
 
11
11
 
12
12
  def simulate_tree(
@@ -29,6 +29,8 @@ def simulate_tree(
29
29
  if max_tips is None and max_time == np.inf:
30
30
  raise ValueError("Either max_tips or max_time must be specified.")
31
31
 
32
+ root_states = list({e.state for e in events})
33
+
32
34
  if notification_probability:
33
35
  events = get_contact_tracing_events(
34
36
  events,
@@ -38,7 +40,6 @@ def simulate_tree(
38
40
  )
39
41
 
40
42
  n_tries = 0
41
- root_states = [e.state for e in events if not is_CT_state(e.state)]
42
43
  while max_tries is None or n_tries < max_tries:
43
44
  root_state = init_state if init_state is not None else rng.choice(root_states)
44
45
  model = Model(root_state, max_notified_contacts, notification_probability, rng)
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "phylogenie"
3
- version = "2.0.8"
3
+ version = "2.0.10"
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
File without changes