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:
Constructor Injection in Spring with Lombok
A Guide to Spring Boot Admin
Implementing a Runnable vs Extending a Thread
Java – Byte Array to Reader
MyBatis with Spring
Java Byte Array to InputStream
Command-Line Arguments in Java
The HttpMediaTypeNotAcceptableException in Spring MVC
Quick Guide to the Java StringTokenizer
Logging in Spring Boot
Java Program to Perform Left Rotation on a Binary Search Tree
Java Program to Implement CopyOnWriteArrayList API
Guide to Spring 5 WebFlux
Java Program to Find Maximum Element in an Array using Binary Search
Java Program to Find the Minimum value of Binary Search Tree
Tìm hiểu về Web Service
Hướng dẫn Java Design Pattern – Template Method
Validate email address exists or not by Java Code
Spring Boot Gradle Plugin
Spring Boot - Google Cloud Platform
Spring Boot Actuator
Java Program to Implement ArrayBlockingQueue API
Dockerizing a Spring Boot Application
Display Auto-Configuration Report in Spring Boot
Spring Data JPA and Null Parameters
Spring Boot - Servlet Filter
The Spring @Controller and @RestController Annotations
Using Optional with Jackson
Introduction to Using FreeMarker in Spring MVC
Java 8 and Infinite Streams
Java Program to Implement Aho-Corasick Algorithm for String Matching
The XOR Operator in Java