import os
import re
import numpy as np
import scipy.io as sio
from scipy.fftpack import fft
import pandas as pd
from .movie import Movie, FullFieldFlashMovie
pd.set_option('display.width', 1000)
pd.set_option('display.max_columns', 100)
#################################################
[docs]def chunks(l, n):
"""Yield successive n-sized chunks from l."""
for i in range(0, len(l), n):
yield l[i:i + n]
##################################################
[docs]def compute_FFT_OneCycle(FR, TF, downsample):
one_cyc = np.int(((1000. / downsample) / TF))
FR_cyc = list(chunks(FR, one_cyc))
if (TF == 15. or TF == 8.):
FR_cyc = FR_cyc[:-1]
FR_cyc_avg = np.mean(FR_cyc, axis=0)
y = FR_cyc_avg
AMP = 2 * np.abs(fft(y) / len(y))
F0 = 0.5 * AMP[0]
assert (F0 - np.mean(y) < 1.e-4)
F1 = AMP[1]
return F0, F1
##################################################
[docs]def create_ff_mov(frame_rate, tst, tend, xrng, yrng):
ff_mov_on = FullFieldFlashMovie(np.arange(xrng), np.arange(yrng), tst, tend, frame_rate=frame_rate,
max_intensity=1).full(t_max=tend) # +0.5)
ff_mov_off = FullFieldFlashMovie(np.arange(xrng), np.arange(yrng), tst, tend, frame_rate=frame_rate,
max_intensity=-1).full(t_max=tend) # +0.5)
return ff_mov_on, ff_mov_off
##################################################
[docs]def create_grating_movie_list(gr_dir_name):
gr_fnames = os.listdir(gr_dir_name)
gr_fnames_ord = sorted(gr_fnames, key=lambda x: (int(re.sub('\D', '', x)), x))
gr_mov_list = []
for fname in gr_fnames_ord[:5]:
movie_file = os.path.join(gr_dir_name, fname)
m_file = sio.loadmat(movie_file)
m_data_raw = m_file['mov'].T
swid = np.shape(m_data_raw)[1]
res = int(np.sqrt(swid / (8 * 16)))
m_data = np.reshape(m_data_raw, (3000, 8 * res, 16 * res))
m1 = Movie(m_data[:500, :, :], row_range=np.linspace(0, 120, m_data.shape[1], endpoint=True), col_range=np.linspace(0, 120, m_data.shape[2], endpoint=True), frame_rate=1000.)
gr_mov_list.append(m1)
return gr_mov_list
"""
##################################################
metrics_dir = os.path.join(os.path.dirname(__file__), 'cell_metrics')
def get_data_metrics_for_each_subclass(ctype):
# Load csv file into dataframe
if ctype.find('_sus') >= 0:
prs_fn = os.path.join(metrics_dir, '{}_cells_v3.csv'.format(ctype))
else:
prs_fn = os.path.join(metrics_dir, '{}_cell_data.csv'.format(ctype))
prs_df = pd.read_csv(prs_fn)
N_class, nmet = np.shape(prs_df)
# Group data by subclasses based on max F0 vals
exp_df = prs_df.iloc[:, [13, 14, 17, 18, 28, 45, 46, 47, 48, 49, 50, 51, 52, 53,
54]].copy() # Bl_lat,Wh_lat,Bl_si, wh_si, spont, 5 F0s, 5 F1s
sub_df = exp_df.iloc[:, [5, 6, 7, 8, 9]]
exp_df['max_tf'] = sub_df.idxmax(axis=1).values # sub_df.idxmax(axis=1)
exp_means = exp_df.groupby(['max_tf']).mean()
exp_std = exp_df.groupby(['max_tf']).std()
exp_nsub = exp_df.groupby(['max_tf']).size()
max_ind_arr = np.where(exp_nsub == np.max(exp_nsub))
max_nsub_ind = max_ind_arr[0][0]
# Get means and std dev for subclasses
exp_prs_dict = {}
for scn in np.arange(len(exp_nsub)):
f0_exp = exp_means.iloc[scn, 5:10].values
f1_exp = exp_means.iloc[scn, 10:].values
spont_exp = exp_means.iloc[scn, 4:5].values
if ctype.find('OFF') >= 0:
si_exp = exp_means.iloc[scn, 2:3].values
ttp_exp = exp_means.iloc[scn, 0:1].values
elif ctype.find('ON') >= 0:
si_exp = exp_means.iloc[scn, 3:4].values
ttp_exp = exp_means.iloc[scn, 1:2].values
else:
si_exp = np.NaN * np.ones((1, 5))
ttp_exp = np.NaN * np.ones((1, 2))
nsub = exp_nsub.iloc[scn]
if nsub == 1:
f0_std = np.mean(exp_std.iloc[max_nsub_ind, 5:10].values) * np.ones((1, 5))
f1_std = np.mean(exp_std.iloc[max_nsub_ind, 10:].values) * np.ones((1, 5))
spont_std = np.mean(exp_std.iloc[max_nsub_ind, 4:5].values) * np.ones((1, 5))
if ctype.find('OFF') >= 0:
si_std = np.mean(exp_std.iloc[max_nsub_ind, 2:3].values) * np.ones((1, 5))
elif ctype.find('ON') >= 0:
si_std = np.mean(exp_std.iloc[max_nsub_ind, 3:4].values) * np.ones((1, 5))
else:
si_std = np.NaN * np.ones((1, 5))
else:
f0_std = exp_std.iloc[scn, 5:10].values
f1_std = exp_std.iloc[scn, 10:].values
spont_std = exp_std.iloc[scn, 4:5].values
if ctype.find('OFF') >= 0:
si_std = exp_std.iloc[scn, 2:3].values
elif ctype.find('ON') >= 0:
si_std = exp_std.iloc[scn, 3:4].values
else:
si_std = np.NaN * np.ones((1, 5))
if ctype.find('t') >= 0:
tcross = 40.
si_inf_exp = (si_exp - tcross / 200.) * (200. / (200. - tcross - 40.))
elif ctype.find('s') >= 0:
tcross = 60.
si_inf_exp = (si_exp - tcross / 200.) * (200. / (200. - tcross - 40.))
else:
si_inf_exp = np.nan
dict_key = exp_means.iloc[scn].name[3:]
exp_prs_dict[dict_key] = {}
exp_prs_dict[dict_key]['f0_exp'] = f0_exp
exp_prs_dict[dict_key]['f1_exp'] = f1_exp
exp_prs_dict[dict_key]['spont_exp'] = spont_exp
exp_prs_dict[dict_key]['si_exp'] = si_exp
exp_prs_dict[dict_key]['si_inf_exp'] = si_inf_exp
exp_prs_dict[dict_key]['ttp_exp'] = ttp_exp
exp_prs_dict[dict_key]['f0_std'] = f0_std
exp_prs_dict[dict_key]['f1_std'] = f1_std
exp_prs_dict[dict_key]['spont_std'] = spont_std
exp_prs_dict[dict_key]['si_std'] = si_std
exp_prs_dict[dict_key]['nsub'] = nsub
exp_prs_dict[dict_key]['N_class'] = N_class
return exp_prs_dict
"""
##################################################
[docs]def check_optim_results_against_bounds(bounds, opt_wts, opt_kpeaks):
bds_wts0 = bounds[0]
bds_wts1 = bounds[1]
bds_kp0 = bounds[2]
bds_kp1 = bounds[3]
opt_wts0 = opt_wts[0]
opt_wts1 = opt_wts[1]
opt_kp0 = opt_kpeaks[0]
opt_kp1 = opt_kpeaks[1]
if (opt_wts0 == bds_wts0[0] or opt_wts0 == bds_wts0[1]):
prm_on_bds = 'w0'
elif (opt_wts1 == bds_wts1[0] or opt_wts1 == bds_wts1[1]):
prm_on_bds = 'w1'
elif (opt_kp0 == bds_kp0[0] or opt_kp0 == bds_kp0[1]):
prm_on_bds = 'kp0'
elif (opt_kp1 == bds_kp1[0] or opt_kp1 == bds_kp1[1]):
prm_on_bds = 'kp1'
else:
prm_on_bds = 'None'
return prm_on_bds
[docs]def cross_from_above(x, threshold):
"""Return the indices into *x* where *x* crosses some threshold from above."""
x = np.asarray(x)
ind = np.nonzero((x[:-1] >= threshold) & (x[1:] < threshold))[0]
if len(ind):
return ind+1
else:
return ind
#######################################################
[docs]def get_tcross_from_temporal_kernel(temporal_kernel):
max_ind = np.argmax(temporal_kernel)
min_ind = np.argmin(temporal_kernel)
temp_tcross_ind = cross_from_above(temporal_kernel[max_ind:min_ind], 0.0)
tcross_ind = max_ind + temp_tcross_ind[0]
return tcross_ind