Compare commits

...

2 Commits

Author SHA1 Message Date
b8e2b10ed3 master > master: protokoll woche 4 2021-05-05 12:57:26 +02:00
73f905a5cd master > master: code 2021-05-05 12:57:17 +02:00
3 changed files with 80 additions and 24 deletions

View File

@ -10,12 +10,13 @@ import os;
import sys; import sys;
sys.tracebacklimit = 0; sys.tracebacklimit = 0;
from itertools import product; from itertools import product;
from lark import Tree;
from textwrap import dedent;
from typing import Dict; from typing import Dict;
from typing import Generator; from typing import Generator;
from typing import List; from typing import List;
from typing import Tuple; from typing import Tuple;
from typing import Union; from typing import Union;
from lark import Tree;
sys.path.insert(0, os.getcwd()); sys.path.insert(0, os.getcwd());
@ -41,32 +42,68 @@ I = ['A0', 'A2'];
def main(): def main():
tree = string_to_parts(zeichenkette); tree = string_to_parts(zeichenkette);
print('Syntaxbaum von \033[1m{}\033[0m:\n'.format(zeichenkette)); print(dedent(
'''
Syntaxbaum von
F := \033[92;1m{F}\033[0m:
'''.format(
F=zeichenkette,
)
));
print(tree.pretty()); print(tree.pretty());
val = rekursiv_eval(tree, I) print(dedent(
print('eval(Formel, I) = \033[1m{}\033[0m'.format(val)); '''
eval(F, I) = \033[94;1m{eval}\033[0m;
atoms(F) = \033[94;1m{atoms}\033[0m; \033[91;1m<- *\033[0m
depth(F) = \033[94;1m{d}\033[0m; \033[91;1m<- *\033[0m
length(F) = \033[94;1m{l}\033[0m; \033[91;1m<- *\033[0m
#parentheses(F) = \033[94;1m{p}\033[0m; \033[91;1m<- *\033[0m
\033[91;1m*\033[0m \033[2mnoch nicht implementiert!\033[0m
\033[1;2;4mChallenge:\033[0m \033[2mschreibe diese Methoden. Probiere mit Stift-und-Zettel die Methoden händisch auszuführen und vergleiche mit dem Code-Output.\033[0m
'''.format(
eval = rekursiv_eval(tree, I),
atoms = rekursiv_atoms(tree),
d = rekursiv_depth(tree),
l = rekursiv_length(tree),
p = rekursiv_parentheses(tree),
)
));
return; return;
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# SEKUNDÄRVORGÄNGE # SEKUNDÄRVORGÄNGE
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def rekursiv_eval(fml: Tree, I: List[str]) -> bool: def rekursiv_atoms(fml: Tree) -> List[str]:
if fml.data == 'atom': ## Herausforderung: schreibe diese Funktion!
return [];
def rekursiv_depth(fml: Tree) -> int:
## Herausforderung: schreibe diese Funktion!
return 0;
def rekursiv_length(fml: Tree) -> int:
## Herausforderung: schreibe diese Funktion!
return 0;
def rekursiv_parentheses(fml: Tree) -> int:
## Herausforderung: schreibe diese Funktion!
return 0;
def rekursiv_eval(fml: Tree, I: List[str]) -> int:
if fml.data in ['atom', 'beliebig']:
index = fml.children[0]; index = fml.children[0];
return 'A{}'.format(index) in I; return 1 if ('{}'.format(index) in I) else 0;
elif fml.data == 'beliebig':
name = fml.children[0];
return '{}'.format(name) in I;
elif fml.data == 'wahr': elif fml.data == 'wahr':
return True; return 1;
elif fml.data == 'falsch': elif fml.data == 'falsch':
return False; return 0;
elif fml.data == 'negation': elif fml.data == 'negation':
teilformel1 = fml.children[1]; teilformel1 = fml.children[1];
if isinstance(teilformel1, Tree): if isinstance(teilformel1, Tree):
val1 = rekursiv_eval(teilformel1, I); val1 = rekursiv_eval(teilformel1, I);
return not val1; return 1 - val1;
elif fml.data == 'konjunktion': elif fml.data == 'konjunktion':
teilformel1 = fml.children[0]; teilformel1 = fml.children[0];
teilformel2 = fml.children[2]; teilformel2 = fml.children[2];
@ -87,7 +124,7 @@ def rekursiv_eval(fml: Tree, I: List[str]) -> bool:
if isinstance(teilformel1, Tree) and isinstance(teilformel2, Tree): if isinstance(teilformel1, Tree) and isinstance(teilformel2, Tree):
val1 = rekursiv_eval(teilformel1, I); val1 = rekursiv_eval(teilformel1, I);
val2 = rekursiv_eval(teilformel2, I); val2 = rekursiv_eval(teilformel2, I);
return (val1 <= val2); return 0 if val1 == 1 and val2 == 0 else 1;
else: else:
raise Exception('Evaluation nicht möglich!'); raise Exception('Evaluation nicht möglich!');
return True; return True;

View File

@ -33,7 +33,7 @@ lexerAussagenlogik = Lark(
?atomic: false | true | atom | generic ?atomic: false | true | atom | generic
?false: "0" -> wahr ?false: "0" -> wahr
?true: "1" -> falsch ?true: "1" -> falsch
?atom: "A" /[0-9]+/ -> atom ?atom: /A[0-9]+/ -> atom
?generic: "{" /((?!({|})).)+/ "}" -> beliebig ?generic: "{" /((?!({|})).)+/ "}" -> beliebig
// Symbole // Symbole
@ -44,8 +44,8 @@ lexerAussagenlogik = Lark(
// Junktoren // Junktoren
?expr_not: conn_not expr -> negation ?expr_not: conn_not expr -> negation
?expr_and: "(" expr conn_or expr ")" -> konjunktion ?expr_and: "(" expr conn_and expr ")" -> konjunktion
?expr_or: "(" expr conn_and expr ")" -> disjunktion ?expr_or: "(" expr conn_or expr ")" -> disjunktion
?expr_implies: "(" expr conn_impl expr ")" -> implikation ?expr_implies: "(" expr conn_impl expr ")" -> implikation
''', ''',
start="expr", start="expr",

View File

@ -1,6 +1,6 @@
# Vorlesungswoche 4 (3. April 9. Mai) # # Vorlesungswoche 4 (3. April 9. Mai) #
- [ ] Organisatorisches (max. 5 min) - [x] Organisatorisches (max. 5 min)
- Hochladen = Abgeben - Hochladen = Abgeben
- Zoom - Zoom
- Zugriff - Zugriff
@ -12,26 +12,45 @@
- Wohldefiniertheit: einfach! - Wohldefiniertheit: einfach!
- bottom-up - bottom-up
- wohlfundierte Relationen - wohlfundierte Relationen
- Wohldefiniertheit: (schwer!) - Wohldefiniertheit: (mühseliger!)
- Satz: bottom-up = top-down - Satz: bottom-up = top-down
- ⊇: weil bottom-up Eigenschaft hat und top-down kleinstmögliche Menge mit Eigenschaft ist.
- ⊆: (schwerer) zeige, dass alles in Klasse alle _n_-ten Stufen enthält, damit gilt Schnitt aus Klasse (=:top-down) enthält Vereinigung (=:bottom-up)
- Präsentation (Schemata) - Präsentation (Schemata)
- für Mengen
- als Liste
- durch `"... | ... | ..."` Schreibweise
- für Funktionen
- definiere ƒ für Basisfälle.
- definiere ƒ für Zusammensetzung durch Werte von ƒ auf Teilen.
- Beispiele: - Beispiele:
- eval(·, I) - [x] als „kleinste Menge“, die 0 enthält und unter +1 abgeschlossen ist.
- Atome(·) - [x] eval(·, I)
- Länge - [ ] Atome(·) -> kommt nächste Woche!
- [ ] Länge -> kommt nächste Woche!
- Induktion - Induktion
- Aus Sicht von bottom-up (-> verallgemeinert Induktion über ) - Aus Sicht von bottom-up (-> verallgemeinert Induktion über )
- wieso funktioniert es? (Beweis durch Widerspruch -> betrachte `min{x | ¬ ф(x)}`) - wieso funktioniert es? (Beweis durch Widerspruch -> betrachte `min{x | ¬ ф(x)}`)
- „min“ hier bzgl. x ≤ y ⟺ x (strikte) Teilformel von y
- alternativ bzgl. x ≤ y ⟺ |Zeichen in x| < |Zeichen in y|
- Beispiele - Beispiele
- strukturelle Induktion - strukturelle Induktion
- Aus Sicht von top-down (!! neue Sichtweise !!) - Aus Sicht von top-down (!! neue Sichtweise !!)
- wieso funktioniert es? (direkter Beweis: `{x | ф(x)} ⊇ »kleinste Menge«`) - wieso funktioniert es? (direkter Beweis: `{x | ф(x)} ⊇ »kleinste Menge«`)
- Beispiele - Beispiele
- [ ] weitere Fragen nach Aufzeichnungsende. - [x] weitere Fragen nach Aufzeichnungsende.
- wie verhält sich das mit Russellmenge?
-> „gelöst“ durch wohlfundiert/Wohlordnung
-> R keine Menge
## Nächste Woche ## ## Nächste Woche ##
- Seminaraufgaben für Serie 2 - Seminaraufgaben für Serie 2:
- KNF/DNF
- Hornformeln / Alg
- str. Induktion / Rekursion
- ~~Kompaktheit~~ (-> möglich nach der ÜG)
### TODOs (Studierende) ### ### TODOs (Studierende) ###