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:
Introduction to Spring Cloud CLI
Converting a Stack Trace to a String in Java
Intersection of Two Lists in Java
Set Interface trong Java
Apache Camel with Spring Boot
Overview of the java.util.concurrent
Java Program to Implement Sieve Of Eratosthenes
HashSet trong Java hoạt động như thế nào?
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Automatic Property Expansion with Spring Boot
Java TreeMap vs HashMap
Spring Boot - Enabling HTTPS
Feign – Tạo ứng dụng Java RESTful Client
An Introduction to Java.util.Hashtable Class
Java – Random Long, Float, Integer and Double
Java Program to Find the Vertex Connectivity of a Graph
Spring @RequestParam Annotation
Lập trình đa luồng với Callable và Future trong Java
JUnit5 @RunWith
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Java Program to implement Priority Queue
Java – String to Reader
Custom JUnit 4 Test Runners
OAuth2 Remember Me with Refresh Token
Multi Dimensional ArrayList in Java
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Java Program to Represent Graph Using 2D Arrays
Lớp Properties trong java
Java Program to Implement Iterative Deepening
Java Convenience Factory Methods for Collections
Java Program to Find the Longest Path in a DAG