# RUN: %kleaver --builder=simplify -print-ast %s > %t array a[64] : w32 -> w8 = symbolic # Check -- X u> Y ==> Y u< X # RUN: grep -A 2 "# Query 1" %t > %t2 # RUN: grep "(query .. false .(Ult (Read w8 1 a) (Read w8 0 a)).)" %t2 (query [] false [(Ugt (Read w8 0 a) (Read w8 1 a))]) # Check -- X u>= Y ==> Y u<= X # RUN: grep -A 2 "# Query 2" %t > %t2 # RUN: grep "(query .. false .(Ule (Read w8 1 a) (Read w8 0 a)).)" %t2 (query [] false [(Uge (Read w8 0 a) (Read w8 1 a))]) # Check -- X u> Y ==> Y u< X # RUN: grep -A 2 "# Query 3" %t > %t2 # RUN: grep "(query .. false .(Slt (Read w8 1 a) (Read w8 0 a)).)" %t2 (query [] false [(Sgt (Read w8 0 a) (Read w8 1 a))]) # Check -- X u>= Y ==> Y u<= X # RUN: grep -A 2 "# Query 4" %t > %t2 # RUN: grep "(query .. false .(Sle (Read w8 1 a) (Read w8 0 a)).)" %t2 (query [] false [(Sge (Read w8 0 a) (Read w8 1 a))]) # Check -- X != Y ==> !(X == Y) # RUN: grep -A 2 "# Query 5" %t > %t2 # RUN: grep "(query .. false .(Not (Eq (Read w8 0 a) (Read w8 1 a))).)" %t2 (query [] false [(Ne (Read w8 0 a) (Read w8 1 a))]) # Check -- !(X or Y) ==> !X and !Y # RUN: grep -A 3 "# Query 6$" %t > %t2 # RUN: grep "(query .. false .(And (Not (Eq 0 (Read w8 0 a)))" %t2 # RUN: grep "(Not (Eq 1 (Read w8 1 a))))" %t2 (query [] false [(Not (Or (Eq 0 (Read w8 0 a)) (Eq 1 (Read w8 1 a))))]) # Check -- false == X ==> !X # RUN: grep -A 2 "# Query 7" %t > %t2 # RUN: grep "(query .. false .(Not (Extract 1 (Read w8 0 a))).)" %t2 (query [] false [(Eq (Extract w1 1 (Read w8 0 a)) false)])