Stretching and Uniformization¶
Import libraries¶
[1]:
import numpy as np
import matplotlib.pyplot as plt
import synthia as syn
Define plotting function¶
[2]:
def plot_profiles(ds, var_name, n_profiles=100):
_, ax = plt.subplots(figsize=(6, 4))
for column in np.random.choice(ds.column, n_profiles):
ds[var_name].sel(column=column).plot(ax=ax, c='#332288', alpha=0.15)
ax.set_ylabel('Air temperature in K')
ax.set_xlabel('Atmospheric level')
Plot source data¶
[3]:
ds_true = syn.util.load_dataset(name='SAF-Synthetic')
plot_profiles(ds_true, 'temperature_fl')
data:image/s3,"s3://crabby-images/ceca0/ceca00772abf3b8e34c5de945591212cc2457696" alt="../_images/examples_enhancement_6_0.png"
Fit copula to data¶
[4]:
parameterizer = syn.QuantileParameterizer(n_quantiles=100)
generator = syn.CopulaDataGenerator()
generator.fit(ds_true, copula=syn.GaussianCopula(), parameterize_by=parameterizer)
Generate ‘streatched’ samples¶
[5]:
N_SAMPLES = 100
ds_synthetic = generator.generate(n_samples=N_SAMPLES, uniformization_ratio=0, stretch_factor=2)
plot_profiles(ds_synthetic, 'temperature_fl')
data:image/s3,"s3://crabby-images/95d6c/95d6cd85f84029dcdd79cdc374bd5eb6b2649de7" alt="../_images/examples_enhancement_10_0.png"
Generate ‘more uniformly distributed’ samples¶
[6]:
N_SAMPLES = 100
ds_synthetic = generator.generate(n_samples=N_SAMPLES, uniformization_ratio=0.5, stretch_factor=1)
plot_profiles(ds_synthetic, 'temperature_fl')
data:image/s3,"s3://crabby-images/a0c1b/a0c1b4c5e7786b98ac14820a7aad77475d213c0f" alt="../_images/examples_enhancement_12_0.png"
[ ]: