Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Zufallszahlenalgorithmus (https://www.delphipraxis.net/152851-zufallszahlenalgorithmus.html)

Codewalker 9. Jul 2010 11:23

Delphi-Version: 2009

Zufallszahlenalgorithmus
 
Ich bin auf der Suche nach ein paar Informationen, nach welchem Algorithmus Delphi mit der Funktion Random Zufallszahlen erzeugt. Dass es ein deterministisches Pseudo-Zufallszahl-Verfahren ist, hab ich noch relativ leicht rausbekommen (gleicher RandSeed --> gleiche Zufallszahlen in gleicher Reihenfolge). Die Delphi-Hilfe gibt leider auch nicht allzu viel Info her. Weiß jemand etwas mehr darüber?

gammatester 9. Jul 2010 11:30

AW: Zufallszahlenalgorithmus
 
Effektiv wird bei jedem Aufruf von random etc RandSeed := $08088405*RandSeed + 1; berechnet (in 32-Bit-Arithmetik).

Codewalker 9. Jul 2010 11:33

AW: Zufallszahlenalgorithmus
 
Zitat:

Zitat von gammatester (Beitrag 1034482)
Effektiv wird bei jedem Aufruf von random etc RandSeed := $08088405*RandSeed + 1; berechnet (in 32-Bit-Arithmetik).

Das ist doch schonmal was (woher auch immer du das hast :wink:). Jetzt fehlt nur doch der Schritt, der die eigentliche Zufallszahl ausspuckt. Kannst du auch noch aushelfen?

blackfin 9. Jul 2010 11:38

AW: Zufallszahlenalgorithmus
 
Die Funktion Random steht doch als ASM-Quelltext in der Unit System?...

himitsu 9. Jul 2010 11:39

AW: Zufallszahlenalgorithmus
 
Zitat:

Zitat von Codewalker (Beitrag 1034484)
(woher auch immer du das hast :wink:)

schau mal in deine System-Unit (system.pas) da findest du den Algorithmus.
(gut, auch wenn es da als Assembler dasteht)

Zitat:

Jetzt fehlt nur doch der Schritt, der die eigentliche Zufallszahl ausspuckt.
Wie gesagt ... schau einfach mal nach.

Dieser Zufallswert wird als als 0..MaxInt behandelt und dann auf 0..(x-1) runterskaliert.

[edit]
@blackfin: zustimm

Codewalker 9. Jul 2010 11:41

AW: Zufallszahlenalgorithmus
 
Zitat:

Zitat von blackfin (Beitrag 1034487)
Die Funktion Random steht doch als ASM-Quelltext in der Unit System?...

Gott wie peinlich. Ich bin schon fast fest davon ausgegangen eh nur auf der Platzhalterzeile in der Systems.pas zu landen und hab es gar nicht ausprobiert. Dann werde ich mal mein Assembler entstauben müssen.
Danke :thumb:

gammatester 9. Jul 2010 11:47

AW: Zufallszahlenalgorithmus
 
Aus der RTL. Der andere Teil ist etwas kitzliger, hier ein Äquivalent für Delhis mit int64. In der RTL wird Assembler benutzt. Man nimmt die höheren Bits, weil die zufälliger sind.
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  a,b: longint;
const
  ARange = 100000;
begin
  a := random(ARange);
  b := (int64(ARange) * RandSeed) shr 32;
  if b<0 then b := b+ARange;
  button1.Caption := InttoHex(a,8) + ' / ' + IntToHex(b,8);
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:22 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz