Exercise logic.propositional.dnf
Description
Proposition to DNF
Derivation
((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~~(~q /\ p) /\ ~~(p /\ ~q) /\ ~~(p /\ ~q) /\ T
⇒ logic.propositional.idempand((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~~(~q /\ p) /\ ~~(p /\ ~q) /\ T
⇒ logic.propositional.truezeroand((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~~(~q /\ p) /\ ~~(p /\ ~q)
⇒ logic.propositional.notnot((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~~(p /\ ~q)
⇒ logic.propositional.notnot((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.truezeroand((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ ~~(T /\ p /\ ~q) /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ T /\ p /\ ~q /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ T /\ p /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.truezeroand((p /\ p /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ ~~(~q /\ p) /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ ~q /\ ~q /\ p /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ T /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.truezeroand((p /\ ~q /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~~~~(T /\ p /\ ~q) /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ ~q /\ p /\ q) || (p /\ ~~(T /\ p /\ ~q) /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ ~q /\ p /\ q) || (p /\ T /\ p /\ ~q /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ T /\ p /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.truezeroand((p /\ ~q /\ p /\ q) || (p /\ p /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~q /\ ~~(~q /\ p) /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.notnot((p /\ ~q /\ p /\ q) || (p /\ ~q /\ ~q /\ p /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~q /\ p /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~q /\ p /\ ~r /\ ~(T /\ r))) /\ ~q /\ p /\ ~q
⇒ logic.propositional.truezeroand((p /\ ~q /\ p /\ q) || (p /\ ~q /\ p /\ ~r /\ ~r)) /\ ~q /\ p /\ ~q
⇒ logic.propositional.idempand((p /\ ~q /\ p /\ q) || (p /\ ~q /\ p /\ ~r)) /\ ~q /\ p /\ ~q
⇒ logic.propositional.andoveror((p /\ ~q /\ p /\ q /\ ~q) || (p /\ ~q /\ p /\ ~r /\ ~q)) /\ p /\ ~q
⇒ logic.propositional.compland((p /\ ~q /\ p /\ F) || (p /\ ~q /\ p /\ ~r /\ ~q)) /\ p /\ ~q
⇒ logic.propositional.falsezeroand(F || (p /\ ~q /\ p /\ ~r /\ ~q)) /\ p /\ ~q
⇒ logic.propositional.falsezeroorp /\ ~q /\ p /\ ~r /\ ~q /\ p /\ ~q