Diesen Artikel habe ich erst 2015 aus dem alten CMS übernommen, der war 2012 noch nicht im Blog.
Ich weiß ehrlich gesagt nicht woher mein Faible für Taschenrechner kommt. Ich bin kein Mathematiker, und ehrlich gesagt kann ich mir auch nur den Bruchteil der Funktionen eines ‚großen‘ Taschenrechners schlüssig erklären. Aber die Dinger verarbeiten Einsen und Nullen, also muss auch da mal programmiert werden.
Auf Rechner des Herstellers Hewlett Packard bin ich seinerzeit durch einen Emulator auf meinem Nokia N800 aufmerksam geworden. Der heißt Free42, und den gibt es für jedes halbwegs gängige Betriebssystem. Ungewohnt war erstmal die umgekehrte polnische Notation (RPN), das war ein Konzept das ich verstehen wollte. Der Gedanke mir so einen Rechner als Original zuzulegen ist in dem Moment gestorben als ich gesehen habe dass das emulierte Modell — ein HP-42S — immer noch für weit über 150 Euro den Besitzer wechselt. Gebraucht, wohlgemerkt. Der wird seit 1990 nicht mehr hergestellt. Das macht neugierig…
Nun denn, zum Spielen reicht sicher auch die Emulation. Und da ich — außer einem Basic-programmierbaren Sharp PC-1402 Anfang der 90er — nie einen programmierbaren Taschenrechner hatte musste auch das mal ausprobiert werden.
HP-42S
Free42 auf Linux
Zufällig hatte ich auch gleich ein passendes Problem für die Lösung: zur Zeit arbeite ich in einem Unternehmen in dem Kaffee mit der Geldkarte bezahlt wird. Also mit dem Chip auf der Bankkarte, den man vorher mit Geld aufladen muss. Aufladen kann man nur um ganze Euro-Beträge. Ein Kaffee kostet aber 26 Cent, und ich würde die Karte gerne sauber ‚leer trinken‘. Also muss ich zu meinem Restbetrag den passenden ganzzahligen Euro-Betrag finden damit eine Summe zustande kommt die sich durch 26 Cent teilen lässt. Ein Mathematiker kann das sicher in eine Formel gießen. Wie gesagt: ich bin keiner.
Auf dem Gerät arbeitet man in der Programmiersprache FOCAL, also giesse ich das Problem in ein Programm:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
|
01 LBL "GELD" 02 0 03 STO 01 04 LBL B 05 RCL 01 06 100 07 + 08 STO 01 09 2 10 + 11 26 12 / 13 1 14 MOD 15 X!=0? 16 GTO B 17 RCL 01 18 100 19 / 20 .END. |
Dieses Programm ist alles andere als perfekt, reichte aber um mir zu zeigen wie man auf so einer merkwürdigen Hardware programmiert. Zur Funktionsweise: zunächst wird die Zahl 0 in Speicher 01 gespeichert. ‚LBL B‘ ist eine Sprungmarke. Dann wird der Wert aus Speicher 01 geholt, um 100 inkrementiert und wieder zurückgeschrieben. Der Wert steht jetzt noch bereit. Mit ‚2 +‘ wird 2 addiert (wir erinnern uns: umgekehrte polnische Notation. Zur Zahl 2 später mehr.), mit ’26 /‘ wird durch 26 Cent geteilt. Vom Ergebnis wird Modulo 1 gezogen. Ist das Ergebnis ungleich 0 wird zu Label B gesprungen, ansonsten wird der aktuelle Wert aus Speicher 01 geholt und durch 100 geteilt. Übrig bleibt der zu ladende Betrag in Euro.
Sicher kann man hier vieles verbessern. Die Zahl 2 ist der Restbetrag in Cent den ich noch auf der Karte habe, so eine ‚Magic Number‘ im Programm ist nicht schön. Außerdem kann es passieren — wenn ich beispielsweise doch mal 25 Cent am Parkautomaten investiert habe — dass mein Restbetrag eine ungerade Zahl ist. Da kann ich Euros addieren bis ich schwarz werde: es wird keine Summe rauskommen die glatt durch 26 Cent teilbar ist.
Aber immerhin: ich kann behaupten, schon einen Taschenrechner programmiert zu haben.
HP-48G
Mein HP-48G
Das hat eine Weile vorgehalten. Irgendwann hat mich das Fieber aber wieder gepackt, ich glaube weil ich für mein Android-Handy andere Emulatoren gefunden habe. Mit
Droid48 oder
go48g kann man einen HP-48G emulieren. Unter Linux nimmt man
x48 um zu spielen.
Der 48G hat gegenüber dem 42S eine Reihe von Vorteilen, einer der gewichtigsten dürfte der weitaus geringere Anschaffungswiderstand der Hardware sein. Das Ding wurde zwischen 1990 und 2003 produziert, 2012 habe ich 30 Euro für einen gebrauchten bezahlt.
Also das gleiche Problem nochmal:
|
< < "Restguthaben:" "" INPUT OBJ-> 0 26 -> rest betrag tasse < < DO betrag 100 + 'betrag' STO UNTIL betrag tasse 100 * >= rest betrag + tasse MOD 0 == OR END IF rest betrag + tasse MOD 0 == THEN betrag "Aufladen" ->TAG rest betrag + "Guthaben neu" ->TAG rest betrag + tasse / "Tassen" ->TAG ELSE "Keine Loesung" END |
Na das sieht doch schon deutlich weniger nach Assembler aus. Die Sprache nennt sich Reverse Polish LISP (RPL) und wirkt auf den ersten Blick wesentlich erwachsener. Auf den zweiten Blick fallen Zeilen auf in denen sehr merkwürdige Folgen von Variablen, Konstanten und Operatoren stehen. Aber auch eine Abbruchbedingung wie
|
betrag tasse 100 * >= rest betrag + tasse MOD 0 == OR |
lässt sich erklären. Wenn man die umgekehrte polnische Notation im Hinterkopf hat und lange genug drüber nachdenkt kommt man in etwa bei sowas raus (mit reichlich Klammern, um wirklich eindeutig zu sein:
|
(betrag >= (tasse * 100)) OR (((rest + betrag) MOD tasse) == 0) |
Wenn also in der Schleife der zu ladende Betrag grösser als 100 Tassen wird, oder die Summe aus Rest- und Ladebetrag ohne Rest durch 100 teilbar ist wird abgebrochen.
Zugegeben: ich hätte vielleicht auch übersichtlicher programmieren können. Aber etwas Spaß muss ja auch dabei sein, oder?
Und weiter?
Mein TI-Nspire
Ich habe hier noch einen Rechner, günstig geschossen während ich auf der Suche nach dem HP-48G war. Das ist ein
TI-Nspire von Texas Instruments. Der arbeitet zwar per Default nicht mit umgekehrter polnischer Notation, zeichnet sich aber durch andere Eigenschaften aus.
Als erstes fällt wenn man das Ding in die Hand nimmt das Display auf. Riesengroß, und mit einer Auflösung von 320×240 Punkten. Das schreit geradezu danach, darauf Grafiken zu plotten. Diese Auflösung macht auch eine richtige grafische Benutzeroberfläche möglich. Die ist zwar etwas gewöhnungsbedürftig, funktioniert aber nach einiger Zeit wirklich gut. Darin enthalten sind dann sogar komplexere Anwendungen, wie zum Beispiel eine Tabellenkalkulation.
Auf dem Foto ist auch zu sehen dass dieses Modell über zwei Tastaturen verfügt. Wenn man gerade mal einen ‚einfachen‘ wissenschaftlichen Taschenrechner vorzieht steckt man einfach die zweite Tastatur in das Gerät. Deren Layout ist dem TI-84 plus nachempfunden, und sobald man einschaltet wird eben dieser emuliert. Vollständig. Einschliesslich der vergleichsweise dürftigen Displayauflösung.
Programmiert habe ich diesen Taschenrechner noch nicht. Dabei verspricht das, spannend zu werden: als TI-84 plus unterstützt das Ding TI-Basic, als TI-Nspire sogar die ausgewachsene Skriptsprache Lua — die der eine oder andere vielleicht sogar vom großen Computer her kennt…
Siehe auch…