📄 myhilbert.m
字号:
function data=myhilbert(data)% Compute Hilbert transform of input data, If "data" is a matrix, "myhilbert"% operates on each column % Written by: E. R.: December 13, 2003% Last updated: January 24, 2005: Change polarity of imaginary pa%% data=myhilbert(data)% INPUT% data matrix; each column represents a signal% OUTPUT% hdata matrix; each column represents the Hilbert transform (complex) % of the corresponding column of the input matrix "data"if ~isreal(data) error(' Input data must be real')end[data,ndim]=shiftdim(data); % Make sure that first dimension is not singletonnsamp=size(data,1);if nsamp == 1 returnenddata=fft(data);if mod(nsamp,2) == 0 % Nyquist frequency present ntr2=nsamp/2+1;else ntr2=(nsamp+1)/2;end %data(1,:)=-data(1,:);data(1,:)=0;data(2:ntr2,:)=-2*(data(2:ntr2,:));data(ntr2+1:end,:)=0;% hdata=-conj(ifft(data));data=-ifft(data);data=shiftdim(data,-ndim); % Undo dimension change, if there was one
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -