gpt4 book ai didi

java - 在 Java 中将 Complex 转换为 ArrayList

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:11:28 26 4
gpt4 key购买 nike

我有一个输入信号,我想将其存储在 ArrayList 中,然后将其转换为 Complex,就像这样

-0.03480425839330703
0.07910192950176387
0.7233322451735928
0.1659819820667019

这样输出它的 FFT

0.9336118983487516
-0.7581365035668999 + 0.08688005256493803i
0.44344407521182005
-0.7581365035668999 - 0.08688005256493803i

这是一个复杂的结构,我想把它转换成ArrayList类型。同时删除 + 0.08688005256493803i 值。

所以我只需要这些值

0.9336118983487516
-0.7581365035668999
0.44344407521182005
-0.7581365035668999

解决这个问题的最佳方法是什么?

这是我正在使用的代码

public static Complex[] fft(Complex[] x) {
int N = x.length;

// base case
if (N == 1) return new Complex[] { x[0] };

// radix 2 Cooley-Tukey FFT
if (N % 2 != 0) { throw new RuntimeException("N is not a power of 2"); }

// fft of even terms
Complex[] even = new Complex[N/2];
for (int k = 0; k < N/2; k++) {
even[k] = x[2*k];
}
Complex[] q = fft(even);

// fft of odd terms
Complex[] odd = even; // reuse the array
for (int k = 0; k < N/2; k++) {
odd[k] = x[2*k + 1];
}
Complex[] r = fft(odd);

// combine
Complex[] y = new Complex[N];
for (int k = 0; k < N/2; k++) {
double kth = -2 * k * Math.PI / N;
Complex wk = new Complex(Math.cos(kth), Math.sin(kth));
y[k] = q[k].plus(wk.times(r[k]));
y[k + N/2] = q[k].minus(wk.times(r[k]));
}
return y;
}

最佳答案

所有你想做的就是放下你的Complex的虚部数据结构。

因为你没有给我们看 Complex类假设它有实部成员(例如 double real; )要删除虚部,只需调用 complex.getRealPart() 之类的东西, 或访问 complex.real (替换为您的真实成员(member)姓名)。

撰写ArrayList<Double>使用以下代码段:

ArrayList<Double> list = new ArrayList<Double>();
for (Complex c : complexes) { // complexes your array of complexes returned from for fft
list.add(c.getRealpart());
}

注意:以防万一,我可能是错的,但我假设您需要的不是实数部分,而是复数的绝对值。要计算它,请使用:

Math.sqrt(c.getRealPart() * c.getRealPart() + c.getImPart() * c.getImPart());

关于java - 在 Java 中将 Complex 转换为 ArrayList<Float>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13125248/

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