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