Skip to content

Latest commit

 

History

History
58 lines (38 loc) · 3.02 KB

README.md

File metadata and controls

58 lines (38 loc) · 3.02 KB

belarus

Run on Repl.it

Wir haben uns entschieden den Interpreter in Nim (https://github.com/nim-lang/Nim) zu schreiben, da @whiterock die Sprache für seine Hobbyprojekte verwendet und sie gut geeignet ist (außerdem machts halt irgendwie Spaß in Nim zu schreiben).

how to compile

Zuerst den Nim compiler installieren: https://nim-lang.org/install.html

nim c ibelarus.nim

Falls das aus irgendeinem Grund nicht funktionieren sollte so befinden sich zwei Releases, einer für macOS (gestestet auf macOS 10.15) und einer für Linux im Ordner releases.

Falls auch das Scheitern sollte kann das Programm online auf Run on Repl.it kompiliert und ausgeführt werden!

how to run

./ibelarus

Daraufhin erscheint die REPL welche in register A gespeichert ist.

Bienvenue!
Input:

Z.B.

5 3 +
8.0
Input:

registers

Register Programm Usage Beispiel
A REPL Auszuführende Befehle eingeben und Enter drücken. Wenn das Programm ausgeführt wird kommt man immer sofort in die REPL. 8 3 + == 11.0
B Fläche eines Dreiecks mit 3 (3D) Koordinaten x1 y1 z1 x2 y2 z2 x3 y3 z3 b@ 1 1 5 4 1 5 4 5 5b@ == 6.0
C Fläche von n Dreiecken mir jeweils 3 (3D) Koordinaten x1 y1 z1 x2 y2 z2 x3 y3 z3(n-times) + n c@ 1 1 5 4 1 5 4 5 5 1 1 5 4 1 5 4 5 5 2 c@ == 12.0
D Oberfläche eines Oktaeders auf zwei Arten (normale Formel vs. mittels C) d@ (interaktiv) d@ und dann Seitenlänge eingeben, e.g. 5 liefert 86.60

design decisions

Die REPL verwendet den Stack zur Rekursion und laesst dem Benutzer dadurch alle anderen Register zur Verfuegung. Dieser Trade-off laesst dem Benutzer alle Register zur Verfuegung waehrend der zu bezahlende Preis ein Stack-Offset ist (bei Operation '#' in der REPL zu beachten).

Die Alternative dazu stellt eine Rekursion mittels Register dar, wie sie beispielsweise beim Berechnen von mehreren Dreiecken (das Programm in Register C) verwendet wird. Dabei wird ein Teil des Codes in ein Register (in dem Fall das Register P) gespeichert und von diesem Register immer wieder geladen und ausgefuehrt.

allocation of work

Herr Weissenfels hat damals mit der Implementation des Stacks und dem simplen Grundgerüst begonnen. Danach haben wir beide parallel verschiedene Operatoren implementiert, getestet und Fehler behoben. Herr Regen hat sich dann mit der Implementation der REPL beschäftigt; parallel dazu hat sich Herr Weissenfels mit der Implementation des Programms in register B beschäftigt bei der neue Fehler zum Vorschein kamen. Herr Regen hat dann noch die Programme in register C und D geschrieben. Tatsaechlich war der Entwicklungsprozess ineinander stark verflochten und eine genauere Aufteilung ist den Git-Logs zu entnehmen.

Hiermit bestaetigen wir, dieses Programm persoenlich entwickelt zu haben.