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:
Spring Security Login Page with React
Guide to Escaping Characters in Java RegExps
Introduction to the Java NIO Selector
Introduction to Eclipse Collections
Convert Hex to ASCII in Java
So sánh HashSet, LinkedHashSet và TreeSet trong Java
Count Occurrences of a Char in a String
Hướng dẫn sử dụng luồng vào ra nhị phân trong Java
Java Program to Implement Quick Sort Using Randomization
Java Program to Implement Disjoint Set Data Structure
Java Program to Find the Minimum Element of a Rotated Sorted Array using Binary Search approach
Giới thiệu về Stream API trong Java 8
Giới thiệu Aspect Oriented Programming (AOP)
Mệnh đề if-else trong java
Guide to Mustache with Spring Boot
Convert a Map to an Array, List or Set in Java
Spring Cloud Series – The Gateway Pattern
Spring MVC and the @ModelAttribute Annotation
Java – Write a Reader to File
Java Program to Implement Randomized Binary Search Tree
Hướng dẫn Java Design Pattern – DAO
Java Program to Implement Cubic convergence 1/pi Algorithm
Java Program to Solve the Fractional Knapsack Problem
Enum trong java
Send email with JavaMail
Java Program to Represent Graph Using Incidence Matrix
CharSequence vs. String in Java
Java Program to Implement Caesar Cypher
Using Spring ResponseEntity to Manipulate the HTTP Response
Hướng dẫn Java Design Pattern – Strategy
wait() and notify() Methods in Java
Java Program to Find the Connected Components of an UnDirected Graph