This repository has been archived on 2025-05-05. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
internship/olaflow/processing/sws_wavedict.py

47 lines
1,016 B
Python
Raw Normal View History

2022-04-08 13:18:55 +02:00
import argparse
import configparser
import logging
import pathlib
import matplotlib.pyplot as plt
import numpy as np
from scipy import interpolate
from scipy import fft
from .olaflow import OFModel
parser = argparse.ArgumentParser(description="Convert swash output to olaFlow input")
parser.add_argument("-v", "--verbose", action="count", default=0)
parser.add_argument("-c", "--config", default="config.ini")
args = parser.parse_args()
logging.basicConfig(level=max((10, 20 - 10 * args.verbose)))
log = logging.getLogger("sws_ola")
log.info("Starting sws -> olaFlow converter")
config = configparser.ConfigParser()
config.read(args.config)
sws_out = pathlib.Path(config.get("swash", "np_out"))
def data(var):
return np.load(sws_out.joinpath(f"{var}.npy"))
x = data("x")
t = data("t")
watl = data("watl")
arg_x0 = np.argmin(np.abs(x+1250))
wl = watl[:, arg_x0]
f = fft.rfftfreq(t.size, np.diff(t).mean())
w_fft = fft.rfft(wl)
amp = np.abs(w_fft)
phi = np.angle(w_fft)
print(f, amp, phi, sep="\n")