From 72d6ddb9ecd2e94f1f2dba08ff55ed7ff1c1a469 Mon Sep 17 00:00:00 2001 From: Jean-Baptiste Bayle <j2b.bayle@gmail.com> Date: Wed, 13 Oct 2021 16:41:55 -0700 Subject: [PATCH] Update README.md --- README.md | 101 +++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 85 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 50aa4d5..3cb08e9 100644 --- a/README.md +++ b/README.md @@ -2,24 +2,48 @@ Python package package simulating instrumental noises, the propagation of laser beams, the measurements and the on-board processing. -The HDF5 measurement file has the following structure, +The default HDF5 measurement file has the following structure, ``` - |- [[[[WIP...]]]] + |- ISC beatnote frequency (total, offsets, fluctuations), of shape (N), in Hz + | - isc_carrier_offsets + | - isc_carrier_fluctuations + | - isc_carriers + | - isc_usb_offsets + | - isc_usb_fluctuations + | - isc_usbs + | + |- ISC DWS measurements (in yaw and pitch), of shape (N), in rad + | - isc_dws_phis + | - isc_dws_etas + | + |- Measured pseudo-ranges (MPRs), of shape (N), in s + | - mprs + | + |- TM beatnote frequency (total, offsets, fluctuations), of shape (N), in Hz + | - tm_carrier_offsets + | - tm_carrier_fluctuations + | - tm_carriers + | - tm_usb_offsets + | - tm_usb_fluctuations + | - tm_usbs + | + |- REF beatnote frequency (total, offsets, fluctuations), of shape (N), in Hz + | - ref_carrier_offsets + | - ref_carrier_fluctuations + | - ref_carriers + | - ref_usb_offsets + | - ref_usb_fluctuations + | - ref_usbs | ``` -Metadata are saved as attributes of the measurement file. - -You can use pre-generated measurement files, or create your own files with custom simulation parameters. Please read carefully this README for more information. Documentation is available as docstring [for instrumental simulation](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/instrument.py) and [for noise generation](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/noises.py). - -### Use pre-generated measurement files +If the `write_all` option is set to `True`, the HDF5 measurement file also contains intermediary simulated quantities. Refer to [`Instrument.write()`](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/instrument.py) for more information. -In the table below, we list each measurement file automatically generated and available for download. We provide a link to download the measurement file, and a link to quickly visualize its content. +Metadata are saved as attributes of the measurement file. -| Name | Description | Measurement file | Figures | -|------|-------------|------------------|---------| +Please read carefully this README for more information. Documentation is available as docstring [for instrumental simulation](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/instrument.py), [for noise generation](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/noises.py), [for DSP tools](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/dsp.py), and [for container classes](https://gitlab.in2p3.fr/lisa-simulation/instrument/-/blob/master/lisainstrument/containers.py). -### Generate a custom measurement file +### Run a simulation Make sure that Python 3.7 or newer is available, and install `lisaconstants` and `lisainstrument` using [pip](https://pip.pypa.io/en/stable/), ``` @@ -27,20 +51,65 @@ pip install git+https://gitlab.in2p3.fr/lisa-simulation/python-constants.git pip install git+https://gitlab.in2p3.fr/lisa-simulation/instrument.git ``` -You can create a new measurement file, +You can run a simulation by creating an Instrument object and calling `simulate()`. ```python from lisainstrument import Instrument -Instrument().write() +instrument = Instrument() +instrument.simulate() +``` + +You can parametrize the simulation by setting the desired arguments when instantiating your instrument, or by using the convenience methods, +```python +instrument = Instrument(aafilter=None, dt=0.25, size=10000) +instrument.disable_all_noises(but='laser') +instrument.disable_dopplers() +instrument.simulate() +``` + +Set `keep_all` to `True` to keep in memory intermediary simulated quantities, +```python +instrument.simulate(keep_all=True) ``` -You can parametrize the simulation by setting the desired arguments when instantiating your instrument, +### Write to a measurement file + +You can write the results of a simulation to a measurement file (note that `simulate()` will be called before writing to disk if the simulation has not run yet), +```python +instrument = Instrument() +instrument.write() +``` + +You can specify a path to the measurement file, and set `write_all` to `True` to save intermediary simulated quantities, ```python -Instrument(aafilter=0, dt=0.25, size=10000).write() +instrument.write('my-file.h5', write_all=True) ``` ### Plot measurements -[[[[WIP...]]]] +Once the simulation has been run, can use convenience methods to plot all beatnote frequency offsets, beatnote frequency fluctuations, beatnote total frequencies, MPRs, or DWS measurements. +```python +instrument.plot_offsets() +instrument.plot_fluctuations() +instrument.plot_totals() +instrument.plot_mprs() +instrument.plot_dws() +``` + +You can skip a number of samples at the beginning, and save the figures to disk, +```python +instrument.plot_fluctuations(output='my-fluctuations.pdf', skip=500) +``` + +To plot quantities for all spacecraft or MOSAs, use the `plot()` method, +```python +instrument.isc_carrier_fluctuations.plot(output='my-figure.png', title='ISC Carrier Fluctuations') +``` +or use the usual Matplotlib functions with a single timeseries, +```python +import matplotlib.pyplot as plt +plt.plot(instrument.t, instrument.isc_carrier_fluctuations['12']) +plt.show() +``` ## Contributing -- GitLab