Skip to content

pta_importer

Import PTA data.

Functions

get_ephem_conv

get_ephem_conv(par_file: str) -> str

Get the ephemeris convention used in par files.

PARAMETER DESCRIPTION
par_file

Path to the par file.

TYPE: str

RETURNS DESCRIPTION
ephem

The ephemeris convention used in the par file.

TYPE: str

Source code in src/ptarcade/pta_importer.py
def get_ephem_conv(par_file: str) -> str:
    """Get the ephemeris convention used in par files.

    Parameters
    ----------
    par_file : str
        Path to the par file.

    Returns
    -------
    ephem : str
        The ephemeris convention used in the par file.

    """
    f = open(par_file)
    lines = f.readlines()

    for line in lines:
        line = line.split() # type: ignore
        if line[0] == "EPHEM":
            ephem = line[-1]

    f.close()

    return ephem

get_pulsars

get_pulsars(
    pta_data: str, filters: list[str] | None = None
) -> list[Pulsar]

Get Pulsar data.

If pta_data is a file, attempt to load it as a pickle. If it is a directory, read in the par and tim files within.

PARAMETER DESCRIPTION
pta_data

Filename for pickle or directory containing par and tim files.

TYPE: str

filters

Selective filter for par and tim files.

TYPE: list[str] DEFAULT: None

RETURNS DESCRIPTION
psrs

List containing pulsar data from pta_data.

TYPE: list[Pulsar]

RAISES DESCRIPTION
SystemExit

If pta_data is not a file or directory.

Source code in src/ptarcade/pta_importer.py
def get_pulsars(pta_data: str, filters: list[str] | None = None) -> list[Pulsar]:
    """Get Pulsar data.

    If `pta_data` is a file, attempt to load it as a pickle. If it is a
    directory, read in the par and tim files within.

    Parameters
    ----------
    pta_data : str
        Filename for pickle or directory containing par and tim files.
    filters : list[str]
        Selective filter for par and tim files.

    Returns
    -------
    psrs : list[Pulsar]
        List containing pulsar data from `pta_data`.

    Raises
    ------
    SystemExit
        If `pta_data` is not a file or directory.

    """
    if os.path.isfile(pta_data):
        with get_readable_fileobj(pta_data, "binary") as handle:
            psrs = pickle.load(handle)

        return psrs

    elif os.path.isdir(pta_data):
        parfiles = sorted(glob.glob(os.path.join(pta_data, "*.par")))
        timfiles = sorted(glob.glob(os.path.join(pta_data, "*.tim")))

        # filter
        if filters is not None:
            parfiles = [x for x in parfiles if x.split("/")[-1].split(".")[0] in filters]
            timfiles = [x for x in timfiles if x.split("/")[-1].split(".")[0] in filters]
        # TODO Need to check that all tim and par files have matches!

        # load the pulsars into enterprise
        psrs = []
        for p, t in zip(parfiles, timfiles):
            ephemeris = get_ephem_conv(p)
            psr = Pulsar(p, t, ephem=ephemeris)
            psrs.append(psr)

        return psrs
    else:
        err = f"'pta_data' is not correct. Must be path or file.\nCurrent value is {pta_data=}."
        log.error(err)
        raise SystemExit

get_wn

get_wn(wn_data: str | None) -> dict | None

Get whitenoise data.

PARAMETER DESCRIPTION
wn_data

File or directory containing whitenoise data.

TYPE: str

RETURNS DESCRIPTION
dict | None

If wn_data isn't None, then the whitenoise data is returned as a dict

Source code in src/ptarcade/pta_importer.py
def get_wn(wn_data: str | None) -> dict | None :
    """Get whitenoise data.

    Parameters
    ----------
    wn_data : str, optional
        File or directory containing whitenoise data.

    Returns
    -------
    dict | None
        If `wn_data` isn't `None`, then the whitenoise data is returned as a
        `dict`

    """
    params = {}
    if wn_data is None:
        return None

    elif os.path.isfile(wn_data):
        with open(wn_data) as fp:
            params.update(json.load(fp))

        return params

    elif os.path.isdir(wn_data):
        for filename in os.listdir(wn_data):
            with open(os.path.join(wn_data, filename)) as f:
                data = json.load(f)
                for key, value in data.items():
                    params.update({key: value})

        return params

    else:
        err = f"'wn_data' is not correct. Must be path, file, or None.\nCurrent value is {wn_data=}."
        log.error(err)
        raise SystemExit

pta_data_importer

pta_data_importer(
    pta_data: str | dict,
) -> tuple[list[Pulsar], dict | None, array_like | None]

Import PTA pulsars objects, white noise parameters, and empirical distributions.

PARAMETER DESCRIPTION
pta_data
  • If string, must be one of ["NG15", "NG12", "IPTA2"].
  • If dict, must have keys ["psrs_data", "noise_data", "emp_dist"]

TYPE: str | dict

RETURNS DESCRIPTION
psrs

List of Pulsar objects

TYPE: list[Pulsar]

params

Dictionary containing noise data

TYPE: dict | None

emp_dist

The empirical distribution to use for sampling

TYPE: _ArrayLikeFloat_co | None

RAISES DESCRIPTION
SystemExit

If pta_data is not str or dict.

Source code in src/ptarcade/pta_importer.py
def pta_data_importer(pta_data: str | dict) -> tuple[list[Pulsar], dict | None, array_like | None]:
    """Import PTA pulsars objects, white noise parameters, and empirical distributions.

    Parameters
    ----------
    pta_data : str | dict
        * If string, must be one of ["NG15", "NG12", "IPTA2"].
        * If dict, must have keys ["psrs_data", "noise_data", "emp_dist"]

    Returns
    -------
    psrs : list[Pulsar]
        List of Pulsar objects
    params : dict | None
        Dictionary containing noise data
    emp_dist : array_like | None
        The empirical distribution to use for sampling

    Raises
    ------
    SystemExit
        If `pta_data` is not str or dict.

    """
    if pta_data == "NG15":
        # This returns a path in the astropy cache that points to these files, otherwise
        # it downloads them there and returns the path

        ng15_dic = {
            "psrs_data": download_file(
                "https://zenodo.org/record/8102748/files/ng15_psrs_v1p1.pkl.gz?download=1",
                show_progress=True,
                cache=True,
                pkgname="ptarcade",
            ),
            "noise_data": download_file(
                "https://zenodo.org/record/8102748/files/ng15_wn_v1p1.json?download=1",
                show_progress=True,
                cache=True,
                pkgname="ptarcade",
            ),
            "emp_dist": download_file(
                "https://zenodo.org/record/8102748/files/ng15_emp_v1p1.pkl?download=1",
                show_progress=True,
                cache=True,
                pkgname="ptarcade",
            ),
        }

        psrs = get_pulsars(ng15_dic["psrs_data"])
        params = get_wn(ng15_dic["noise_data"])
        emp_dist = ng15_dic["emp_dist"]

    elif pta_data == "NG12":
        ng12_dic = {
            "psrs_data": download_file(
                "https://zenodo.org/record/8092873/files/ng12_psrs_v4.pkl.gz?download=1",
                cache=True,
                pkgname="ptarcade",
            ),
            "noise_data": download_file(
                "https://zenodo.org/record/8092873/files/ng12_wn_v4.json?download=1",
                cache=True,
                pkgname="ptarcade",
            ),
            "emp_dist": None,
        }

        psrs = get_pulsars(ng12_dic["psrs_data"])
        params = get_wn(ng12_dic["noise_data"])
        emp_dist = ng12_dic["emp_dist"]

    elif pta_data == "IPTA2":
        ipta2_dic = {
            "psrs_data": download_file(
                "https://zenodo.org/record/8092873/files/ipta2_psrs_de438.pkl.gz?download=1",
                cache=True,
                pkgname="ptarcade",
            ),
            "noise_data": download_file(
                "https://zenodo.org/record/8092873/files/ipta2_wn_de438.json?download=1",
                cache=True,
                pkgname="ptarcade",
            ),
            "emp_dist": None,
        }

        psrs = get_pulsars(ipta2_dic["psrs_data"])
        params = get_wn(ipta2_dic["noise_data"])
        emp_dist = ipta2_dic["emp_dist"]

    elif isinstance(pta_data, dict):
        psrs = get_pulsars(pta_data["psrs_data"])
        params = get_wn(pta_data["noise_data"])
        emp_dist = pta_data["emp_dist"]

    else:
        err = f"'pta_data' is not correct\n.Current value is {pta_data=}."
        log.error(err)
        raise SystemExit

    return psrs, params, emp_dist