Forum: PC-Programmierung Lisp-Fragment nach Python übersetzen


von Mampf F. (mampf) Benutzerseite


Lesenswert?

Hallo :)

Ich quäle mich gerade durch einen überschaubar langen Lisp-Code, den 
ich gerne nach Python übersetzen möchte. Ich denke, ich habe 
mittlerweile das meiste herausgefunden ...

Es gibt aber einen kleinen Teil, bei dem mir die Abfolge der Befehle etc 
nicht klar ist ... Also in welcher Reihenfolge die Bedingung geprüft, 
der Schleifenzähler modifiziert usw wird.
1
      ;;do a basic binary search
2
      (do ((i (+ start 1) (+ start (/ (- end start) 2))))
3
          ((or (= i start) (= i end))
4
           i)
5
        (let ((yi (- (aref para (+ i x)) (aref para i))))
6
          (if (> yi y)
7
              (setf end i)
8
              (setf start i)))))))

"para" ist nur ein Liste mit irgendwelchen Elementen.

Ich hab es jetzt erstmal so wörtlich wie möglich übersetzt ...
1
    # init loop
2
    ret=None
3
    i=start+1
4
    while True:
5
        # evaluate
6
        if i is start or i is end:
7
            ret=i
8
            break
9
        
10
        # execute
11
        yi=para[i+x]-para[i]
12
        if yi>y:
13
            end=i
14
        else:
15
            start=i
16
17
        # prepare next loop
18
        i=start+(end-start)/2
19
20
    print(ret)

Insbesondere, wo end und start modifiziert und anschließend die Variable 
i neu berechnet wird, wäre es kritisch zu wissen, was wann passiert.

Würde das in etwa so passen?

Viele Grüße

: Bearbeitet durch User
von Andreas S. (andreas) (Admin) Benutzerseite


Lesenswert?

Statt das Zeile für Zeile nachzubauen, nimm doch einfach eine 
Standardimplementierung der binären Suche: 
https://docs.python.org/3.6/library/bisect.html

von Mampf F. (mampf) Benutzerseite


Lesenswert?

Andreas S. schrieb:
> Statt das Zeile für Zeile nachzubauen, nimm doch einfach eine
> Standardimplementierung der binären Suche:

Danke für den Link, aber das löst mein Problem nicht.

Der gesamte Lisp-Code ist weit umfangreicher und nicht so standard wie 
die binäre Suche. Es war deshalb unerlässlich, den Lisp-Code zu 
verstehen, bevor ich ihn Zeile für Zeile nachbaue :)

Mittlerweile hab ich alles übersetzt und es funktioniert sogar yay

von Yalu X. (yalu) (Moderator)


Lesenswert?

Eine kleine Anmerkung:

Mampf F. schrieb:
> if i is start or i is end:

Hier solltest du die beiden "is" durch "==" ersetzen, denn "is"
vergleicht Objektreferenzen und "==" Objektinhalte, hier also die
Zahlenwerte.

Bei zwei verschiedenen Objekten mit gleichen Inhalt liefern "is" und
"==" unterschiedliche Ergebisse, wie folgendes Beispiel zeigt:

1
>>> a = 257
2
>>> b = 257
3
>>> a == b
4
True
5
>>> a is b
6
False

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.