Logging

Logging#

Msprime uses the Python logging infrastructure to help debugging complex simulations. Messages at the INFO level are high-level information about the state of the current simulation, such as switches in simulation model, etc. While it is straightforward to set up logging messages using the built-in Python methods, the daiquiri library is a bit more convenient. For example,

import daiquiri
import msprime

daiquiri.setup(level="INFO")
ts = msprime.sim_ancestry(
    10,
    population_size=1000,
    model=[
        msprime.DiscreteTimeWrightFisher(duration=100),
        msprime.StandardCoalescent(),
    ],
    random_seed=1234
)
2025-01-08 11:54:22,599 [3400] INFO     msprime.ancestry: Sampling 10 individuals with ploidy 2 in population 0 (name='pop_0') at time 0
2025-01-08 11:54:22,602 [3400] INFO     msprime.ancestry: Starting replicate 0
2025-01-08 11:54:22,602 [3400] INFO     msprime.ancestry: model[0] {'name': 'dtwf'} started at time=0 nodes=20 edges=0
2025-01-08 11:54:22,603 [3400] INFO     msprime.ancestry: Running model {'name': 'dtwf'} until max time: 100.000000
2025-01-08 11:54:22,605 [3400] INFO     msprime.ancestry: model[1] {'name': 'hudson'} started at time=100 nodes=25 edges=10
2025-01-08 11:54:22,605 [3400] INFO     msprime.ancestry: Running model {'name': 'hudson'} until max time: inf
2025-01-08 11:54:22,606 [3400] INFO     msprime.ancestry: Completed at time=5876.22 nodes=39 edges=38

When running larger simulations and trying to figure out when they might finish, it can be helpful to use the DEBUG logging output. For example:

daiquiri.setup(level="DEBUG")
ts = msprime.sim_ancestry(
    10 ** 5,
    population_size=10000,
    recombination_rate=2e-8,
    sequence_length=1e6,
    random_seed=32
)
2025-01-08 11:54:22,612 [3400] INFO     msprime.ancestry: Sampling 100000 individuals with ploidy 2 in population 0 (name='pop_0') at time 0
2025-01-08 11:54:22,695 [3400] INFO     msprime.ancestry: Starting replicate 0
2025-01-08 11:54:22,704 [3400] INFO     msprime.ancestry: model[0] {'name': 'hudson'} started at time=0 nodes=200000 edges=0
2025-01-08 11:54:22,704 [3400] INFO     msprime.ancestry: Running model {'name': 'hudson'} until max time: inf
2025-01-08 11:54:22,736 [3400] DEBUG    msprime.ancestry: time=0.0104295 ancestors=190080 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,757 [3400] DEBUG    msprime.ancestry: time=0.0219435 ancestors=180166 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,779 [3400] DEBUG    msprime.ancestry: time=0.0346803 ancestors=170256 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,801 [3400] DEBUG    msprime.ancestry: time=0.0491285 ancestors=160336 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,826 [3400] DEBUG    msprime.ancestry: time=0.0657941 ancestors=150418 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,852 [3400] DEBUG    msprime.ancestry: time=0.0847891 ancestors=140540 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,882 [3400] DEBUG    msprime.ancestry: time=0.106283 ancestors=130644 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,914 [3400] DEBUG    msprime.ancestry: time=0.131827 ancestors=120740 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,951 [3400] DEBUG    msprime.ancestry: time=0.161742 ancestors=110874 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:22,991 [3400] DEBUG    msprime.ancestry: time=0.197291 ancestors=101020 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,036 [3400] DEBUG    msprime.ancestry: time=0.240122 ancestors=91192 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,088 [3400] DEBUG    msprime.ancestry: time=0.293227 ancestors=81390 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,147 [3400] DEBUG    msprime.ancestry: time=0.361519 ancestors=71580 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,215 [3400] DEBUG    msprime.ancestry: time=0.45156 ancestors=61818 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,288 [3400] DEBUG    msprime.ancestry: time=0.573763 ancestors=52074 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,373 [3400] DEBUG    msprime.ancestry: time=0.755864 ancestors=42402 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,469 [3400] DEBUG    msprime.ancestry: time=1.03995 ancestors=32814 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,579 [3400] DEBUG    msprime.ancestry: time=1.54834 ancestors=23356 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,713 [3400] DEBUG    msprime.ancestry: time=2.72085 ancestors=14190 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:23,886 [3400] DEBUG    msprime.ancestry: time=7.38436 ancestors=5736 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,032 [3400] DEBUG    msprime.ancestry: time=150.174 ancestors=558 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,050 [3400] DEBUG    msprime.ancestry: time=4639.98 ancestors=154 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,061 [3400] DEBUG    msprime.ancestry: time=17020.3 ancestors=100 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,070 [3400] DEBUG    msprime.ancestry: time=35240.4 ancestors=96 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,077 [3400] DEBUG    msprime.ancestry: time=66125.6 ancestors=62 ret=ExitReason.MAX_EVENTS
2025-01-08 11:54:24,083 [3400] DEBUG    msprime.ancestry: time=192317 ancestors=0 ret=ExitReason.COALESCENCE
2025-01-08 11:54:24,084 [3400] DEBUG    msprime.ancestry: Skipping remaining 0 models
2025-01-08 11:54:24,166 [3400] INFO     msprime.ancestry: Completed at time=192317 nodes=407802 edges=437129

In this example we run a reasonably large simulation and turn on the DEBUG output. This will then periodically (every 10,000 simulation events) print out the current time in the simulation, and the number of extant ancestral lineages.

Warning

The format of these logging messages is not fixed and may change arbitrarily in the future. If you need to obtain the information within them, please open an issue on GitHub so that we can provide a documented API for this.