{"cells":[{"cell_type":"markdown","metadata":{"id":"CeRA9JaXBoiP"},"source":["# Install packages\n","\n","First install packages using `pip install lalsuite pycbc` in the command line. If instead you are using Anaconda, try google it, it should be something similar."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"Hz-xz8VOBoiS"},"outputs":[],"source":["import numpy as np\n","import matplotlib.pyplot as plt\n","\n","from pycbc.waveform import get_td_waveform"]},{"cell_type":"markdown","metadata":{"id":"yfH1pDTYBoiT"},"source":["# Generating Gravitational Waveforms (GW)"]},{"cell_type":"markdown","metadata":{"id":"4sQHQv-UBoiT"},"source":["Use this PyCBC function to generate GW. We will use the `hp` waveform.\n","\n","Try changing the masses parameters yourselves to see the results! Typically we use masses between 5 and 50. The smaller the masses, the longer the signals.\n","\n","You can refer to this documentation https://pycbc.org/pycbc/latest/html/waveform.html."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"9hdY1b08BoiU","outputId":"d040852f-bc73-4a13-a391-0243af8c12c3"},"outputs":[{"name":"stdout","output_type":"stream","text":["<class 'pycbc.types.timeseries.TimeSeries'>\n","<class 'numpy.ndarray'>\n","(2048,)\n"]}],"source":["# Generate GW signal\n","hp, hc = get_td_waveform(approximant='IMRPhenomPv2', mass1=30, mass2=40,\n","                                 f_lower=30, delta_t=1/2048)\n","print(type(hc))\n","\n","# Convert to numpy array\n","wave = hp.data\n","print(type(wave))\n","print(wave.shape)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"5zofKky3BoiU","outputId":"73eb4c55-6ca7-40ad-b5da-f7a24d8d085f"},"outputs":[{"data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"needs_background":"light"},"output_type":"display_data"}],"source":["plt.figure()\n","plt.plot(wave)\n","plt.show()"]},{"cell_type":"markdown","metadata":{"id":"H5B6Od9DBoiV"},"source":["Below is a piece of function I use myself for generating random waveforms, and make their peaks aligned at some common index. You don't exactly need to use this function, but it serves as a reference."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"E3YWo50aBoiV"},"outputs":[],"source":["def get_waves(n_waves, spin, params=None):\n","    DIM = 2048     # output dimension of signals\n","    MAXLOC = int(2048*0.9)    # index of the aligned peaks\n","\n","    if params is None:\n","        if spin:\n","            params_mass = np.random.uniform(low=20, high=50, size=(n_waves,2))\n","            params_spin1 = np.random.randn(n_waves,3)\n","            params_spin1 *= 1/np.linalg.norm(params_spin1, axis=1).reshape(-1,1) * np.random.rand(n_waves,1)\n","            params_spin2 = np.random.randn(n_waves,3)\n","            params_spin2 *= 1/np.linalg.norm(params_spin2, axis=1).reshape(-1,1) * np.random.rand(n_waves,1)\n","            params = np.hstack((params_mass, params_spin1, params_spin2))\n","        else:\n","            params = np.random.uniform(low=20, high=50, size=(n_waves,2))\n","\n","    waves = np.zeros((n_waves, DIM))\n","\n","    for i in range(n_waves):\n","        if spin:\n","            hp, _ = get_td_waveform(approximant='IMRPhenomPv2', mass1=params[i][0], mass2=params[i][1],\n","                                 spin1x=params[i][2], spin1y=params[i][3], spin1z=params[i][4],\n","                                 spin2x=params[i][5], spin2y=params[i][6], spin2z=params[i][7],\n","                                 f_lower=30, delta_t=1/2048)\n","        else:\n","            hp, _ = get_td_waveform(approximant='IMRPhenomPv2', mass1=params[i][0], mass2=params[i][1],\n","                                 f_lower=30, delta_t=1/2048)\n","\n","        data = np.array(hp.data)\n","        idx = np.argmax(np.abs(data))\n","\n","        if idx >= MAXLOC:\n","            waves[i, 0:MAXLOC] = data[idx-MAXLOC : idx]\n","        else:\n","            waves[i, MAXLOC-idx : MAXLOC] = data[0:idx]\n","        if len(data)-idx >= DIM-MAXLOC:\n","            waves[i, MAXLOC:DIM] = data[idx : idx+DIM-MAXLOC]\n","        else:\n","            waves[i, MAXLOC : MAXLOC+len(data)-idx] = data[idx : len(data)]\n","\n","    return waves, params\n","\n","\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"qxuTeW6TBoiV"},"outputs":[],"source":[]}],"metadata":{"kernelspec":{"display_name":"Python 3","language":"python","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.7.1"},"colab":{"provenance":[]}},"nbformat":4,"nbformat_minor":0}