Calculations/Time-Series-Analyzer/Intensity_Noise_Analysis.ipynb

130 lines
142 KiB
Plaintext
Raw Normal View History

2024-06-18 19:01:35 +02:00
{
"cells": [
{
"cell_type": "code",
"execution_count": 1,
2024-06-18 19:01:35 +02:00
"id": "6c616b70",
"metadata": {},
"outputs": [],
"source": [
"from Analyzer import *"
2024-06-18 19:01:35 +02:00
]
},
{
"cell_type": "code",
"execution_count": 2,
2024-06-18 19:01:35 +02:00
"id": "96bd598e",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Calculating power spectrum...\n"
]
},
2024-06-18 19:01:35 +02:00
{
"data": {
"image/png": "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
2024-06-18 19:01:35 +02:00
"text/plain": [
"<Figure size 1200x800 with 1 Axes>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"\"\"\"Synthetic data to validate analysis\"\"\"\n",
"# # Generate time series data with values against time in seconds\n",
"# num_seconds = 10 # Total number of seconds\n",
"# time = np.arange(0, num_seconds, 1/30) # Create timestamp index\n",
"# voltage = np.sin(2*np.pi*4*time) + np.sin(2*np.pi*7*time) + np.random.randn(len(time))*0.2 # Generate 4 Hz and 7 Hz sine wave\n",
"# data = np.column_stack((time, voltage))\n",
"\n",
"\"\"\"Real data\"\"\" \n",
"\n",
"ac_filename_list = [\"20240807/AC Coupling/P1.0_M0_OOL\",\n",
" \"20240807/AC Coupling/P5.0_M1.1_OOL\",\n",
" \"20240807/AC Coupling/P6.0_M2.1_OOL\",\n",
" \"20240807/AC Coupling/P7.0_M3.0_OOL\"]\n",
2024-06-18 19:01:35 +02:00
"\n",
"dc_filename_list = [\"20240807/DC Coupling/P1.0_M0_OOL\",\n",
" \"20240807/DC Coupling/P5.0_M1.1_OOL\",\n",
" \"20240807/DC Coupling/P6.0_M2.1_OOL\",\n",
" \"20240807/DC Coupling/P7.0_M3.0_OOL\"]\n",
2024-06-18 19:01:35 +02:00
"\n",
"idx = 3\n",
2024-06-18 19:01:35 +02:00
"\n",
"filename = ac_filename_list[idx]\n",
"dir = str(globals()['_dh'][0]).replace('\\\\','/') + \"/Time-Series-Data/\"\n",
"filepath_data = dir + filename + \".csv\"\n",
"ac_data = extract_data(filepath_data)\n",
2024-06-18 19:01:35 +02:00
"\n",
"filename = dc_filename_list[idx]\n",
"dir = str(globals()['_dh'][0]).replace('\\\\','/') + \"/Time-Series-Data/\"\n",
"filepath_data = dir + filename + \".csv\"\n",
"dc_data = extract_data(filepath_data)\n",
2024-06-18 19:01:35 +02:00
"\n",
"# Extract the first and second columns from data_array\n",
"dc_voltages = dc_data[:, 1]\n",
"ac_time = ac_data[:, 0]\n",
2024-06-18 19:01:35 +02:00
"\n",
"processed_ac_data, Sxx_smooth = compute_psd(ac_data)\n",
2024-06-18 19:01:35 +02:00
"\n",
"dt = ac_time[1] - ac_time[0] # Sampling interval / time step\n",
"N = ac_time.shape[0] # Total number of data points\n",
"f_s = 1 / dt # Sampling frequency\n",
"delta_f = f_s/N; # Step size in frequency domain\n",
2024-06-18 19:01:35 +02:00
"\n",
"Skk, RIN_Sxx_smooth = compute_RIN(dc_voltages, delta_f, Sxx_smooth)\n",
2024-06-18 19:01:35 +02:00
"\n",
"# plot_psd(processed_ac_data, Sxx_smooth, filename.split('/')[-1])\n",
2024-06-18 19:01:35 +02:00
"\n",
"plot_rin(processed_ac_data, RIN_Sxx_smooth, filename.split('/')[-1])"
2024-06-18 19:01:35 +02:00
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "1db01efd",
2024-06-18 19:01:35 +02:00
"metadata": {},
"outputs": [],
"source": [
"plot_e_folding_time(processed_ac_data, Skk, 100, 1000, filename.split('/')[-1])"
2024-06-18 19:01:35 +02:00
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "3f19dbfa",
2024-06-18 19:01:35 +02:00
"metadata": {},
"outputs": [],
"source": [
"plot_e_folding_time(processed_ac_data, Skk, 1000, 5000, filename.split('/')[-1])"
]
2024-06-18 19:01:35 +02:00
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"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.9.12"
}
},
"nbformat": 4,
"nbformat_minor": 5
}