Skip to content

Commit

Permalink
Merge remote-tracking branch 'nanograv/master'
Browse files Browse the repository at this point in the history
  • Loading branch information
paulray committed Dec 18, 2024
2 parents 5518be0 + 91be315 commit 938266f
Show file tree
Hide file tree
Showing 11 changed files with 124 additions and 68 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ci_test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -136,5 +136,5 @@ jobs:
python -m pip install --force-reinstall --no-deps .
- name: Run tests
shell: bash -el {0}
run: pytest -v --pyargs tests
run: pytest -v --pyargs tests --reruns 5

16 changes: 0 additions & 16 deletions CHANGELOG-unreleased.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,23 +9,7 @@ the released changes.

## Unreleased
### Changed
- Command line scripts now automatically do `allow_tcb` and `allow_T2` while reading par files.
- Updated the `plot_chains` function in `event_optimize` so that the subplots are a fixed size to prevent the subplots from being condensed in the case of many fit parameters.
### Added
- Time derivatives of NE_SW in `SolarWindDispersion`
- New prefix pattern for `split_prefixed_name` to handle derivatives of NE_SW
- Added an option `nbin` to `photonphase` to decide how many phase bins to use for the phaseogram
- Added an option `linearize_model` to speed up the photon phases calculation within `event_optimize` through the designmatrix.
- Added AIC and BIC calculation to be written in the post fit parfile from `event_optimize`
- When TCB->TDB conversion info is missing, will print parameter name
- Piecewise-constant model for chromatic variations (CMX)
- `add_param` returns the name of the parameter (useful for numbered parameters)
- micromamba CI environment for testing macOS-latest, without tox
### Fixed
- Changed WAVE_OM units from 1/d to rad/d.
- When EQUAD is created from TNEQ, has proper TCB->TDB conversion info
- TOA selection masks will work when only TOA is the first one
- Condense code in Glitch model and add test coverage.
### Removed
- macOS 12 CI

26 changes: 26 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,32 @@ and this project, at least loosely, adheres to [Semantic Versioning](https://sem
This file contains the released changes to the codebase. See CHANGELOG-unreleased.md for
the unreleased changes. This file should only be changed while tagging a new version.

## [1.1.1] 2024-012-18
### Changed
- Command line scripts now automatically do `allow_tcb` and `allow_T2` while reading par files.
- Updated the `plot_chains` function in `event_optimize` so that the subplots are a fixed size to prevent the subplots from being condensed in the case of many fit parameters.
### Added
- Time derivatives of NE_SW in `SolarWindDispersion`
- New prefix pattern for `split_prefixed_name` to handle derivatives of NE_SW
- Added an option `nbin` to `photonphase` to decide how many phase bins to use for the phaseogram
- Added an option `linearize_model` to speed up the photon phases calculation within `event_optimize` through the designmatrix.
- Added AIC and BIC calculation to be written in the post fit parfile from `event_optimize`
- When TCB->TDB conversion info is missing, will print parameter name
- Piecewise-constant model for chromatic variations (CMX)
- `add_param` returns the name of the parameter (useful for numbered parameters)
- Rerun intermittent failures in CI
- micromamba CI environment for testing macOS-latest, without tox
- models now have metadata dictionary
### Fixed
- Changed WAVE_OM units from 1/d to rad/d.
- When EQUAD is created from TNEQ, has proper TCB->TDB conversion info
- TOA selection masks will work when only TOA is the first one
- Condense code in Glitch model and add test coverage.
- `find_empty_masks` will now search through `CMX` parameters
- Fixed some docstrings for binary models.
### Removed
- macOS 12 CI

## [1.1] 2024-11-05
### Changed
* Bump oldest python to 3.9
Expand Down
3 changes: 2 additions & 1 deletion requirements_dev.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ wheel>=0.29.0
pytest>=4.3
pytest-cov>=2.7.1
pytest-runner>=5.1
pytest-xdist
pytest-rerunfailures
flake8>=3.7
pep8-naming>=0.8.2
flake8-docstrings>=1.4
Expand All @@ -37,4 +39,3 @@ loguru
# click<=8.0.4
gprof2dot
py-cpuinfo
pytest-xdist
43 changes: 27 additions & 16 deletions src/pint/models/binary_bt.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
class BinaryBT(PulsarBinary):
"""Blandford and Teukolsky binary model.
This binary model is described in Blandford and Teukolshy 1976. It is
This binary model is described in Blandford and Teukolsky (1976). It is
a relatively simple parametrized post-Keplerian model that does not
support Shapiro delay calculations.
Expand All @@ -36,12 +36,16 @@ class BinaryBT(PulsarBinary):
Notes
-----
Because PINT's binary models all support specification of multiple orbital
frequency derivatives FBn, this is capable of behaving like the model called
BTX in tempo2. The model called BTX in tempo instead supports multiple
(non-interacting) companions, and that is not supported here. Neither can
PINT accept "BTX" as an alias for this model.
frequency derivatives ``FBn``, this is capable of behaving like the model called
``BTX`` in ``tempo2``. The model called ``BTX`` in ``tempo`` instead supports multiple
(non-interacting) companions, and that is not supported here.
References
----------
- Blandford & Teukolsky 1976, ApJ, 205, 580 [1]_
.. [1] https://ui.adsabs.harvard.edu/abs/1976ApJ...205..580B/abstract
See Blandford & Teukolsky 1976, ApJ, 205, 580.
"""

register = True
Expand Down Expand Up @@ -82,16 +86,23 @@ def validate(self):


class BinaryBTPiecewise(PulsarBinary):
"""Model implementing the BT model with piecewise orbital parameters A1X and T0X. This model lets the user specify time ranges and fit for a different piecewise orbital parameter in each time range,
This is a PINT pulsar binary BTPiecewise model class, a subclass of PulsarBinary.
It is a wrapper for stand alone BTPiecewise class defined in
./stand_alone_psr_binary/BT_piecewise.py
The aim for this class is to connect the stand alone binary model with the PINT platform.
BTpiecewise special parameters, where xxxx denotes the 4-digit index of the piece:
T0X_xxxx Piecewise T0 values for piece
A1X_xxxx Piecewise A1 values for piece
XR1_xxxx Lower time boundary of piece
XR2_xxxx Upper time boundary of piece
"""BT model with piecewise orbital parameters ``A1X`` and ``T0X``. This model lets the user specify time ranges and fit for a different piecewise orbital parameter in each time range.
``BTpiecewise`` special parameters, where xxxx denotes the 4-digit index of the piece:
- ``T0X_xxxx``: Piecewise ``T0`` values for piece
- ``A1X_xxxx``: Piecewise ``A1`` values for piece
- ``XR1_xxxx``: Lower time boundary of piece
- ``XR2_xxxx``: Upper time boundary of piece
The actual calculations for this are done in
:class:`pint.models.stand_alone_psr_binaries.BT_piecewise.BTpiecewise`
Parameters supported:
.. paramtable::
:class: pint.models.binary_bt.BinaryBTPiecewise
"""

register = True
Expand Down
8 changes: 7 additions & 1 deletion src/pint/models/dispersion_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -627,6 +627,10 @@ def validate(self):
r2[j] = getattr(self, f"DMXR2_{index:04d}").quantity.mjd
indices[j] = index
for j, index in enumerate(DMXR1_mapping):
if (r1[j] == r2[j]) and (r1[j] > 0):
log.warning(
f"Start of DMX_{index:04d} ({r1[j]}) equal to end of DMX_{index:04d} ({r2[j]})"
)
if np.any((r1[j] > r1) & (r1[j] < r2)):
k = np.where((r1[j] > r1) & (r1[j] < r2))[0]
for kk in k.flatten():
Expand All @@ -639,6 +643,8 @@ def validate(self):
log.warning(
f"End of DMX_{index:04d} ({r1[j]}-{r2[j]}) overlaps with DMX_{indices[kk]:04d} ({r1[kk]}-{r2[kk]})"
)
if not hasattr(self, "dmx_toas_selector"):
self.dmx_toas_selector = TOASelect(is_range=True)

def validate_toas(self, toas):
DMX_mapping = self.get_prefix_mapping_component("DMX_")
Expand All @@ -651,7 +657,7 @@ def validate_toas(self, toas):
b = self._parent[DMXR1_mapping[k]].quantity.mjd * u.d
e = self._parent[DMXR2_mapping[k]].quantity.mjd * u.d
mjds = toas.get_mjds()
n = np.sum((b <= mjds) & (mjds < e))
n = np.sum((b <= mjds) & (mjds <= e))
if n == 0:
bad_parameters.append(DMX_mapping[k])
if bad_parameters:
Expand Down
5 changes: 5 additions & 0 deletions src/pint/models/model_builder.py
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,10 @@ def __call__(
if not hasattr(tm, "NoiseComponent_list"):
setattr(tm, "NoiseComponent_list", [])

tm.meta["allow_tcb"] = allow_tcb_
tm.meta["convert_tcb"] = convert_tcb
tm.meta["allow_T2"] = allow_T2

return tm

def _validate_components(self):
Expand Down Expand Up @@ -851,6 +855,7 @@ def get_model(
**kwargs,
)
model.name = parfile
model.meta["original_name"] = parfile

return model

Expand Down
29 changes: 16 additions & 13 deletions src/pint/models/noise_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -442,8 +442,7 @@ def ecorr_cov_matrix(self, toas):


class PLDMNoise(NoiseComponent):
"""Model of DM variations as radio frequency-dependent noise with a
power-law spectrum.
"""Model of DM variations as radio frequency-dependent noise with a power-law spectrum.
Variations in DM over time result from both the proper motion of the
pulsar and the changing electron number density along the line of sight
Expand All @@ -459,9 +458,11 @@ class PLDMNoise(NoiseComponent):
.. paramtable::
:class: pint.models.noise_model.PLDMNoise
Note
----
Ref: Lentati et al. 2014, MNRAS 437(3), 3004-3023
References
----------
- Lentati et al. 2014, MNRAS 437(3), 3004-3023 [1]_
.. [1] https://ui.adsabs.harvard.edu/abs/2014MNRAS.437.3004L/abstract
"""

Expand Down Expand Up @@ -558,8 +559,7 @@ def pl_dm_cov_matrix(self, toas):


class PLChromNoise(NoiseComponent):
"""Model of a radio frequency-dependent noise with a power-law spectrum and
arbitrary chromatic index.
"""Model of a radio frequency-dependent noise with a power-law spectrum and arbitrary chromatic index.
Such variations are usually attributed to time-variable scattering in the
ISM. Scattering smears/broadens the shape of the pulse profile by convolving it with
Expand All @@ -579,9 +579,11 @@ class PLChromNoise(NoiseComponent):
.. paramtable::
:class: pint.models.noise_model.PLChromNoise
Note
----
Ref: Lentati et al. 2014, MNRAS 437(3), 3004-3023
References
----------
- Lentati et al. 2014, MNRAS 437(3), 3004-3023 [1]_
.. [1] https://ui.adsabs.harvard.edu/abs/2014MNRAS.437.3004L/abstract
"""

register = True
Expand Down Expand Up @@ -692,10 +694,11 @@ class PLRedNoise(NoiseComponent):
.. paramtable::
:class: pint.models.noise_model.PLRedNoise
Note
----
Ref: Lentati et al. 2014, MNRAS 437(3), 3004-3023
References
----------
- Lentati et al. 2014, MNRAS 437(3), 3004-3023 [1]_
.. [1] https://ui.adsabs.harvard.edu/abs/2014MNRAS.437.3004L/abstract
"""

register = True
Expand Down
12 changes: 11 additions & 1 deletion src/pint/models/timing_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@

import abc
import copy
import datetime
import inspect
import contextlib
from collections import OrderedDict, defaultdict
Expand Down Expand Up @@ -109,6 +110,9 @@

ignore_prefix = {"DMXF1_", "DMXF2_", "DMXEP_"}

# prefixes of parameters that may need to be checked for empty ranges
prefixes = ["DM", "SW", "CM"]

DEFAULT_ORDER = [
"astrometry",
"jump_delay",
Expand Down Expand Up @@ -225,6 +229,8 @@ class TimingModel:
----------
name : str
The name of the timing model
meta : dict
A dictionary of metadata
component_types : list
A list of the distinct categories of component. For example,
delay components will be register as 'DelayComponent'.
Expand All @@ -239,6 +245,9 @@ def __init__(self, name="", components=[]):
"First parameter should be the model name, was {!r}".format(name)
)
self.name = name
self.meta = {
"read_time": f"{datetime.datetime.now().isoformat()}",
}
self.component_types = []
self.top_level_params = []
self.add_param_from_top(
Expand Down Expand Up @@ -2763,6 +2772,7 @@ def as_parfile(
if include_info:
info_string = pint.utils.info_string(prefix_string="# ", comment=comment)
info_string += f"\n# Format: {format.lower()}"
info_string += "".join([f"\n# {x}: {self.meta[x]}" for x in self.meta])
result_begin = info_string + "\n"
else:
result_begin = ""
Expand Down Expand Up @@ -2901,7 +2911,7 @@ def find_empty_masks(self, toas, freeze=False):
if freeze:
log.info(f"'{maskpar}' has no TOAs so freezing")
getattr(self, maskpar).frozen = True
for prefix in ["DM", "SW"]:
for prefix in prefixes:
mapping = pint.utils.xxxselections(self, toas, prefix=prefix)
for k in mapping:
if len(mapping[k]) == 0:
Expand Down
39 changes: 23 additions & 16 deletions src/pint/models/wavex.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,7 @@

class WaveX(DelayComponent):
"""
Implementation of the wave model as a delay correction
Delays are expressed as a sum of sinusoids.
Implementation of the wave model as a delay correction, with delays are expressed as a sum of sinusoids.
Used for decomposition of timing noise into a series of sine/cosine components with the amplitudes as fitted parameters.
Expand All @@ -23,25 +21,34 @@ class WaveX(DelayComponent):
.. paramtable::
:class: pint.models.wavex.WaveX
This is an extension of the L13 method described in Lentati et al., 2013 doi: 10.1103/PhysRevD.87.104021
This model is similar to the TEMPO2 WAVE model parameters and users can convert a `TimingModel` with a Wave model
to a WaveX model and produce the same results. The main differences are that the WaveX frequencies are explicitly stated,
This is an extension of the method described in Lentati et al. (2013).
This model is similar to the TEMPO2 WAVE model parameters and users can convert a :class:`~pint.models/timing_model.TimingModel`
with a :class:`~pint.models.wave.Wave` model to a ``WaveX`` model and produce the same results.
The main differences are that the ``WaveX`` frequencies are explicitly stated,
they do not necessarily need to be harmonics of some base frequency, the wave amplitudes are fittable parameters, and the
sine and cosine amplutides are reported as separate `prefixParameter`s rather than as a single `pairParameter`.
sine and cosine amplutides are reported as separate :class:`~pint.models.parameter.prefixParameter` rather than as a
single :class:`pint.models.parameter.pairParameter`.
Analogous parameters in both models have the same units:
WAVEEPOCH is the same as WXEPOCH
WAVEOM and WXFREQ_000N have units of 1/d
WAVEN and WXSIN_000N/WXCOS_000N have units of seconds
The `pint.utils` functions `translate_wave_to_wavex()` and `translate_wavex_to_wave()` can be used to go back and forth between
two model.
- ``WAVEEPOCH`` is the same as ``WXEPOCH``
- ``WAVEOM`` and ``WXFREQ_000N`` have units of 1/d
- ``WAVEN`` and ``WXSIN_000N/WXCOS_000N`` have units of seconds
The :mod:`pint.utils` functions :func:`~pint.utils.translate_wave_to_wavex` and :func:`~pint.utils.translate_wavex_to_wave`
can be used to go back and forth between two model.
WARNING: If the choice of ``WaveX`` frequencies in a :class:`~pint.models/timing_model.TimingModel` doesn't correspond to harmonics of some base
freqeuncy, it will not be possible to convert it to a :class:`~pint.models.wave.Wave` model.
To set up a ``WaveX`` model, users can use the :mod:`pint.utils` function :func:`~pint.utils.wavex_setup` with either a list of frequencies or a choice
of harmonics of a base frequency determined by ``2 * pi /Timespan``
WARNING: If the choice of WaveX frequencies in a `TimingModel` doesn't correspond to harmonics of some base
freqeuncy, it will not be possible to convert it to a Wave model.
References
----------
- Lentati et al. (2013), PRD, 87, 104021 [1]_
To set up a WaveX model, users can use the `pint.utils` function `wavex_setup()` with either a list of frequencies or a choice
of harmonics of a base frequency determined by 2 * pi /Timespan
.. [1] https://ui.adsabs.harvard.edu/abs/2013PhRvD..87j4021L/abstract
"""

register = True
Expand Down
Loading

0 comments on commit 938266f

Please sign in to comment.