Accelerating gravitational wave template generation with machine learning.
Project description
Machine Learning for Gravitational Waves from Binary Neutron Star mergers
This package's purpose is to speed up the generation of template gravitational waveforms for binary neutron star mergers by training a machine learning model on a dataset of waveforms generated with some physically-motivated surrogate.
It is able to reconstruct them with mismatches lower than 1/10000, with as little as 1000 training waveforms; the accuracy then steadily drops as more training waveforms are used.
Currently, the only model used for training is TEOBResumS
,
but it is planned to introduce the possibility to use others.
The documentation is currently hosted here; in the future it will be moved to a better place and inserted into the CI pipeline.
Installation
When the package will be published hopefully it will look like
pip install mlgw_bns
but for now one should clone this repo, install poetry and run
poetry install
in the project folder.
For this to work, the TEOBResumS
repository must be installed in the same folder
as mlgw_bns
:
some_folder/
|--- mlgw_bns/
|--- mlgw_bns/
|--- docs/
|--- tests/
|--- ...
|--- teobresums/
|--- Python/
|--- C/
|--- ...
Usage
To make sure everything is working properly one can run a pipeline
poetry run tox
which will install all missing dependencies,
run tests and also build the documentation locally, in the folder docs/html/
;
one can access it starting from index.html
.
To only run the tests, do
poetry run pytest
To only build the documentation, do
poetry run sphinx-build docs docs/html
Make a pretty dependency graph with
poetry run pydeps mlgw_bns/
To make an html page showing the test coverage of the code, do
poetry run coverage html
There are pre-commit hooks which will clean up the code,
format everything with black
, check that there are no large files,
check that the typing is correct with mypy
.
Inner workings
The main steps taken by mlgw_bns
to train on a dataset are as follows:
- generate the dataset
- decompose the Fourier transforms of the waveforms into phase and amplitude
- downsample the dataset to a few thousand points
- apply a PCA to reduce the dimensionality to a few tens of real numbers
- train a neural network on the relation between the waveform parameters and the PCA components
In several of these steps data-driven optimizations are performed:
- the points at which the waveforms are downsampled are not uniformly chosen: instead, a greedy downsampling algorithm determines them
- the PCA is trained on a separate downsampled dataset, which is then thrown out
- the hyperparameters for the neural network are optimized according to both the time taken for the training and the estimated reconstruction error
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file mlgw_bns-0.6.0.tar.gz
.
File metadata
- Download URL: mlgw_bns-0.6.0.tar.gz
- Upload date:
- Size: 3.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.12 CPython/3.9.9 Linux/5.13.0-28-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 39bcf1f01725fbf17b2d7a3d8787ec6b34a01fe33b3dcdcf0d4c4ab6e03a7d51 |
|
MD5 | ca49a24ccd0bdcdb1fb7c135003b1939 |
|
BLAKE2b-256 | dbd67985e73b2a863bad600b4d467ab62d6c180c608c9228858fbe3283a2c32a |
File details
Details for the file mlgw_bns-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: mlgw_bns-0.6.0-py3-none-any.whl
- Upload date:
- Size: 3.6 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.12 CPython/3.9.9 Linux/5.13.0-28-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bb1f1426c16539962db3ef100fc1201d2106ad33fdcda6d7eb5aa3bc9cef29c3 |
|
MD5 | c6c9e5d67b604253005db224356de668 |
|
BLAKE2b-256 | bcfbaac5928a06146f91a05c5bcd1128aa7b4f9f4256665840f49d46a54160cf |