-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathdemo.m
39 lines (31 loc) · 1.13 KB
/
demo.m
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
clear, clc,
% set simulation metadata
T = 1000; % # of time steps
V.dt = 1/8; % time step size
% initialize params
P.a = 1; % observation scale
P.b = 0; % observation bias
tau = 1.5; % decay time constant
P.gam = 1-V.dt/tau; % C(t) = gam*C(t-1)
P.lam = 0.1; % firing rate = lam/dt
P.sig = 0.1; % standard deviation of observation noise
% simulate data
N = poissrnd(P.lam*V.dt*ones(T,1)); % simulate spike train
C = filter(1,[1 -P.gam],N); % calcium concentration
F = P.a*C+P.b + P.sig*randn(T,1); % observations
% fast oopsi
[Nhat Phat] = fast_oopsi(F,V,P);
% smc-oopsi
V.smc_iter_max = 1;
[M P V] = smc_oopsi(F,V,P);
%% plot results
figure(1), clf
tvec=0:V.dt:(T-1)*V.dt;
h(1)=subplot(411); plot(tvec,F); axis('tight'), ylabel('F (au)')
h(2)=subplot(412); plot(tvec,C); axis('tight'), ylabel('C (au)')
h(3)=subplot(413); stem(tvec,N); hold on, plot(tvec,Nhat,'r','linewidth',1), axis('tight'), ylabel('fast')
Nsmc = M.nbar/max(M.nbar);
Nsmc(Nsmc<0.1)=0;
h(4)=subplot(414); stem(tvec,N); hold on, plot(tvec,Nsmc,'k','linewidth',2); axis('tight'), ylabel('smc')
xlabel('time (sec)')
linkaxes(h,'x')