phylogenie 1.0.6__tar.gz → 1.0.8__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 (68) hide show
  1. {phylogenie-1.0.6 → phylogenie-1.0.8}/PKG-INFO +1 -1
  2. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/backend/remaster/generate.py +8 -8
  3. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/backend/treesimulator.py +1 -0
  4. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/msas/base.py +20 -3
  5. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/remaster/generator.py +1 -1
  6. {phylogenie-1.0.6 → phylogenie-1.0.8}/pyproject.toml +1 -1
  7. phylogenie-1.0.6/phylogenie/backend/__pycache__/__init__.cpython-310.pyc +0 -0
  8. phylogenie-1.0.6/phylogenie/backend/__pycache__/treesimulator.cpython-310.pyc +0 -0
  9. phylogenie-1.0.6/phylogenie/backend/remaster/__pycache__/__init__.cpython-310.pyc +0 -0
  10. phylogenie-1.0.6/phylogenie/backend/remaster/__pycache__/generate.cpython-310.pyc +0 -0
  11. phylogenie-1.0.6/phylogenie/backend/remaster/__pycache__/reactions.cpython-310.pyc +0 -0
  12. phylogenie-1.0.6/phylogenie/core/__pycache__/__init__.cpython-310.pyc +0 -0
  13. phylogenie-1.0.6/phylogenie/core/__pycache__/configs.cpython-310.pyc +0 -0
  14. phylogenie-1.0.6/phylogenie/core/__pycache__/dataset.cpython-310.pyc +0 -0
  15. phylogenie-1.0.6/phylogenie/core/__pycache__/distributions.cpython-310.pyc +0 -0
  16. phylogenie-1.0.6/phylogenie/core/__pycache__/factories.cpython-310.pyc +0 -0
  17. phylogenie-1.0.6/phylogenie/core/__pycache__/typeguards.cpython-310.pyc +0 -0
  18. phylogenie-1.0.6/phylogenie/core/__pycache__/typings.cpython-310.pyc +0 -0
  19. phylogenie-1.0.6/phylogenie/core/context/__pycache__/__init__.cpython-310.pyc +0 -0
  20. phylogenie-1.0.6/phylogenie/core/context/__pycache__/configs.cpython-310.pyc +0 -0
  21. phylogenie-1.0.6/phylogenie/core/context/__pycache__/distributions.cpython-310.pyc +0 -0
  22. phylogenie-1.0.6/phylogenie/core/context/__pycache__/factories.cpython-310.pyc +0 -0
  23. phylogenie-1.0.6/phylogenie/core/msas/__pycache__/__init__.cpython-310.pyc +0 -0
  24. phylogenie-1.0.6/phylogenie/core/msas/__pycache__/alisim.cpython-310.pyc +0 -0
  25. phylogenie-1.0.6/phylogenie/core/msas/__pycache__/base.cpython-310.pyc +0 -0
  26. phylogenie-1.0.6/phylogenie/core/trees/__pycache__/__init__.cpython-310.pyc +0 -0
  27. phylogenie-1.0.6/phylogenie/core/trees/__pycache__/base.cpython-310.pyc +0 -0
  28. phylogenie-1.0.6/phylogenie/core/trees/__pycache__/treesimulator.cpython-310.pyc +0 -0
  29. phylogenie-1.0.6/phylogenie/core/trees/remaster/__pycache__/__init__.cpython-310.pyc +0 -0
  30. phylogenie-1.0.6/phylogenie/core/trees/remaster/__pycache__/configs.cpython-310.pyc +0 -0
  31. phylogenie-1.0.6/phylogenie/core/trees/remaster/__pycache__/factories.cpython-310.pyc +0 -0
  32. phylogenie-1.0.6/phylogenie/core/trees/remaster/__pycache__/generator.cpython-310.pyc +0 -0
  33. phylogenie-1.0.6/phylogenie/skyline/__pycache__/__init__.cpython-310.pyc +0 -0
  34. phylogenie-1.0.6/phylogenie/skyline/__pycache__/matrix.cpython-310.pyc +0 -0
  35. phylogenie-1.0.6/phylogenie/skyline/__pycache__/parameter.cpython-310.pyc +0 -0
  36. phylogenie-1.0.6/phylogenie/skyline/__pycache__/vector.cpython-310.pyc +0 -0
  37. {phylogenie-1.0.6 → phylogenie-1.0.8}/LICENSE.txt +0 -0
  38. {phylogenie-1.0.6 → phylogenie-1.0.8}/README.md +0 -0
  39. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/__init__.py +0 -0
  40. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/backend/__init__.py +0 -0
  41. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/backend/remaster/__init__.py +0 -0
  42. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/backend/remaster/reactions.py +0 -0
  43. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/configs.py +0 -0
  44. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/__init__.py +0 -0
  45. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/configs.py +0 -0
  46. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/context/__init__.py +0 -0
  47. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/context/configs.py +0 -0
  48. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/context/distributions.py +0 -0
  49. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/context/factories.py +0 -0
  50. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/dataset.py +0 -0
  51. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/factories.py +0 -0
  52. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/msas/__init__.py +0 -0
  53. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/msas/alisim.py +0 -0
  54. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/__init__.py +0 -0
  55. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/base.py +0 -0
  56. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/remaster/__init__.py +0 -0
  57. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/remaster/configs.py +0 -0
  58. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/remaster/factories.py +0 -0
  59. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/trees/treesimulator.py +0 -0
  60. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/core/typeguards.py +0 -0
  61. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/main.py +0 -0
  62. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/py.typed +0 -0
  63. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/skyline/__init__.py +0 -0
  64. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/skyline/matrix.py +0 -0
  65. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/skyline/parameter.py +0 -0
  66. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/skyline/vector.py +0 -0
  67. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/typeguards.py +0 -0
  68. {phylogenie-1.0.6 → phylogenie-1.0.8}/phylogenie/typings.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: phylogenie
3
- Version: 1.0.6
3
+ Version: 1.0.8
4
4
  Summary: Generate phylogenetic datasets with minimal setup effort
5
5
  Author: Gabriele Marino
6
6
  Author-email: gabmarino.8601@gmail.com
@@ -24,7 +24,7 @@ def _beautify_xml(xml: bytes) -> str:
24
24
 
25
25
  def _generate_config_file(
26
26
  output_xml_file: str,
27
- tree_file_name: str,
27
+ tree_filename: str,
28
28
  populations: list[str],
29
29
  init_values: list[int],
30
30
  sample_population: str,
@@ -85,7 +85,7 @@ def _generate_config_file(
85
85
  simulate.append(trajectory)
86
86
 
87
87
  logger = Element(
88
- "logger", {"spec": "Logger", "mode": "tree", "fileName": tree_file_name}
88
+ "logger", {"spec": "Logger", "mode": "tree", "fileName": tree_filename}
89
89
  )
90
90
  logger.append(
91
91
  Element(
@@ -140,7 +140,7 @@ def _postprocess_tree(input_file: str, output_file: str, attributes: list[str])
140
140
 
141
141
 
142
142
  def generate_trees(
143
- tree_file_name: str,
143
+ tree_filename: str,
144
144
  populations: str | list[str] = DEFAULT_POPULATION,
145
145
  init_population: str = DEFAULT_POPULATION,
146
146
  sample_population: str = SAMPLE_POPULATION,
@@ -158,14 +158,14 @@ def generate_trees(
158
158
  init_values[populations.index(init_population)] = 1
159
159
 
160
160
  if output_xml_file is None:
161
- xml_file = f"{tree_file_name}-temp.xml"
161
+ xml_file = f"{tree_filename}-temp.xml"
162
162
  else:
163
163
  xml_file = output_xml_file
164
164
 
165
- temp_tree_file = f"{tree_file_name}-temp.nex"
165
+ temp_tree_filename = f"{tree_filename}-temp.nex"
166
166
  _generate_config_file(
167
167
  output_xml_file=xml_file,
168
- tree_file_name=temp_tree_file,
168
+ tree_filename=temp_tree_filename,
169
169
  populations=populations,
170
170
  init_values=init_values,
171
171
  sample_population=sample_population,
@@ -181,7 +181,7 @@ def generate_trees(
181
181
  cmd.append(xml_file)
182
182
  subprocess.run(cmd, check=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
183
183
 
184
- _postprocess_tree(temp_tree_file, tree_file_name, ["type", "time"])
184
+ _postprocess_tree(temp_tree_filename, tree_filename, ["type", "time"])
185
185
  if output_xml_file is None:
186
186
  subprocess.run(["rm", xml_file], check=True)
187
- subprocess.run(["rm", temp_tree_file], check=True)
187
+ subprocess.run(["rm", temp_tree_filename], check=True)
@@ -101,6 +101,7 @@ def generate_tree(
101
101
  )
102
102
  for i, leaf in enumerate(tree.iter_leaves()):
103
103
  state: str = getattr(leaf, STATE)
104
+ delattr(leaf, STATE)
104
105
  date = tree.get_distance(leaf)
105
106
  leaf.name = f"{i}|{state}|{date}"
106
107
  save_forest([tree], output_file)
@@ -1,6 +1,7 @@
1
1
  import os
2
2
  from abc import abstractmethod
3
3
  from enum import Enum
4
+ from pathlib import Path
4
5
  from typing import Literal
5
6
 
6
7
  from numpy.random import Generator
@@ -14,9 +15,14 @@ class BackendType(str, Enum):
14
15
  ALISIM = "alisim"
15
16
 
16
17
 
18
+ MSAS_DIRNAME = "MSAs"
19
+ TREES_DIRNAME = "trees"
20
+
21
+
17
22
  class MSAsGenerator(DatasetGenerator):
18
23
  data_type: Literal[DataType.MSAS] = DataType.MSAS
19
24
  trees: TreesGeneratorConfig
25
+ keep_trees: bool = False
20
26
 
21
27
  @abstractmethod
22
28
  def _generate_one_from_tree(
@@ -24,11 +30,22 @@ class MSAsGenerator(DatasetGenerator):
24
30
  ) -> None: ...
25
31
 
26
32
  def _generate_one(self, filename: str, rng: Generator, data: pgt.Data) -> None:
27
- tree_filename = f"{filename}.temp-tree"
33
+ if self.keep_trees:
34
+ base_dir = Path(filename).parent
35
+ file_id = Path(filename).stem
36
+ tree_filename = os.path.join(base_dir, TREES_DIRNAME, file_id)
37
+ msas_dir = os.path.join(base_dir, MSAS_DIRNAME)
38
+ os.makedirs(msas_dir, exist_ok=True)
39
+ msa_filename = os.path.join(msas_dir, file_id)
40
+ else:
41
+ tree_filename = f"{filename}.temp-tree"
42
+ msa_filename = filename
43
+
28
44
  self.trees.generate_one(
29
45
  filename=tree_filename, data=data, seed=int(rng.integers(0, 2**32 - 1))
30
46
  )
31
47
  self._generate_one_from_tree(
32
- filename=filename, tree_file=f"{tree_filename}.nwk", rng=rng, data=data
48
+ filename=msa_filename, tree_file=f"{tree_filename}.nwk", rng=rng, data=data
33
49
  )
34
- os.remove(f"{tree_filename}.nwk")
50
+ if not self.keep_trees:
51
+ os.remove(f"{tree_filename}.nwk")
@@ -51,7 +51,7 @@ class ReMASTERGenerator(TreesGenerator):
51
51
  self, filename: str, rng: Generator, data: pgt.Data, reactions: list[Reaction]
52
52
  ) -> None:
53
53
  generate_trees(
54
- tree_file_name=f"{filename}.nwk",
54
+ tree_filename=f"{filename}.nwk",
55
55
  populations=self.populations,
56
56
  init_population=self.init_population.format(**data),
57
57
  sample_population=self.sample_population,
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "phylogenie"
3
- version = "1.0.6"
3
+ version = "1.0.8"
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