![]() |
VLI - very long integer
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo,
ich habe vor längerer Zeit auf meiner Website die Unit VLI vorgestellt, die das Hantieren mit Ganzzahlen erlaubt, die größer als Int64 sind. Leider war die Unit nie ganz fertig, da die Division gefehlt hat. Ich habe die Unit nun komplettiert, die Division nutzt eine Routine, die von Prof. Flanders in seinem Buch 'Scientific Pascal' vorgestellt hat. Weiterhin benutze ich zur Addition eine Routine, die ich von peanut aus seiner BigInt-Unit übernommen habe, ich hoffe, peanut hat nichts dagegen. Mir ist klar, dass es schon eine Reihe von BigInt-Implementierungen gibt. Dank Prof. Flanders ist meine Division aber erheblich schneller als in den meisten Implementierungen. Ich habe die Unit mit Delphi 2009/XE entwickelt, eigentlich sollte sie auch mit älteren Version laufen. Ein Beisipiel zur Verwendung:
Delphi-Quellcode:
Wer Lust und Zeit hat, kann die Unit gern testen. Ich bedanke mich jetzt schon für Rück- und Fehlermeldungen.
var
A, B, Q, R: TVLI; begin A := TVLI.Create('12345789123456789123457891234567891234578912345678912345789123456790'); B := TVLI.Create('12345789123456789'); Q := TVLI.Create; R := TVLI.Create; try Q.Divide(A, B, R); Memo1.Lines.Add('A = ' + A.AsString); Memo1.Lines.Add('B = ' + B.AsString); Memo1.Lines.Add('A / B = ' + Q.AsString + ' Rest ' + R.AsString); finally R.Free; Q.Free; B.Free; A.Free; end; end; Lutz PS: Ich habe noch einen Fehler in der Division entdeckt und die Unit nochmal ausgetauscht. |
AW: VLI - very long integer
Es wäre noch ganz nett, das ganze als record zu implementieren, dann muss man sich nicht mit Instanzen rumschlagen.
Auch interressant wäre es, einige Operatoren zu überlasen, dass wird aus
Delphi-Quellcode:
ein
VLI.Add(OtherVLI)
Delphi-Quellcode:
CLI + OtherVLI
|
AW: VLI - very long integer
Dafür kannst'e gern eine meiner Mathe-Libs nehmen.
Diese sind quasi eh "nur" Proof-of-Concepts ... Das sind sozusagen Vorlagen, für sowas. ![]() ![]() ... Ansonsten hat das einen Nachteil: - vor Delphi 2006 könnte es keiner nutzen (aber OK, es sind ja nun schon 4 Versionen, wo das denoch funktioniert) - und es lassen sich so nicht alle Operationen umsetzen, so daß sich so nur schwer ein stimmiges Konzept aufbauen läßt PS: ![]() |
AW: VLI - very long integer
Zitat:
|
AW: VLI - very long integer
Hallo,
ich hatte über records auch schon nachgedacht. Operatorüberladung wäre klasse, allerdings wird der Constructor nicht automatisch aufgerufen, was schon wieder nachteilig ist. Lutz |
AW: VLI - very long integer
Ja, leider gibt es für Records keinen automatischen "Constructor".
Es kann aber gern gevotet werden: ![]() Allerdings nutzt du ein dynamisches Array, welches dennoch automatisch initialisiert wird. Bei meinen Operator-Records nutze ich deshalb gerne notgedrungen solche Typen, wie dyn. Arrays, Strings oder Interfaces, als Marker, wenn ich noch andere "uninitialisierte" Typen verwende, wie z.B. dein FMinus (Boolean). Sind diese nil (oder ''), dann wurde der Record noch nicht initialisiert, nun wird also in allen Recordmethoden/Operatoren am Anfang eine Prüfmethode eingebunden, welche auf eine Initialisierung prüft.
Delphi-Quellcode:
procedure TVLI.InitCheck;
begin if FVLIAr = nil then begin SetLength(FVLIAr, 1); FVLIAr[0] := 0; FMinus := false; end; end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:53 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz