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:
Java Program to Implement Double Order Traversal of a Binary Tree
Tránh lỗi NullPointerException trong Java như thế nào?
The Basics of Java Security
Spring Boot - Twilio
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Registration – Password Strength and Rules
Converting a List to String in Java
Java Program to Perform Deletion in a BST
Spring Boot Actuator
Java Program to Implement Dijkstra’s Algorithm using Queue
Spring Boot - Zuul Proxy Server and Routing
Beans and Dependency Injection
A Guide to Spring Boot Admin
Spring Boot - Interceptor
Spring Boot - Thymeleaf
Java – Try with Resources
Spring 5 WebClient
How to Change the Default Port in Spring Boot
Spring Boot - Google OAuth2 Sign-In
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Set Interface trong Java
Debug a JavaMail Program
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Perform Right Rotation on a Binary Search Tree
@Order in Spring
Hướng dẫn kết nối cơ sở dữ liệu với Java JDBC
Comparing Arrays in Java
Spring Cloud – Tracing Services with Zipkin
Spring Boot - Tomcat Port Number
Java Program to Implement IdentityHashMap API
Introduction to Netflix Archaius with Spring Cloud
HttpClient Basic Authentication