-
Notifications
You must be signed in to change notification settings - Fork 1
/
utils.py
44 lines (35 loc) · 1.27 KB
/
utils.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import numpy as np
class AttributeDict(dict):
def __getattr__(self, attr):
return self[attr]
def __setattr__(self, attr, value):
self[attr] = value
class Recorder():
def __init__(self, inst, rec_vars_list, time, dt):
self.inst = inst
self.time = time
self.dt = dt
self.out = {}
for item in rec_vars_list:
self.out[item] = np.zeros(int(time/dt))
self.rec_vars_list = rec_vars_list
def update(self, ii):
for item in self.rec_vars_list:
try:
self.out[item][ii] = getattr(self.inst, item)
except AttributeError: # go deeper
start = self.inst
for sub_i in item.split('.'):
start = getattr(start, sub_i)
self.out[item][ii] = start
return
def adjust_var(self, item, spike_times, preset):
tt = np.arange(0, self.time, self.dt)
idxs = np.where(np.in1d(tt, np.array(spike_times)))[0]
new_vals = np.array(self.out[item])
new_vals[idxs] = preset
self.out[item] = list(new_vals)
def Q_nak(tt, fact=1, tau_Q=100, tau_rise=0.6):
vals = 1/(1*np.exp((tt-1)/tau_Q) + 30*np.exp(-(tt-3)/tau_rise))
nrm = np.max(vals)
return fact*vals/nrm