[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
hash table types
- To: Jon White <JLW@SU-AI.ARPA>, dcp@TENEX
- Subject: hash table types
- From: David C. Plummer in disguise <DCP@SCRC-QUABBIN.ARPA>
- Date: Mon, 20 May 85 10:12 EDT
- Cc: common-lisp@SU-AI.ARPA
- In-reply-to: The message of 17 May 85 11:41-EDT from Jon White <JLW@SU-AI.ARPA>
Date: 17 May 85 0841 PDT
From: Jon White <JLW@SU-AI.ARPA>
Your list of "external things [I] see need changing" looks quite good
to me. I might add the suggestion that we add a ROT primitive to CL
which is machine independent. The following definition got added to
Interlisp shortly after I went to Xerox:
(ROT x n fieldsize)
"performs a bitwise left-rotation of the integer x, by n places, within
a field of fieldsize bits wide. Bits shifted out of the position selected
by (expt 2 (sub1 fieldsize)) will flow into the 'units' position."
Now, this definition has the advantage that on many machines, there will be
one particular field size for which the implementation of this ROT will be
very efficient (i.e., the one actually supported by a hardware ROT instruction).
And since SXHASH is permitted to be implemetation dependent -- not "address
dependent", but rather varying between one implementation and another -- then
each implementation can use a ROT in it's sxhash with a field size that is
efficient.
I wouldn't object to this, but a refinement is necessary. Is ROT
supposed to give the same answer in all implementations? On two's
complement machines, (rot 1 (1- n) n) where N is the word width is
(probably) MOST-NEGATIVE-FIXNUM. Also, (rot 1 (1- n) n) == (ash -1 (1- n)).
In other words, ROT should imply sign extension (on two's complement
machines).