Author: Dieter Buerssner
Date: 12:58:56 11/04/02
Go up one level in this thread
On November 04, 2002 at 15:18:04, Severi Salminen wrote: >>>>__int64 rand64() >>>>{ >>>> int a,b,c,d,e; >>>> a=rand(); >>>> b=rand()<<15; >>>> c=rand()<<30; >>>> d=rand()<<45; >>>> e=rand()<<60; >>>> >>>> return a^((__int64)b)^((__int64)c)^ >>>> ((__int64)d)^((__int64)e); >>>>} >>> >>>Under most systems, d and e will be zero. > >A few points. As Dieter said, the above is wrong, because of too late type >casts. Secondly why do you use XOR? Why not OR, the result is about the same? OR >has a definite sequence points and can be used like in your original rand64(): No, binary or does also not guarantee the order in which the different parts are called. You are thinking of logical or. >unsigned __int64 rand64() >{ > return (ui) rand()|(ui)rand()<<15|(ui)rand()<<30 //and so on... >} It is even worse. There is no guarantee, that rand() returns exactly 15 bits (there is a guarantee, that it returns at least 15 bits). So, if an implementation will return (say) 31 bits, you will have in average much more set bits in the 64 bit number, than 0 bits. Not very random ... When using xor, it at least gives something rather random looking back. OTOH for any slightly serious simulation, one would of course never use a system rand(). I also agree with all the other posters, who suggest to use your own PRNG or use a program generated table. Regards, Dieter
This page took 0 seconds to execute
Last modified: Thu, 15 Apr 21 08:11:13 -0700
Current Computer Chess Club Forums at Talkchess. This site by Sean Mintz.