From 65f9d57eb20b0f8268c30a3e5834a9d4c45faa0d Mon Sep 17 00:00:00 2001 From: Angela Yueran Jia Date: Thu, 22 Aug 2024 13:30:48 -0700 Subject: [PATCH] Add prediction visualization --- model_analysis.py | 99 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 99 insertions(+) create mode 100644 model_analysis.py diff --git a/model_analysis.py b/model_analysis.py new file mode 100644 index 0000000..2d2a29b --- /dev/null +++ b/model_analysis.py @@ -0,0 +1,99 @@ +import os, sys, glob +import h5py +import numpy as np +import matplotlib.pyplot as plt +import matplotlib as mpl +import torch +import lightning as L +from torch.utils.data import Dataset, DataLoader + +import train +import decoder + +N = 16384 +SMPL_RATE_DEC1 = 125e6 +decimation = 256 +smpl_rate = SMPL_RATE_DEC1/decimation +time_data = np.linspace(0, N-1, num=N) / smpl_rate + +valid_file = 'C:\\Users\\aj14\\Desktop\\SMI\\data\\valid_30to1kHz_2kshots_dec=256_randampl.h5py' +train_file = 'C:\\Users\\aj14\\Desktop\\SMI\\data\\training_30to1kHz_10kshots_dec=256_randampl.h5py' +test_file = 'C:\\Users\\aj14\\Desktop\\SMI\\data\\test_30to1kHz_2kshots_dec=256_randampl.h5py' + +model_tag = "fu7qnzar" +step = 128 +batch_size = 128 + +runner = train.TrainingRunner(train_file, valid_file, test_file, step=step) +model, result = runner.load_model(model_tag) + +train_mode = True + +if train_mode: + iter_loader = iter(runner.train_loader) +else: + iter_loader = iter(runner.test_loader) +# for i in range(9): +# next(iter_loader) +batch_val = next(iter_loader) +batches = [batch_val] + +for batch in batches: + ## Plot results + inputs = batch[0] + targets = batch[1] + + print(inputs.shape) + print(targets.shape) + outputs_val, _ = model.predict_step(batch, 1, test_mode=True) + + outputs_val = torch.squeeze(outputs_val).cpu().detach().numpy() + inputs_val = torch.squeeze(inputs).cpu().detach().numpy() + targets_val = torch.squeeze(targets).cpu().detach().numpy() + + targets_squeezed_val = np.squeeze(targets_val) + print("targets shape", targets_squeezed_val.shape) + outputs_squeezed_val = np.squeeze(outputs_val) + print("preds shape", outputs_squeezed_val.shape) + + fig, ax = plt.subplots(2) + fig.set_size_inches(8, 6) + + if train_mode: + inputs_flattened = inputs_val.flatten() + ax[0].plot(inputs_flattened) + ax[0].set_title('Training PD Trace (scrambled buffer)', fontsize=15) + ax[0].set_ylabel('V', fontsize=15) + ax[0].set_xticks([]) + ax[0].tick_params(axis='y', which='major', labelsize=13) + # ax[0].set_xlabel('Time (s)') + ax[1].plot(targets_squeezed_val, marker='.', label='Target') + ax[1].set_title('Velocity', fontsize=15) + ax[1].set_ylabel('um/s', fontsize=15) + ax[1].set_xlabel('Batch Idx', fontsize=15) + + ax[1].plot(outputs_squeezed_val, marker='.', label='Pred') + ax[1].legend(prop={'size': 12}) + ax[1].tick_params(axis='both', which='major', labelsize=13) + else: + idx = 0 + ax[0].plot(time_data, inputs_val[idx]) + ax[0].set_title('Test PD Trace (contiguous buffer)', fontsize=15) + ax[0].set_ylabel('V', fontsize=15) + ax[0].set_xticks([]) + ax[0].tick_params(axis='y', which='major', labelsize=13) + # ax[0].set_xlabel('Time (s)') + num_groups = outputs_squeezed_val.shape[1] # 127 + start_idxs = torch.arange(num_groups) * step + + ax[1].plot(time_data[start_idxs], targets_squeezed_val[idx], marker='.', label='Target') + ax[1].set_title('Velocity', fontsize=15) + ax[1].set_ylabel('um/s', fontsize=15) + ax[1].set_xlabel('Time (s)', fontsize=15) + + ax[1].plot(time_data[start_idxs], outputs_squeezed_val[idx], marker='.', label='Pred') + ax[1].legend(prop={'size': 12}) + ax[1].tick_params(axis='both', which='major', labelsize=13) + + fig.tight_layout() + plt.show() \ No newline at end of file