Mathematical Logic and NUMBAS Available at Github.Com/Tandethsquire/Logicnode

Mathematical Logic and NUMBAS Available at Github.Com/Tandethsquire/Logicnode

Mathematical Logic and NUMBAS Available at github.com/Tandethsquire/LogicNode Andrew Iskauskas EAMS 2018, Newcastle August 29th, 2018 Andrew Iskauskas Mathematical Logic and NUMBAS Motivation Many problems in an introductory course to Logic lend themselves to some degree of randomisation in assessments: Validity of Syllogisms Conversion of statements to/from Polish notation Model equivalence and statements in propositional logic Normal forms (conjunctive and disjunctive) However, implementing such questions in `vanilla' NUMBAS is code-heavy with a lot of repetition between disparate problems. Andrew Iskauskas Mathematical Logic and NUMBAS Example: Valuing Statements One such problem is finding the truth table for (P ^ Q) !:R. To evaluate this type of statement, we can use the equivalence P ! Q ≡ (:P) _ Q. But when the operands of ! are complex, converting this becomes a non-trivial exercise in regular expressions, and is extremely sensitive to the presentation of the expression: will (((P) ^ (Q)) ! (:(R))) give the same result? Andrew Iskauskas Mathematical Logic and NUMBAS Parse Trees The key ingredient to dealing with many such problems is the use of a parse tree: (P ^ Q) !:R ! ^ : P Q R An implementation of this in NUMBAS would allow for valuations of the tree, comparisons of different trees, and a way of obtaining equivalent expressions of the logical statement. Andrew Iskauskas Mathematical Logic and NUMBAS Implementation In Logic.js, we treat each element of the parse tree as a node object, with parent, children, and value properties. By collecting and linking together many such nodes, the parse tree is abstractly represented. From this, we can extract the logical statement in different notations (particularly Polish and reverse Polish notation), and by giving the variables P,Q,R ::: true/false valuations and collapsing the tree, extract the truth table for a statement. Andrew Iskauskas Mathematical Logic and NUMBAS Collapsing Consider the valuation P = T , Q = F , R = T of our statement: _ ! : : _ ^ : ^ F : F T F T T F F Substitution of ! is achieved by modifying the node structure, and collapsing is performed recursively from the bottom up. Andrew Iskauskas Mathematical Logic and NUMBAS Applications Expressions: make components produces a collection of nodes; string from tree converts the nodes into Polish (prefix), reverse Polish (postfix), or standard (infix) notation. Truth Tables: truth table creates an array of all possible valuations of the statement Model equivalence: make model creates a collections of statements, whose truth tables can be compared to check equivalence Conjunctive and Disjunctive Forms: normal form creates (or converts) a tree as `an AND of ORs', or an `OR of ANDs'. Andrew Iskauskas Mathematical Logic and NUMBAS Example Andrew Iskauskas Mathematical Logic and NUMBAS Further Applications Not complete by any means: examples of further work include Visualisation of the parse tree (an attempt in this direction can be found in tree to canvas in LogicNode.js); Generating arguments in `natural' English corresponding to a propositional logic system (an extension of the model generation); Complete Operator Sets: given a set of connectives, can the set f:; ^g be expressed? Andrew Iskauskas Mathematical Logic and NUMBAS Join in! The .js file for the Logic extension can be found at github.com/Tandethsquire/LogicNode; pull requests are warmly received. An example of what can be done with the current functions can be found in the NUMBAS demo exam numbas.mathcentre.ac.uk/exam/7728/logic-node-demo/ Andrew Iskauskas Mathematical Logic and NUMBAS.

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    10 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us