-
Notifications
You must be signed in to change notification settings - Fork 760
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Extending PSI Logic to support NOT Operator
Added support for processing queries with the NOT operator homomorphically. Introduced the NOT Expr, and a corresponding inline NOT QueryExpr Within the weights, or CNF, framework: * Extensions to the ExpandOr() function to queries with NOT operators, via a new function negate() * New function Tidy() which eliminates duplicate columns in inner clauses, or columns and their negation in inner clauses that can be created by squashing ORs. It also eliminates empty clauses, * Put the code from build() which constructed the corresponding weights into a new function buildWeights(), and extended this to the case there are negations of columns * New framework which evaluates queries homomorphically directly from the string: * New function removeOr() within the QueryBuilder class which generates a new query string which is logically equivalent, but only has Ands and Nots * Overloaded contains() function that takes a string instead of a QueryType, and evaluates the RPN directly using a stack of ciphertexts Co-authored-by: @TabOg Co-authored-by: @jlhcrawford Co-authored-by: @hamishun
- Loading branch information
Showing
8 changed files
with
942 additions
and
177 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.