gpt4 book ai didi

java - 为什么我在低通滤波器循环中收到 IndexOutOfBoundsException 错误?

转载 作者:行者123 更新时间:2023-12-02 01:31:02 32 4
gpt4 key购买 nike

我正在尝试在我的第一个 Java 应用程序中实现 Pan Tompkins 算法。我根据原始文章为低通滤波器做了以下循环,但当我尝试运行它时,我不断收到 IndexOutOfBoundsException 错误。有人能看到我哪里出错了吗?

我不想用系数制作滤波器,我只是需要帮助才能使公式发挥作用,请。

/**
* Lowpass filter
* lpfilt() implements the digital filter represented by the difference equation:
* y(nT) = 2y(nT - T) - y(nT - 2 T) + x(nT)- 2x(nT- 6T)+x(nT- 12T)
*/

public static ArrayList<Double> lpfilter(ArrayList<Double> ecg) {
int N = ecg.size();

ArrayList<Double> ecgLP = new ArrayList<Double>();
for (int n = 0; n < N; n++) {
if (n - 12 < 0) {
ecgLP.set(n, ecg.get(n));
} else {
ecgLP.set(n, 2 * ecgLP.get(n - 1) - ecgLP.get(n - 2) + ecg.get(n) - 2 * ecg.get(n - 6) + ecg.get(n - 12));
}
}
return ecgLP;
}

最佳答案

它发生在第一次迭代中。查看以下行:

ecgLP.set(n, ecg.get(n));

对于 n=0,您尝试将键 0 设置为值 ecg.get(0)。但到目前为止还没有设置0。因此,您会收到 IndexoutofBounds 错误。据我所知,前 12 (0..11) 次迭代应该填充 ArrayList,但是您的代码每次都会失败并出现错误,因为您尝试使用尚未初始化的成员。

我建议您在单独的循环中进行初始化,然后从 n=12 开始。

关于java - 为什么我在低通滤波器循环中收到 IndexOutOfBoundsException 错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56065017/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com