-
Notifications
You must be signed in to change notification settings - Fork 0
First Order Logic Modifications
Tobias J. Park edited this page Feb 25, 2020
·
4 revisions
Author: Tobias Park
The following is a list of modifications that we may need to make to ALPACA to support first order logic proofs.
- Tree.cpp, line 138 and beyond - ALPACA's tree structure does not natively support -> and = expressions. Instead, it converts them into OR statements. In first order logic proofs, we need to be able to support conditional introduction/elimination and = introduction/elimination, and we cannot do this if every -> and = symbol is simply turned into an OR statement.
Possible solutions:
- Create a new type of Node in the structure that supports > statements; for instance, it can be a Node object that stores a premise statement and a conclusion statement.
- Still convert > and = to OR statements, but make a note (via a private variable, perhaps) that the statement was originally an > or = -type statement. Then, the first order logic program can be programmed to be able to notice this and tree the modified OR statements as if they were their original > or = counterparts. However, this could be complicated and messy; it may not be an elegant solution.
- statementevaluator.cpp is not applicable for first order logic because we are not creating truth tables.... unless we want a tool that acts as an automated theorem prover, such as Taut Con in Professor Bram's Intro to Logic Class.