Java Perform to a 2D FFT Inplace Given a Complex 2D Array

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 Generate All Subsets of a Given Set in the Gray Code Order
Hướng dẫn Java Design Pattern – Transfer Object
Java Program to Implement DelayQueue API
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence
Deque và ArrayDeque trong Java
Java Program to Implement TreeMap API
Java – Reader to String
Java Program to Implement Circular Doubly Linked List
Java Program to Implement Tarjan Algorithm
Uploading MultipartFile with Spring RestTemplate
Multipart Upload with HttpClient 4
Java Program to Implement Disjoint Sets
Java Program to Solve any Linear Equations
Write/Read cookies using HTTP and Read a file from the internet
Java Program to Perform Cryptography Using Transposition Technique
Easy Ways to Write a Java InputStream to an OutputStream
Hướng dẫn Java Design Pattern – Flyweight
A Guide to HashSet in Java
A Comparison Between Spring and Spring Boot
Guide to the Volatile Keyword in Java
Hướng dẫn Java Design Pattern – Null Object
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Add Multiple Items to an Java ArrayList
Converting Strings to Enums in Java
Calling Stored Procedures from Spring Data JPA Repositories
Java Program to Implement Hash Tables with Double Hashing
Spring Boot - Eureka Server
Getting a File’s Mime Type in Java
Convert String to Byte Array and Reverse in Java
Quick Guide to @RestClientTest in Spring Boot
String Operations with Java Streams