findzc.m

来自「一种新的时频分析方法的matlab源程序。」· M 代码 · 共 20 行

M
20
字号
function zcx = findzc(in)

npts = length(in);
zcx = zeros(1,npts/2);
wasPositive = in(1) > 0;
idx = 1;

for i=2:npts
    isPositive = in(i) > 0;
    
    if wasPositive ~= isPositive
        zcx(idx) = i + in(i)/(in(i-1)-in(i));
        idx = idx+1;
        wasPositive = isPositive;
    end
end

% clear unused points
zcx(idx:end) = [];

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?