master > master: allgemeine Aufräumung
This commit is contained in:
9
code/grammars/README.md
Normal file
9
code/grammars/README.md
Normal file
@@ -0,0 +1,9 @@
|
||||
# LARK #
|
||||
|
||||
Die Grammatik wird hier in `.lark` Format präsentiert und gelext+geparsed.
|
||||
Für Python braucht man `lark`, `lark-parser`, `lark-parser[regex]` über **PIP** zu installieren.
|
||||
Siehe
|
||||
<https://lark-parser.readthedocs.io/en/latest/grammar.html>
|
||||
und
|
||||
<https://github.com/lark-parser/lark>
|
||||
für mehr Informationen zu **LARK**.
|
||||
35
code/grammars/grammar.lark
Normal file
35
code/grammars/grammar.lark
Normal file
@@ -0,0 +1,35 @@
|
||||
%import common.WS
|
||||
%import common.NUMBER
|
||||
%import common.WORD
|
||||
|
||||
%ignore WS
|
||||
|
||||
// Schemata für Ausdrücke
|
||||
?expr: open | closed
|
||||
?closed: atomic | not | "(" open ")"
|
||||
?open: and | and2 | or | or2 | implies
|
||||
|
||||
// Schemata für atomische Ausdrücke
|
||||
?atomic: taut | contradiction | atom | generic
|
||||
?taut: /1|true/ -> taut
|
||||
?contradiction: /0|false/ -> contradiction
|
||||
?atom: /A[0-9]+/ -> atom
|
||||
// als 'generische' Formeln schreibe bspw. {F}, {G}, {F1}, usw.
|
||||
?generic: "{" /((?!({|})).)+/ "}" -> generic
|
||||
|
||||
// Symbole (erlaube mehrere Varianten)
|
||||
?symb_not: /!|~|not/ -> symb
|
||||
?symb_and: /&+|\^|and/ -> symb
|
||||
?symb_or: /\|+|v|or/ -> symb
|
||||
?symb_impl: /->|=>/ -> symb
|
||||
|
||||
// Schema für Negation: ¬ F
|
||||
?not: symb_not closed
|
||||
// Schemata für Konjunktion: F1 ⋀ F2 bzw. F1 ⋀ F2 ⋀ ... ⋀ Fn
|
||||
?and2: closed symb_and closed
|
||||
?and: [ closed ( symb_and closed )+ ]
|
||||
// Schemata für Disjunktion: F1 ⋁ F2 bzw. F1 ⋁ F2 ⋁ ... ⋁ Fn
|
||||
?or2: closed symb_or closed
|
||||
?or: [ closed ( symb_or closed )+ ]
|
||||
// Schema für Implikation: F1 ⟶ F2
|
||||
?implies: closed symb_impl closed
|
||||
Reference in New Issue
Block a user