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 First Fit Decreasing for 1-D Objects and M Bins
Java Program to Perform the Shaker Sort
Check if a String is a Palindrome in Java
Overview of the java.util.concurrent
Introduction to Spring Cloud Stream
Java Program to Implement Fermat Primality Test Algorithm
Guide to the Synchronized Keyword in Java
Java Program to Implement Max Heap
Java Program to Implement Graph Structured Stack
Java Program to Find Number of Articulation points in a Graph
Functional Interfaces in Java 8
Spring RestTemplate Request/Response Logging
Java Convenience Factory Methods for Collections
Spring RequestMapping
Collect a Java Stream to an Immutable Collection
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Spring @RequestParam Annotation
Function trong Java 8
Command-Line Arguments in Java
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Java Program to Implement Sieve Of Eratosthenes
Java Program to Perform the Unique Factorization of a Given Number
Spring Boot - File Handling
Java – Convert File to InputStream
Spring Boot - Cloud Configuration Server
Java Collections Interview Questions
Java Program to Implement Self organizing List
Java Program to Implement Sorted List
Find the Registered Spring Security Filters
Java Program to Find the Mode in a Data Set
Từ khóa this và super trong Java
Finding Max/Min of a List or Collection