aboutsummaryrefslogtreecommitdiff
path: root/examples/xor/xor_epsilon.vnnlib
diff options
context:
space:
mode:
Diffstat (limited to 'examples/xor/xor_epsilon.vnnlib')
-rw-r--r--examples/xor/xor_epsilon.vnnlib15
1 files changed, 15 insertions, 0 deletions
diff --git a/examples/xor/xor_epsilon.vnnlib b/examples/xor/xor_epsilon.vnnlib
new file mode 100644
index 0000000..427243e
--- /dev/null
+++ b/examples/xor/xor_epsilon.vnnlib
@@ -0,0 +1,15 @@
+; Epsilon Equivalence for XOR
+
+; Constant declaration
+(declare-const X_0 Real)
+(declare-const X_1 Real)
+(declare-const Y_0 Real)
+(declare-const Y_1 Real)
+
+; Bounded inputs: X must be 0 or 1
+(assert (or (= X_0 0) (= X_0 1)))
+(assert (or (= X_1 0) (= X_1 1)))
+
+; Violation of epsilon equivalence (epsilon = 0.1)
+(define-fun absolute ((x Real)) Real (if (>= x 0) x (- x)))
+(assert (> (absolute (- Y_0 Y_1)) 0.1))