doc-src/Intro/gate2.thy
author blanchet
Sun, 04 Mar 2012 23:20:43 +0100
changeset 46818 2a28e66e2e4c
parent 105 216d6ed87399
permissions -rw-r--r--
ensure no abstractions leak through after lambda-lifting (for formulas with higher-order occurrences of quantifiers)

Gate2 = FOL +
consts  "~&"     :: "[o,o] => o" (infixl 35)
        "#"      :: "[o,o] => o" (infixl 30)
        If       :: "[o,o,o] => o"       ("if _ then _ else _")
rules   nand_def "P ~& Q == ~(P & Q)"    
        xor_def  "P # Q  == P & ~Q | ~P & Q"
        If_def   "if P then Q else R == P&Q | ~P&R"
end