Quine-McCluskey Algoritması Java
Quine–McCluskey kullanımı (veya asal çıkarımlar yöntemi), Willard V. Quine tarafından sahiplenilmesi ve Edward J. McCluskey tarafından genişletilen Boolean okullarının minimizasyonu için kullanılabilir.
Quine-McCluskey-Algorithm-Java
Introduction:
The Quine–McCluskey algorithm (or the method of prime implicants) is a method used for minimization of Boolean functions that was developed by Willard V. Quine and extended by Edward J. McCluskey. It is functionally identical to Karnaugh mapping, but the tabular form makes it more efficient for use in computer algorithms, and it also gives a deterministic way to check that the minimal form of a Boolean function has been reached. It is sometimes referred to as the tabulation method. The method involves two steps:
- Finding all prime implicants of the function.
- Use those prime implicants in a prime implicant chart to find the essential prime implicants of the function, as well as other prime implicants that are necessary to cover the function.
Problem Definition:
The method groups the minterms entered by the user first according to the number of ones in their binary equivalent. Then the minterms are grouped in such a way that the there is only change in a single position of the two minterms compared. The comparing is carried forward to newer tables until there are no more groups to be formed. Then all the minterms that are never paired are chosen as prime implicants and using the least number of prime implicants that cover all minterms, we generate the minimized equation for the Boolean function.
Modules:
- void minTermsDectoBin(); - Converts decimal minterms to binary equivalents.
- int totalSizeCalc(); - Calculates the max no. of minterms for the no of variables.
- int calcNoOfOnes(int[]); - Counts the no of ones in the binary of the minterm
- void display(); - Various Display Functions to display the tables
- int compare(); - Various compare functions to compare tables and minterms
- void firstStage(); - First Stage grouping
- void printParityTable(); - To print the parity table
- void parityInit(); - Initialize the parity table with -1
- int paritycheck(); - To check the prime implicants
- int checkForSingle(); - Prime implicants that are must to be included in eqn
- int parityToEqt(); - To generate equation from prime implicants
- void displayFinal(); - Display the final equation
Conclusion:
The Quine-McCluskey Method was hence implemented using arrays. Array was used because the size of the data elements to be stored where fixed and was in a tabular form of a 2d array. Also, there was no need to access elements from between and hence a linear traversal was only required along with static storage, which provides a fast access. Hence, arrays were preferred for the implementation of tabular form Quine-McCluskey Method. And thereby using arrays we implemented the project which performs the operation of minimizing the Boolean function entered by the user. The method hence provided with the minimized equations of the function.
Â
Türkçe :
Â
Quine-McCluskey-Algoritma-Java
GiriÅŸ:
Quine–McCluskey kullanımı (veya asal çıkarımlar yöntemi), Willard V. Quine tarafından sahiplenilmesi ve Edward J. McCluskey tarafından genişletilen Boolean okullarının minimizasyonu için kullanılan bir kullanılabilir. İşlevsel olarak işlevsellik eşlemesiyle, ancak uygulanabilecek bir sistem tasarımında kullanım için daha verimli hale getirmek ve ayrıntılı bir Boole sağlamanın minimum kontrol edilmesiyle elde edilirliğini belirlemek için bir yol sağlar. Bazen tablolama olarak adlandırılır. iki yöntem adım içerir:
- Fonksiyonun tüm asal imalarını bulma.
- Bu asal implikantları, işlevin temel özellikleri olarak kapsamlı ve genel olarak kapsamak için gerekli olan herkes için geçerli olan bir tablonda kullanım için bir standart değildir.
Problem tanımı:
Yöntem, kullanıcı tarafından girilen mintermleri, ikili eşdeğerlerindeki sayı sayısına göre gruplandırır. Daha sonra mintermler, karşılaştırılan iki mintermin yalnızca tek bir konumunda değişiklik olacak şekilde gruplandırılır. Karşılaştırma, oluşturulacak başka grup kalmayıncaya kadar daha yeni tablolara taşınır. Daha sonra hiçbir zaman eşleşmeyen tüm mintermler asal çıkarımlar olarak seçilir ve tüm mintermleri kapsayan en az sayıda asal implikant kullanılarak Boole fonksiyonu için minimize edilmiş denklemi üretiriz.
Modüller:
- geçersiz minTermsDectoBin(); - Ondalık mintermleri ikili eşdeğerlere dönüştürür.
- int toplamSizeCalc(); - Maksimum sayıyı hesaplar. değişken sayısı için mintermler.
- int calcNoOfOnes(int[]); - Minterm ikili dosyasındakilerin sayısını sayar
- geçersiz ekran(); - Tabloları görüntülemek için çeşitli Görüntüleme İşlevleri
- int karşılaştır(); - Tabloları ve mintermleri karşılaştırmak için çeşitli karşılaştırma işlevleri
- void firstStage(); - Birinci Aşama gruplaması
- geçersiz printParityTable(); - Parite tablosunu yazdırmak için
- geçersiz eşlikInit(); - Parite tablosunu -1 ile başlatın
- int paritycheck(); - Asal imaları kontrol etmek için
- int checkForSingle(); - Denklemde yer alması gereken asal imalar
- int parityToEqt(); - Asal imalardan denklem oluşturmak için
- geçersiz displayFinal(); - Son denklemi göster
Çözüm:
Quine-McCluskey Yöntemi bu artan diziler uygulandı. Dizi, saklanacak verinin öğelerinin görünümünde olduğu ve bir 2 dizinin bulunduğu tablo içind uygulanacaktır. Ayrıca, araçlara erişim için gerekli ve bu şekilde, erişimle geçiş ile birlikte bir geçiş geçiş gerekliydi. Bu artan, şeklindeki Quine-McCluskey yönteminin için diziler tercih edilirken. Bu sayede aracılığıyla kullanıcı tarafından girilen Boolean'ı en aza indirgeyerek gerçekleştiren projeyi diziler kullanarak hayata geçirebiliriz. Bu gelişmiş sistem fonksiyonun en aza indirilmiş olan denklemleri ile teslim edilir.
Â
- import java.util.Scanner;
- import java.util.Vector;
- import ts.display;
- class declarations {
- Â Â // Variable Declarations
- Â Â public static int i = 0, j = 0, l = 0, k = 0, c = 0, noOfVariables = 0, maxBit = 0, noOfMinTerms = 0;
- Â Â public static int[] minTermsDec = new int[16];
- Â Â public static int[][] minTermsBin = new int[16][16];
- Â Â public static int[] noOfOnes = new int[16];
- Â Â public static int[][] g0 = new int[14][5];
- Â Â public static int[][] g1 = new int[16][5];
- Â Â public static int[][] g2 = new int[16][5];
- Â Â public static int[][] g3 = new int[16][5];
- Â Â public static int[][] g4 = new int[16][5];
- Â Â public static int[][] h0 = new int[16][7];
- Â Â public static int[][] h1 = new int[16][7];
- Â Â public static int[][] h2 = new int[16][7];
- Â Â public static int[][] h3 = new int[16][7];
- Â Â public static int[][] i0 = new int[16][9];
- Â Â public static int[][] i1 = new int[16][9];
- Â Â public static int[][] i2 = new int[16][9];
- Â Â public static int[][] k0 = new int[16][13];
- Â Â public static int[][] k1 = new int[16][13];
- Â Â public static int[][] parityTable = new int[20][24];
- Â Â public static int gzero = 0, gone = 0, gtwo = 0, gthree = 0, gfour = 0;
- Â Â public static int hzero = 0, hone = 0, htwo = 0, hthree = 0;
- Â Â public static int izero = 0, ione = 0, itwo = 0;
- Â Â public static int kzero = 0, kone = 0;
- Â Â public static int[][] Final = new int[100][5];
- Â Â public static int finalc = 0;
- Â Â public static int parityCnt = 0;
- Â Â static Scanner s = new Scanner(System.in);
- Â Â //Constructor to initialize parityÂ
- Â Â declarations() {
- Â Â for (i = 0; i < 20; i++)
- Â Â Â Â Â Â for (j = 0; j < 24; j++)
- Â Â Â Â Â Â Â Â parityTable[i][j] = -1;
- Â Â }
- Â Â // Function Definitions
- Â Â public static int parityToEqt() // Function to generate the parity bits
- Â Â {
- Â Â Â Â for (j = 0; j < 16; j++) {
- Â Â Â Â Â Â if (checkForSingle(j) != 100) {
- Â Â Â Â Â Â Â Â Final[finalc][0] = parityTable[checkForSingle(j)][20];
- Â Â Â Â Â Â Â Â Final[finalc][1] = parityTable[checkForSingle(j)][21];
- Â Â Â Â Â Â Â Â Final[finalc][2] = parityTable[checkForSingle(j)][22];
- Â Â Â Â Â Â Â Â Final[finalc][3] = parityTable[checkForSingle(j)][23];
- Â Â Â Â Â Â Â Â finalc++;
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â Â Â return 0;
- Â Â }
- // Function to compare the parity table and final parities for equation
- Â Â public static int compareSamefinal(int a[][], int size)Â
- Â Â {
- Â Â Â Â for (i = 0; i < size; i++) {
- Â Â Â Â Â Â for (j = i + 1; j < size;) {
- Â Â Â Â Â Â Â Â if ((a[j][0] == a[i][0]) && (a[j][1] == a[i][1]) && (a[j][2] == a[i][2]) && (a[j][3] == a[i][3])) {
- Â Â Â Â Â Â Â Â Â Â for (k = j; k < size; k++) {
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][0] = a[k + 1][0];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][1] = a[k + 1][1];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][2] = a[k + 1][2];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][3] = a[k + 1][3];
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â Â Â size--;
- Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â j++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â Â Â return size;
- Â Â }
- // Function to check for parity that are necessary for equation as they are lone contributers for a minterm
- Â Â public static int checkForSingle(int column)Â
- Â Â {
- Â Â Â Â int patc = 0, temp121 = 0;
- Â Â Â Â for (i = 0; i < parityCnt; i++) {
- Â Â Â Â Â Â if (parityTable[i][column] == 999) {
- Â Â Â Â Â Â Â Â temp121 = i;
- Â Â Â Â Â Â Â Â patc++;
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â Â Â if (patc == 1)
- Â Â Â Â Â Â return temp121;
- Â Â Â Â else
- Â Â Â Â Â Â return 100;
- Â Â }
- Â Â public static int paritycheck3(int a[][], int b[][], int h[][], int first, int second,
- Â Â Â Â Â Â int third)Â
- Â Â {
- Â Â Â Â int t = 0;
- Â Â Â Â while (t != first) {
- Â Â Â Â Â Â int c = 0;
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â for (i = 0; i < third; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != h[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (c == 0) {
- Â Â Â Â Â Â Â Â parityTable[parityCnt][16] = a[t][4];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][17] = a[t][5];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][18] = a[t][6];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][19] = a[t][7];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][23] = a[t][3];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][22] = a[t][2];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][21] = a[t][1];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][20] = a[t][0];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][7]] = 999;
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][6]] = 999;
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][5]] = 999;
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][4]] = 999;
- Â Â Â Â Â Â Â Â parityCnt++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return 0;
- Â Â }
- Â Â public static int paritycheck2(int a[][], int b[][], int h[][], int first, int second,
- Â Â Â Â Â Â int third) // Function to check parity
- Â Â {
- Â Â Â Â int t = 0;
- Â Â Â Â while (t != first) {
- Â Â Â Â Â Â int c = 0;
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â for (i = 0; i < third; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != h[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (c == 0) {
- Â Â Â Â Â Â Â Â parityTable[parityCnt][16] = a[t][4];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][17] = a[t][5];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][23] = a[t][3];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][22] = a[t][2];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][21] = a[t][1];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][20] = a[t][0];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][5]] = 999;
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][4]] = 999;
- Â Â Â Â Â Â Â Â parityCnt++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return 0;
- Â Â }
- Â Â public static int paritycheck1(int a[][], int b[][], int h[][], int first, int second,
- Â Â Â Â Â Â int third) // Function to check parity
- Â Â {
- Â Â Â Â int t = 0;
- Â Â Â Â while (t != first) {
- Â Â Â Â Â Â int c = 0;
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â for (i = 0; i < third; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] != h[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â c++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (c == 0) {
- Â Â Â Â Â Â Â Â parityTable[parityCnt][16] = a[t][4];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][23] = a[t][3];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][22] = a[t][2];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][21] = a[t][1];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][20] = a[t][0];
- Â Â Â Â Â Â Â Â parityTable[parityCnt][a[t][4]] = 999;
- Â Â Â Â Â Â Â Â parityCnt++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return 0;
- Â Â }
- Â Â public static int totalSizeCalc() // Function to check the maximum no of minterms possible for the no of variables
- Â Â {
- Â Â Â Â for (i = 0; i < noOfVariables; i++) {
- Â Â Â Â Â Â maxBit = maxBit + (int) Math.pow(2, i);
- Â Â Â Â }
- Â Â Â Â return maxBit + 1;
- Â Â }
- Â Â public static void inputMinTerms() // Function to input the minterms
- Â Â {
- Â Â Â Â int inp = 0;
- Â Â Â Â Vector vec = new Vector(16);
- Â Â Â Â System.out.print("Enter the minterms to be minimized: \n");
- Â Â Â Â for (i = 0; i < maxBit; i++) {
- Â Â Â Â Â Â inp = s.nextInt();
- Â Â Â Â Â Â if (inp >= (maxBit)) {
- Â Â Â Â Â Â Â Â for (i = 0; i < noOfMinTerms; i++)
- Â Â Â Â Â Â Â Â Â Â minTermsDec[i] = vec.get(i);
- Â Â Â Â Â Â Â Â return;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â else if (inp == (-1)) {
- Â Â Â Â Â Â Â Â for (i = 0; i < noOfMinTerms; i++)
- Â Â Â Â Â Â Â Â Â Â minTermsDec[i] = vec.get(i);
- Â Â Â Â Â Â Â Â return;
- Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â vec.add(inp);
- Â Â Â Â Â Â Â Â noOfMinTerms++;
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â }
- Â Â public static int calcNoOfOnes(int num[]) // Function to calculate the no of ones in the minterms binary value
- Â Â {
- Â Â Â Â int flag = 0;
- Â Â Â Â for (i = 0; i < maxBit; i++) {
- Â Â Â Â Â Â if (num[i] == 1)
- Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â }
- Â Â Â Â return flag;
- Â Â }
- Â Â public static void minTermsDectoBin() // Function to convert the minterms in decimal to their binary equivalents
- Â Â {
- Â Â Â Â int temp;
- Â Â Â Â for (i = 0; i <= noOfMinTerms; i++) {
- Â Â Â Â Â Â for (j = 0; j < noOfMinTerms; j++) {
- Â Â Â Â Â Â Â Â temp = minTermsDec[j];
- Â Â Â Â Â Â Â Â minTermsBin[j][4] = temp;
- Â Â Â Â Â Â Â Â for (l = 3; l >= 0; l--) {
- Â Â Â Â Â Â Â Â Â Â minTermsBin[j][l] = temp % 2;
- Â Â Â Â Â Â Â Â Â Â temp = temp / 2;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (minTermsDec[j] == 1)
- Â Â Â Â Â Â Â Â Â Â noOfOnes[j] = 1;
- Â Â Â Â Â Â Â Â else
- Â Â Â Â Â Â Â Â Â Â noOfOnes[j] = calcNoOfOnes(minTermsBin[j]);
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â }
- Â Â public static void firstStage() // Function for first stage comparisons
- Â Â {
- Â Â Â Â for (i = 0; i < noOfMinTerms; i++) {
- Â Â Â Â Â Â if (noOfOnes[i] == 0) {
- Â Â Â Â Â Â Â Â for (j = 0; j < 5; j++) {
- Â Â Â Â Â Â Â Â Â Â g0[gzero][j] = minTermsBin[i][j];
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â gzero++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (noOfOnes[i] == 1) {
- Â Â Â Â Â Â Â Â for (j = 0; j < 5; j++) {
- Â Â Â Â Â Â Â Â Â Â g1[gone][j] = minTermsBin[i][j];
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â gone++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (noOfOnes[i] == 2) {
- Â Â Â Â Â Â Â Â for (j = 0; j < 5; j++) {
- Â Â Â Â Â Â Â Â Â Â g2[gtwo][j] = minTermsBin[i][j];
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â gtwo++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (noOfOnes[i] == 3) {
- Â Â Â Â Â Â Â Â for (j = 0; j < 5; j++) {
- Â Â Â Â Â Â Â Â Â Â g3[gthree][j] = minTermsBin[i][j];
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â gthree++;
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (noOfOnes[i] == 4) {
- Â Â Â Â Â Â Â Â for (j = 0; j < 5; j++) {
- Â Â Â Â Â Â Â Â Â Â g4[gfour][j] = minTermsBin[i][j];
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â gfour++;
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â }
- Â Â public static void display() // Display function to display the no of ones
- Â Â {
- Â Â Â Â for (j = 0; j < noOfMinTerms; j++) {
- Â Â Â Â Â Â System.out.print(noOfOnes[j] + "\t");
- Â Â Â Â }
- Â Â }
- Â Â public void displayFinal() // Function to display the final table
- Â Â {
- Â Â Â Â for (i = 0; i < finalc; i++) {
- Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â System.out.print(Final[i][j] + "\t");
- Â Â Â Â Â Â }
- Â Â Â Â Â Â System.out.print("\n");
- Â Â Â Â }
- Â Â }
- Â Â public static void displayArray(int a[][], int n) // Dsiplay Function
- Â Â {
- Â Â Â Â for (i = 0; i < n; i++) {
- Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â System.out.print(a[i][j] + "\t");
- Â Â Â Â Â Â }
- Â Â Â Â Â Â System.out.print("\n");
- Â Â Â Â }
- Â Â }
- Â Â static int compare(int a[][], int b[][], int h[][], int first, int second) // Compare Function
- Â Â {
- Â Â Â Â int y = 0, t = 0;
- Â Â Â Â while (t < first) {
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] == b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = b[i][j];
- Â Â Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = 9;
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â h[y][4] = a[t][4];
- Â Â Â Â Â Â Â Â Â Â h[y][5] = b[i][4];
- Â Â Â Â Â Â Â Â Â Â if (h[y][6] == 0)
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][6] = 1;
- Â Â Â Â Â Â Â Â Â Â y++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return y;
- Â Â }
- Â Â public static int compare1(int a[][], int b[][], int h[][], int first, int second) // Compare Function
- Â Â {
- Â Â Â Â int y = 0, t = 0;
- Â Â Â Â while (t != first) {
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] == b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = b[i][j];
- Â Â Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = 9;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â h[y][4] = a[t][4];
- Â Â Â Â Â Â Â Â Â Â h[y][5] = a[t][5];
- Â Â Â Â Â Â Â Â Â Â h[y][6] = b[i][4];
- Â Â Â Â Â Â Â Â Â Â h[y][7] = b[i][5];
- Â Â Â Â Â Â Â Â Â Â y++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return y;
- Â Â }
- Â Â public static int compare2(int a[][], int b[][], int h[][], int first, int second) // Compare function
- Â Â {
- Â Â Â Â int y = 0, t = 0;
- Â Â Â Â while (t != first) {
- Â Â Â Â Â Â for (i = 0; i < second; i++) {
- Â Â Â Â Â Â Â Â int flag = 0;
- Â Â Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â Â Â if (a[t][j] == b[i][j]) {
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = b[i][j];
- Â Â Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â Â Â flag++;
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][j] = 9;
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â if (flag == 1) {
- Â Â Â Â Â Â Â Â Â Â h[y][4] = a[t][4];
- Â Â Â Â Â Â Â Â Â Â h[y][5] = a[t][5];
- Â Â Â Â Â Â Â Â Â Â h[y][6] = a[t][6];
- Â Â Â Â Â Â Â Â Â Â h[y][7] = a[t][7];
- Â Â Â Â Â Â Â Â Â Â h[y][8] = b[i][4];
- Â Â Â Â Â Â Â Â Â Â h[y][9] = b[i][5];
- Â Â Â Â Â Â Â Â Â Â h[y][10] = b[i][6];
- Â Â Â Â Â Â Â Â Â Â h[y][11] = b[i][7];
- Â Â Â Â Â Â Â Â Â Â if (h[y][12] == 0)
- Â Â Â Â Â Â Â Â Â Â Â Â h[y][12] = 1;
- Â Â Â Â Â Â Â Â Â Â y++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â t++;
- Â Â Â Â }
- Â Â Â Â return y;
- Â Â }
- Â Â public static int compareSame(int a[][], int size) // Compare Function
- Â Â {
- Â Â Â Â for (i = 0; i < size; i++) {
- Â Â Â Â Â Â for (j = i + 1; j < size;) {
- Â Â Â Â Â Â Â Â if ((a[j][0] == a[i][0]) && (a[j][1] == a[i][1]) && (a[j][2] == a[i][2]) && (a[j][3] == a[i][3])) {
- Â Â Â Â Â Â Â Â Â Â for (k = j; k < size; k++) {
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][0] = a[k + 1][0];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][1] = a[k + 1][1];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][2] = a[k + 1][2];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][3] = a[k + 1][3];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][4] = a[k + 1][4];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][5] = a[k + 1][5];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][6] = a[k + 1][6];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][7] = a[k + 1][7];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][8] = a[k + 1][8];
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â Â Â size--;
- Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â j++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â Â Â return size;
- Â Â }
- Â Â public static int compareSame2(int a[][], int size) // Compare Function
- Â Â {
- Â Â Â Â for (i = 0; i < size; i++) {
- Â Â Â Â Â Â for (j = i + 1; j < size;) {
- Â Â Â Â Â Â Â Â if ((a[j][0] == a[i][0]) && (a[j][1] == a[i][1]) && (a[j][2] == a[i][2]) && (a[j][3] == a[i][3])) {
- Â Â Â Â Â Â Â Â Â Â for (k = j; k < size; k++) {
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][0] = a[k + 1][0];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][1] = a[k + 1][1];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][2] = a[k + 1][2];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][3] = a[k + 1][3];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][4] = a[k + 1][4];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][5] = a[k + 1][5];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][6] = a[k + 1][6];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][7] = a[k + 1][7];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][8] = a[k + 1][8];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][9] = a[k + 1][9];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][10] = a[k + 1][10];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][11] = a[k + 1][11];
- Â Â Â Â Â Â Â Â Â Â Â Â a[k][12] = a[k + 1][12];
- Â Â Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â Â Â Â Â size--;
- Â Â Â Â Â Â Â Â } else {
- Â Â Â Â Â Â Â Â Â Â j++;
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â Â Â return size;
- Â Â }
- Â Â static void parityInit() // Function to initialize the parity table
- Â Â {
- Â Â Â Â for (i = 0; i < 20; i++)
- Â Â Â Â Â Â for (j = 0; j < 24; j++)
- Â Â Â Â Â Â Â Â parityTable[i][j] = -1;
- Â Â }
- Â Â static void printParityTable() // Function to print the parity table
- Â Â {
- Â Â Â Â for (i = 0; i < parityCnt; i++) {
- Â Â Â Â Â Â System.out.print("\n P" + i + 1 + " : ");
- Â Â Â Â Â Â for (j = 16; j < 20; j++) {
- Â Â Â Â Â Â Â Â if (parityTable[i][j] == -1)
- Â Â Â Â Â Â Â Â Â Â continue;
- Â Â Â Â Â Â Â Â else {
- Â Â Â Â Â Â Â Â Â Â System.out.print(" " + parityTable[i][j] + " ");
- Â Â Â Â Â Â Â Â Â Â if (j != 19 && parityTable[i][j + 1] != -1)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print(",");
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â Â Â System.out.print("\n");
- Â Â Â Â }
- Â Â }
- Â Â static void eqnGenerator() // Function to generate the equation from the parity
- Â Â {
- Â Â Â Â System.out.print("\n The Equation is : \t");
- Â Â Â Â for (i = 0; i < finalc; i++) {
- Â Â Â Â Â Â if (i != 0)
- Â Â Â Â Â Â Â Â System.out.print(" + ");
- Â Â Â Â Â Â for (j = 0; j < 4; j++) {
- Â Â Â Â Â Â Â Â if (j == 0 && j < noOfVariables) {
- Â Â Â Â Â Â Â Â Â Â if (Final[i][j] == 0)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("A'");
- Â Â Â Â Â Â Â Â Â Â else if (Final[i][j] == 1)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("A");
- Â Â Â Â Â Â Â Â } else if (j == 1 && j < noOfVariables) {
- Â Â Â Â Â Â Â Â Â Â if (Final[i][j] == 0)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("B'");
- Â Â Â Â Â Â Â Â Â Â else if (Final[i][j] == 1)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("B");
- Â Â Â Â Â Â Â Â } else if (j == 2 && j < noOfVariables) {
- Â Â Â Â Â Â Â Â Â Â if (Final[i][j] == 0)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("C'");
- Â Â Â Â Â Â Â Â Â Â else if (Final[i][j] == 1)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("C");
- Â Â Â Â Â Â Â Â } else if (j == 3) {
- Â Â Â Â Â Â Â Â Â Â if (Final[i][j] == 0 && j < noOfVariables)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("D'");
- Â Â Â Â Â Â Â Â Â Â else if (Final[i][j] == 1)
- Â Â Â Â Â Â Â Â Â Â Â Â System.out.print("D");
- Â Â Â Â Â Â Â Â }
- Â Â Â Â Â Â }
- Â Â Â Â }
- Â Â }
- }
- class l extends declarations {
- Â Â public static void main(String args[]) {
- Â Â Â Â try {
- Â Â Â Â Â Â Scanner sc = new Scanner(System.in);
- Â Â Â Â Â Â System.out.println("Please enter your name");
- Â Â Â Â Â Â String s = sc.next();
- Â Â Â Â Â Â System.out.print("Enter the number of variables to be Minimized: ");
- Â Â Â Â Â Â noOfVariables = sc.nextInt();
- Â Â Â Â Â Â maxBit = totalSizeCalc();
- Â Â Â Â Â Â parityInit();
- Â Â Â Â Â Â inputMinTerms();
- Â Â Â Â Â Â System.out.println();
- Â Â Â Â Â Â minTermsDectoBin();
-       System.out.print("\n\n  **STAGE 1**\n\n");
- Â Â Â Â Â Â firstStage();
- Â Â Â Â Â Â if (gzero != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\ngroup of 0s\n");
- Â Â Â Â Â Â Â Â displayArray(g0, gzero);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (gone != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\ngroup of 1s\n");
- Â Â Â Â Â Â Â Â displayArray(g1, gone);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (gtwo != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\ngroup of 2s\n");
- Â Â Â Â Â Â Â Â displayArray(g2, gtwo);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (gthree != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\ngroup of 3s\n");
- Â Â Â Â Â Â Â Â displayArray(g3, gthree);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â if (gfour != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\ngroup of 4s\n");
- Â Â Â Â Â Â Â Â displayArray(g4, gfour);
- Â Â Â Â Â Â }
-       System.out.print("\n\n  **STAGE 2**\n\n");
- Â Â Â Â Â Â hzero = compare(g0, g1, h0, gzero, gone);
- Â Â Â Â Â Â if (hzero != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 0 with 1:\n");
- Â Â Â Â Â Â Â Â displayArray(h0, hzero);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â hone = compare(g1, g2, h1, gone, gtwo);
- Â Â Â Â Â Â if (hone != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 1 with 2:\n");
- Â Â Â Â Â Â Â Â displayArray(h1, hone);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â htwo = compare(g2, g3, h2, gtwo, gthree);
- Â Â Â Â Â Â if (htwo != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 2 with 3:\n");
- Â Â Â Â Â Â Â Â displayArray(h2, htwo);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â hthree = compare(g3, g4, h3, gthree, gfour);
- Â Â Â Â Â Â if (hthree != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 3 with 4:\n");
- Â Â Â Â Â Â Â Â displayArray(h3, hthree);
- Â Â Â Â Â Â }
-       System.out.print("\n\n   **STAGE 3**\n\n");
- Â Â Â Â Â Â izero = compare1(h0, h1, i0, hzero, hone);
- Â Â Â Â Â Â izero = compareSame(i0, izero);
- Â Â Â Â Â Â if (izero != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 0 with 1:\n");
- Â Â Â Â Â Â Â Â displayArray(i0, izero);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â ione = compare1(h1, h2, i1, hone, htwo);
- Â Â Â Â Â Â ione = compareSame(i1, ione);
- Â Â Â Â Â Â if (ione != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 1 with 2:\n");
- Â Â Â Â Â Â Â Â displayArray(i1, ione);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â itwo = compare1(h2, h3, i2, htwo, hthree);
- Â Â Â Â Â Â itwo = compareSame(i2, itwo);
- Â Â Â Â Â Â if (itwo != 0) {
- Â Â Â Â Â Â Â Â System.out.print("\n\nComparing Group 2 with 3:\n");
- Â Â Â Â Â Â Â Â displayArray(i2, itwo);
- Â Â Â Â Â Â }
- Â Â Â Â Â Â System.out.print("\n\n Parity Check \n\n");
- Â Â Â Â Â Â paritycheck1(g0, g1, g1, gzero, gone, gone);
- Â Â Â Â Â Â paritycheck1(g1, g2, g0, gone, gtwo, gzero);
- Â Â Â Â Â Â paritycheck1(g2, g3, g1, gtwo, gthree, gone);
- Â Â Â Â Â Â paritycheck1(g3, g4, g2, gthree, gfour, gtwo);
- Â Â Â Â Â Â paritycheck1(g4, g3, g3, gfour, gthree, gthree);
- Â Â Â Â Â Â paritycheck2(h0, h1, h1, hzero, hone, hone);
- Â Â Â Â Â Â paritycheck2(h1, h0, h2, hone, hzero, htwo);
- Â Â Â Â Â Â paritycheck2(h2, h1, h3, htwo, hone, hthree);
- Â Â Â Â Â Â paritycheck2(h3, h2, h2, hthree, htwo, htwo);
- Â Â Â Â Â Â paritycheck3(i0, i1, i1, izero, ione, ione);
- Â Â Â Â Â Â paritycheck3(i1, i0, i2, ione, izero, itwo);
- Â Â Â Â Â Â paritycheck3(i2, i1, i1, itwo, ione, ione);
- Â Â Â Â Â Â parityToEqt();
- Â Â Â Â Â Â printParityTable();
- Â Â Â Â Â Â finalc = compareSamefinal(Final, finalc);
- Â Â Â Â Â Â System.out.print("\n");
- Â Â Â Â Â Â eqnGenerator();
- Â Â Â Â Â Â display d = new display();
- Â Â Â Â Â Â d.disp(s);
- Â Â Â Â } catch (Exception e) {
- Â Â Â Â Â Â System.out.println("Exception Encountered\n" + e + "\nPlease try again");
- Â Â Â Â }
- Â Â }
- }