This is the java implementation of classic Coppersmith-Freivalds’ algorithm to check whether the multiplication of matrix A and B equals the given matrix C. It does it by checking A*(B*r)-(C*r) where r is any random column vector consisting only 0/1 as its elements. If this value is zero algorithm prints Yes, No otherwise.
Here is the source code of the Java Program to Implement Coppersmith Freivald’s Algorithm. 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 check whether the matrix c is equal to the multiplication of a and b //implementation of Coppersmith Freivalds Algorithm import java.util.Random; import java.util.Scanner; public class Coppersmith_Freivalds_Algorithm { public static void main(String args[]) { System.out.println("Enter the dimesion of the matrices: "); Scanner input = new Scanner(System.in); int n = input.nextInt(); System.out.println("Enter the 1st matrix: "); double a[][] = new double[n][n]; for(int i=0; i<n; i++) { for(int j=0; j<n; j++) { a[i][j] = input.nextDouble(); } } System.out.println("Enter the 2st matrix: "); double b[][] = new double[n][n]; for(int i=0; i<n; i++) { for(int j=0; j<n; j++) { b[i][j] = input.nextDouble(); } } System.out.println("Enter the result matrix: "); double c[][] = new double[n][n]; for(int i=0; i<n; i++) { for(int j=0; j<n; j++) { c[i][j] = input.nextDouble(); } } //random generation of the r vector containing only 0/1 as its elements double [][]r = new double[n][1]; Random random = new Random(); for(int i=0; i<n; i++) { r[i][0] = random.nextInt(2); } //test A * (b*r) - (C*) = 0 double br[][] = new double[n][1]; double cr[][] = new double[n][1]; double abr[][] = new double[n][1]; br = multiplyVector(b, r, n); cr = multiplyVector(c, r, n); abr = multiplyVector(a, br, n); //check for all zeros in abr boolean flag = true; for(int i=0; i<n; i++) { if(abr[i][0] == 0) continue; else flag = false; } if(flag == true) System.out.println("Yes"); else System.out.println("No"); input.close(); } public static double[][] multiplyVector(double[][] a, double[][] b, int n) { double result[][] = new double[n][1]; for (int i = 0; i < n; i++) { for (int j = 0; j < 1; j++) { for (int k = 0; k < n; k++) { result[i][j] = result[i][j] + a[i][k] * b[k][j]; } } } return result; } }
Output:
$ javac Coppersmith_Freivalds_Algorithm.java $ java Coppersmith_Freivalds_Algorithm Enter the dimesion of the matrices: 2 Enter the 1st matrix: 2 3 3 4 Enter the 2st matrix: 1 0 1 2 Enter the result matrix: 6 5 8 7 Yes
Related posts:
Spring Boot - Tracing Micro Service Logs
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Java Program to Implement Network Flow Problem
How to Set TLS Version in Apache HttpClient
HttpClient Timeout
HttpAsyncClient Tutorial
Spring Data JPA Delete and Relationships
Spring Security Form Login
Java Program to Use rand and srand Functions
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Spring Cloud AWS – RDS
Generate Spring Boot REST Client with Swagger
Java Program to Implement Self organizing List
Hướng dẫn Java Design Pattern – Decorator
Các chương trình minh họa sử dụng Cấu trúc điều khiển trong Java
Java Program to Implement Knapsack Algorithm
Introduction to the Java NIO2 File API
Guide to Spring 5 WebFlux
Java Program to find the maximum subarray sum using Binary Search approach
Check If a File or Directory Exists in Java
Java Program to Implement Flood Fill Algorithm
Compare Two JSON Objects with Jackson
Introduction to Spring Data REST
Getting Started with Custom Deserialization in Jackson
Java Program to Implement Attribute API
The Spring @Controller and @RestController Annotations
Java Program to Implement Gaussian Elimination Algorithm
Java Program to Implement Binomial Heap
How to Get the Last Element of a Stream in Java?
HttpClient 4 – Follow Redirects for POST
Hamcrest Collections Cookbook
Overflow and Underflow in Java