Skip to content

Commit

Permalink
add record_provenance argument to sim_mutations; closes #2272
Browse files Browse the repository at this point in the history
  • Loading branch information
petrelharp authored and Ben Jeffery committed Jul 8, 2024
1 parent a2d0753 commit bf7ba4c
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 15 deletions.
34 changes: 19 additions & 15 deletions msprime/mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -1562,6 +1562,7 @@ def sim_mutations(
end_time=None,
discrete_genome=None,
keep=None,
record_provenance=True,
):
"""
Simulates mutations on the specified ancestry and returns the resulting
Expand Down Expand Up @@ -1631,6 +1632,8 @@ def sim_mutations(
:param bool discrete_genome: Whether to generate mutations at only integer positions
along the genome (Default=True).
:param bool keep: Whether to keep existing mutations. (default: True)
:param bool record_provenance: If True, record all input parameters
in the tree sequence :ref:`tskit:sec_provenance`.
:return: The :class:`tskit.TreeSequence` object resulting from overlaying
mutations on the input tree sequence.
:rtype: :class:`tskit.TreeSequence`
Expand All @@ -1645,20 +1648,20 @@ def sim_mutations(
else:
seed = int(seed)

parameters = dict(
command="sim_mutations",
tree_sequence=tree_sequence,
rate=rate,
model=model,
start_time=start_time,
end_time=end_time,
discrete_genome=discrete_genome,
keep=keep,
random_seed=seed,
)
encoded_provenance = provenance.json_encode_provenance(
provenance.get_provenance_dict(parameters)
)
provenance_dict = None
if record_provenance:
parameters = dict(
command="sim_mutations",
tree_sequence=tree_sequence,
rate=rate,
model=model,
start_time=start_time,
end_time=end_time,
discrete_genome=discrete_genome,
keep=keep,
random_seed=seed,
)
provenance_dict = provenance.get_provenance_dict(parameters)

if rate is None:
rate = 0
Expand Down Expand Up @@ -1698,5 +1701,6 @@ def sim_mutations(
)

tables = tskit.TableCollection.fromdict(lwt.asdict())
tables.provenances.add_row(encoded_provenance)
if provenance_dict is not None:
tables.provenances.add_row(provenance.json_encode_provenance(provenance_dict))
return tables.tree_sequence()
8 changes: 8 additions & 0 deletions tests/test_mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,14 @@ def test_keep(self):
assert record["parameters"]["command"] == "sim_mutations"
assert record["parameters"]["keep"] == keep

def test_record_provenance(self):
ts = msprime.sim_ancestry(10, random_seed=1)
assert ts.num_provenances == 1
mutated = msprime.sim_mutations(ts, rate=1, record_provenance=True)
assert mutated.num_provenances == 2
mutated = msprime.sim_mutations(ts, rate=1, record_provenance=False)
assert mutated.num_provenances == 1


class TestMatrixMutationModel:
def validate_model(self, model):
Expand Down

0 comments on commit bf7ba4c

Please sign in to comment.