-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathrm_resp.m
63 lines (53 loc) · 1.41 KB
/
rm_resp.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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
function outtrace = rm_resp(intrace)
%% function to remove instrument response of irisFetch data structure
% written by Ge Jin, 2014/02/27
intrace = intrace(1);
isfigure = 0;
lo_corner = 0.005; % in Hz
npoles=5;
data = intrace.data;
data = detrend(data);
data = flat_hanning_win(1:length(data),data,1,length(data),50);
N = intrace.sampleCount;
delta = 1/intrace.sampleRate;
T = N*delta;
if mod(N,2)
faxis = [0:(N-1)/2,-(N-1)/2:-1]*(1/T);
else
faxis = [0:N/2,-N/2+1:-1]*(1/T);
end
poles = intrace.sacpz.poles;
zeros = intrace.sacpz.zeros;
gain = intrace.sacpz.constant;
w = faxis.*2*pi;
resp = ones(size(w));
for ip = 1:length(poles)
resp = resp./(i*w - poles(ip));
end
for ip = 1:length(zeros)
resp = resp.*(i*w - zeros(ip));
end
resp = resp*gain;
if isfigure
figure(33)
clf
set(gcf,'position',[360 514 900 400]);
hold on
subplot(1,2,1)
set(gca,'fontsize',18)
semilogy(faxis,abs(resp),'rx');
subplot(1,2,2)
set(gca,'fontsize',18)
plot(faxis,angle(resp),'rx');
end
lo_w=2*pi*lo_corner;
hpfiltfrq=( ((w./lo_w).^(2*npoles))./(1+(w./lo_w).^(2*npoles)) );
norm_trans=hpfiltfrq./resp; % this is normalization transfer function
norm_trans(find(isnan(norm_trans))) = 0;
fftdata = fft(data);
fftdata = fftdata(:).*norm_trans(:);
data_cor = real(ifft(fftdata));
outtrace = intrace;
outtrace.data_cor = data_cor;
disp(['Station: ',intrace.station,'.',intrace.channel,' deconv to ',intrace.sacpz.units]);
return