This is the java implementation of performing Discrete Fourier Transform using Fast Fourier Transform algorithm. This class finds the DFT of N (power of 2) complex elements, generated randomly, using FFT. The input to the class is a two dimensional array of sequence.
Here is the source code of the Java Perform to a 2D FFT Inplace Given a Complex 2D Array. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a sample program to perform 2D FFT inplace
import java.util.Scanner;
public class TwoD_FFT
{
static void twoDfft(double[][] inputData, double[][] realOut,
double[][] imagOut, double[][] amplitudeOut)
{
int height = inputData.length;
int width = inputData[0].length;
// Two outer loops iterate on output data.
for (int yWave = 0; yWave < height; yWave++)
{
for (int xWave = 0; xWave < width; xWave++)
{
// Two inner loops iterate on input data.
for (int ySpace = 0; ySpace < height; ySpace++)
{
for (int xSpace = 0; xSpace < width; xSpace++)
{
// Compute real, imag, and ampltude.
realOut[yWave][xWave] += (inputData[ySpace][xSpace] * Math
.cos(2
* Math.PI
* ((1.0 * xWave * xSpace / width) + (1.0
* yWave * ySpace / height))))
/ Math.sqrt(width * height);
imagOut[yWave][xWave] -= (inputData[ySpace][xSpace] * Math
.sin(2
* Math.PI
* ((1.0 * xWave * xSpace / width) + (1.0
* yWave * ySpace / height))))
/ Math.sqrt(width * height);
amplitudeOut[yWave][xWave] = Math
.sqrt(realOut[yWave][xWave]
* realOut[yWave][xWave]
+ imagOut[yWave][xWave]
* imagOut[yWave][xWave]);
}
System.out.println(realOut[yWave][xWave] + " + "
+ imagOut[yWave][xWave] + " i");
}
}
}
}
public static void main(String args[])
{
System.out.println("Enter the size: ");
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
double[][] input = new double[n][n];
double[][] real = new double[n][n];
double[][] img = new double[n][n];
double[][] amplitutude = new double[n][n];
System.out.println("Enter the 2D elements ");
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++)
input[i][j] = sc.nextDouble();
twoDfft(input, real, img, amplitutude);
sc.close();
}
}
Output:
$ javac TwoD_FFT.java $ java TwoD_FFT Enter the size: 2 Enter the 2D elements 2 3 4 2 2.5 + 0.0 i 5.5 + 0.0 i -0.5 + -1.8369701987210297E-16 i 0.5 + -3.0616169978683826E-16 i 2.5 + 0.0 i -0.5 + -3.6739403974420594E-16 i -0.5 + -1.8369701987210297E-16 i -1.5 + -1.8369701987210297E-16 i
Related posts:
Inject Parameters into JUnit Jupiter Unit Tests
Spring Cloud – Securing Services
Java Program to Implement Pagoda
Using JWT with Spring Security OAuth (legacy stack)
Java Program to Implement Stack
Reversing a Linked List in Java
Java Program to Check the Connectivity of Graph Using BFS
Java Program to Implement VList
HttpClient 4 – Follow Redirects for POST
Spring Cloud AWS – EC2
Java Program to Implement Self organizing List
Batch Processing with Spring Cloud Data Flow
Spring Security Registration – Resend Verification Email
Java Program to Implement the Monoalphabetic Cypher
Generating Random Numbers in a Range in Java
Exploring the New Spring Cloud Gateway
Java Program to Test Using DFS Whether a Directed Graph is Weakly Connected or Not
Unsatisfied Dependency in Spring
Java Program to Implement K Way Merge Algorithm
Java Program to Implement Treap
Tránh lỗi NullPointerException trong Java như thế nào?
Guide to java.util.concurrent.Future
Java Program to Implement Self Balancing Binary Search Tree
So sánh HashMap và HashSet trong Java
Configure a Spring Boot Web Application
Java – String to Reader
Java Program to Implement Randomized Binary Search Tree
New Features in Java 13
Quản lý bộ nhớ trong Java với Heap Space vs Stack
Converting Between an Array and a Set in Java
Java Program to Describe the Representation of Graph using Incidence List
Spring Boot - Tomcat Deployment