File: plot_template_phase_temporal.py

package info (click to toggle)
gammapy 2.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,800 kB
  • sloc: python: 81,999; makefile: 211; sh: 11; javascript: 10
file content (43 lines) | stat: -rw-r--r-- 992 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
r"""
.. _PhaseCurve-temporal-model:

Phase curve temporal model
==========================

This model parametrises a PhaseCurve time model, i.e. with a template phasogram and timing parameters

"""

import astropy.units as u
from astropy.time import Time
from gammapy.modeling.models import (
    Models,
    PowerLawSpectralModel,
    SkyModel,
    TemplatePhaseCurveTemporalModel,
)

path = "$GAMMAPY_DATA/tests/phasecurve_LSI_DC.fits"
t_ref = 43366.275 * u.d
f0 = 1.0 / (26.7 * u.d)

phase_model = TemplatePhaseCurveTemporalModel.read(
    path, normalize=False, t_ref=t_ref, phi_ref=0.0, f0=f0
)
time_range = [Time("59100", format="mjd"), Time("59200", format="mjd")]

phase_model.plot(time_range, n_points=400)

# %%
# YAML representation
# -------------------
# Here is an example YAML file using the model:

model = SkyModel(
    spectral_model=PowerLawSpectralModel(),
    temporal_model=phase_model,
    name="phase_curve_model",
)
models = Models([model])

print(models.to_yaml())