Tiwave
GW waveforms with taichi-lang
Install / Use
/learn @nnrui/TiwaveREADME
tiwave - gravitational waveforms implemented using taichi-lang
<!-- [](https://nrui.github.io/tiwave/) -->
[!WARNING] This is an experimental project under active development. The design and APIs are not stable and may change frequently.
tiwave is a python implementation of several gravitational waveform models powered by taichi-lang, developed primarily for the preparatory science of space-borne gravitaional-wave missions.
This package enables high-performance waveform generation across CPUs and GPUs, while keeping pythonic usability and maintainability.
Installation
Install from PyPI:
pip install tiwave
Install the latest or specific commit version:
# install the latest development version
pip install git+https://github.com/nnrui/tiwave
# install a specific commit
pip install git+https://github.com/nnrui/tiwave@<commit-hash>
Usage
import taichi as ti
ti.init(arch=ti.cpu, default_fp=ti.f64)
import numpy as np
from tiwave.waveforms import IMRPhenomXAS
reference_frequency = 20.0
minimum_frequency = 20.0
maximum_frequency = 2048.0
sampling_rate = 4096
duration = 4.0
num_samples = int(duration * sampling_rate)
full_freqs = np.fft.rfftfreq(num_samples, 1 / sampling_rate)
freqs_mask = (full_freqs <= maximum_frequency) * (full_freqs >= minimum_frequency)
freqs = full_freqs[freqs_mask]
freqs_ti = ti.field(ti.f64, shape=freqs.shape)
freqs_ti.from_numpy(freqs)
params = dict(
mass_1=36.0,
mass_2=29.0,
chi_1=-0.4,
chi_2=0.02,
luminosity_distance=800.0,
inclination=0.4,
reference_phase=1.2,
)
xas_tiw = IMRPhenomXAS(freqs_ti, reference_frequency)
xas_tiw.update_waveform(params)
xas_tiw.waveform_container_numpy
More examples or tutorials can be found in the document.
Other Tools
If tiwave cannot meet your needs, you may find other packages for gravitaional waveform generation (welcome to open issues or pull requests if you know more):
Known Limitations
- For waveforms of X family, only the recommended configuration are implemented, except the multibanding settings which is currently not supported in
tiwave. The details of recommended settings can be found in the document oflalsimulation, LALSimIMRPhenomX.c; - The 32 mode in IMRPhenomXHM has relatively large numerical errors. However, we believe it is still safe to use for sources with moderate mass ratio and spins (more details can be found in the notebook and Appendix A in the paper);
- Currently, automatic differentiation is only available for IMRPhenomXAS, and limited to the backward mode;
Contact
The author strive to make this package easy-to-use and maintainable. But the author's experience and knowledge in software engineering is limited. Any feedback, comments, and suggestions are greatly appreciated. Feel free to open issues or contact.
Citation
If you think this package is useful, please considering cite arxiv: 2601.xxxx.
The development of this package depending on many previous works, Please cite the original works for the corresponding modules you have used.
IMRPhenomD: (validation for reimplemented IMRPhenomD in
tiwaveover the entire parameter space is still in progress)
- Sascha Husa, et al. Frequency-domain gravitational waves from nonprecessing black-hole binaries. I. New numerical waveforms and anatomy of the signal, Phys. Rev. D 93, 044006
- Sebastian Khan, et al. Frequency-domain gravitational waves from nonprecessing black-hole binaries. II. A phenomenological model for the advanced detector era, Phys. Rev. D 93, 044007
IMRPhenomXAS:
- Geraint Pratten, et al. Setting the cornerstone for a family of models for gravitational waves from compact binaries: The dominant harmonic for nonprecessing quasicircular black holes, Phys. Rev. D 102, 064001
IMRPhenomXHM:
- Cecilio García-Quirós, et al. Multimode frequency-domain model for the gravitational wave signal from nonprecessing black-hole binaries, Phys. Rev. D 102, 064002
IMRPhenomXPHM: (support for the precession effects in
tiwaveis still ongoing)
- Geraint Pratten, et al. Computationally efficient models for the dominant and subdominant harmonic modes of precessing binary black holes, Phys. Rev. D 103, 104056
- (the single-spin model) Mark Hannam, et al. Simple Model of Complete Precessing Black-Hole-Binary Gravitational Waveforms, Phys. Rev. Lett. 113, 151101
- (the double-spin model) Katerina Chatziioannou, et, al. Constructing gravitational waves from generic spin-precessing compact binary inspirals, Phys. Rev. D 95, 104004
Related Skills
node-connect
352.2kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
111.1kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
352.2kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
352.2kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
