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:
How to Implement Caching using Adonis.js 5
Using JWT with Spring Security OAuth
Java Program to Implement the Program Used in grep/egrep/fgrep
Hướng dẫn Java Design Pattern – Flyweight
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Spring Boot - Introduction
Spring REST API + OAuth2 + Angular
Java Optional as Return Type
Working With Maps Using Streams
Java Program to Implement Binomial Tree
Send email with JavaMail
Java Program to Implement Double Ended Queue
A Quick Guide to Using Keycloak with Spring Boot
RestTemplate Post Request with JSON
Java Program to Implement SynchronosQueue API
Java Switch Statement
Java Program to Implement Queue
Using Spring @ResponseStatus to Set HTTP Status Code
Java Program to Check whether Directed Graph is Connected using DFS
Sorting Query Results with Spring Data
Spring Data MongoDB Transactions
Encode a String to UTF-8 in Java
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Getting Started with Custom Deserialization in Jackson
Unsatisfied Dependency in Spring
Quick Guide to @RestClientTest in Spring Boot
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Kết hợp Java Reflection và Java Annotations
JUnit 5 @Test Annotation
Convert String to int or Integer in Java
Spring Cloud – Tracing Services with Zipkin