function [sta, stc, sta_resamp] = Spike_Triggered_Covariance(sp_binary, stimulus, tw, pp, rate_)
% sp_binary
%tw = 200; % ms
stimulus = stimulus - mean(stimulus);
length_sta = round(tw/pp);
length_stc = length_sta/rate_;
sta = zeros(2*length_sta+1,1);
spike_indx = find(sp_binary>0);
maxindx = spike_indx(end);
indx_int = find(spike_indx>length_sta & spike_indx<maxindx-length_sta);
stc = zeros(2*length_stc+1,length(indx_int));
%sta_resamp = zeros(2*length_stc+1,1);
for j = 1: length(indx_int)
sta = sta + stimulus(spike_indx(indx_int(j))-length_sta:spike_indx(indx_int(j))+length_sta);
stc_ = stimulus(spike_indx(indx_int(j))-length_sta:spike_indx(indx_int(j))+length_sta);
% uy = iddata([],stc_,1);
% ur = resample(uy,length_stc,length_sta);
% size(ur)
stc(:,j) = stc_;%ur.u;
end
sta = sta/length(indx_int);
% uy = iddata([],sta,1);
% ur = resample(uy,length_stc,length_sta);
sta_resamp = sta;%ur.u;