The purpose of this application is to simplify boolean expressions. It accomplishes the simplification using Quine-McClusky for expressions over 4 variables, and Karnaugh Map for expressions with 4 or less variables. Feel free to contribute!
- Allow simplification of boolean expressions from truth-table
- Converts truth-table to SOP (Sum of Product), then plots on Karnaugh-Map
- Uses Quine McCluskey method of simplification of 5+ variables
- Prime implicant matching is powered by branch-and-bound method
- Show pairing visualization for up to 4 variables
- Allow for mapping of pairings and SOP determination
- Easy to use interface, with ability of real-time
- Extensive unit test suite for expression simplification
- Ability to simulate grid by plotting disjoint sets on different levels
This application makes use of algorithms and data-structures to power a pattern recognition engine. For Karnaugh Maps, this application uses a unique non-standardized algorithm. Here's a quick overview of the steps:
- Gather required information from truth-table and generate matrix and SOP (Sum of Product) expressions
- Bitwise operators can make this easier/faster
- Indicate all
1
's in the truth-table with a value of1
in the matrix - Generate
2D prefix sum
array from the matrixPrefix sums
are a powerful technique dervived from the fundemental theorem of calculus- The idea of
prefix sums
are similar to integration in calculus - finding the area (sum) under a curve - We integrate the results and use
ƒ(b) - ƒ(a)
to quickly find the sum, allowing us to haveO(1)
summation - We can further apply the
principle of inclusion-exclusion
to extend prefix sums to be 2D
- Traverse through array, and for every
1
value execute the group finding algorithm - Group finding algorithm involves going from
[-1, N]
where N = # of columns or rows, and checking to see if the prefix sum is equal tox * y
.- The reason we go from [-1, N] is because you can have overlap to the other side of the Karnaugh Map
- Prefix Sums are a powerful technique as you can find if you can form a grouping in
O(1)
complexity since if there are pairs, the following is true:prefixSum(x1, y1, x2, y2) == (abs(x1-x2)+1)*(abs(y1-y2)+1)
! - Through some tricky careful implementation with prefix sums this will account for all cases
- Special note needs to be taken for the 4 corners case
- Store all the
groupings
in a specialdisjoint set
- The advantage of disjoint sets is that you can find duplicates quickly, and merge them quickly
- The ideal disjoint set used here is quick-union with path compression and union-by-rank
- Path compression allows to minimize the distance from the nodes to the root by making it a length of
1
upon amerge
orfind
- Union-by-rank decreases the depth of the tree by appending smaller trees below larger trees (hence rank)
- Store all
groupings
in aPriorityQueue
- Priority queue to store orders
- The ordering is established based off of the size of
(abs(x1-x2)+1)*(abs(y1-y2)+1)
, the size of the grouping - In case of ties, greedily assign them to squares
- Store a
hashset
that indicates if a grouping was already made, and if it was merge the current coordinate pointer to that disjoint set- In case it was not made, push the new group and create disjoint set
- Pop the priority queue until you get to a valid grouping not yet occupied
- Add final grouping to an answer (
LinkedList
) - Continue processing the rest of the grid, and by the end you have a LinkedList with all the groupings!
- Output groupings onto grid, be careful of wrapping cases, use
drawArc
anddrawRoundRect
where appropriate; use a circularly linked list to traverse colors for RGB and increment pointer each time