Python update trouble (2.3 to 2.4): x<<y
John Machin
sjmachin at lexicon.net
Sun May 21 17:43:57 EDT 2006
On 22/05/2006 5:22 AM, Gonzalo Monzón wrote:
> Thank you for all the suggestions! :-)
>
> The C routine is almost -changing data type long for word- a copy of the
> function given by a hardware manufacturer, the same code used in their
> firmware to calc the checksum of every piece of data sent or received,
> and that data is somewhat special: it does not contain only plain ascii
> character data (only 0x01 - 0x09 as delimiters) and every data set ends
> with a 0x00 null byte so its fine to calculating checksum until "\x00"
> is reached. And I must get the same crc calculations. That C routine
> (and a very similar PHP one too) are tested for months and work smoothly.
>
> And of course I should use integer not long!!... we aren't anymore in
> the 8 bit computer era... ;-) original code from hardware manufacturer
> use words by the way. And now really don't know why I used long. I
> thought I did that way 'cause see pyrex C generated glue code always
> using PyInt_FromLong so thought would use the same type.
Perhaps we need some amplification of "of course I should use integer
not long" :-)
Is the transmitted checksum (which your routine must create and/or
verify) 2 bytes long or 4 bytes long??? This is the most important
thing; once that is established, then you choose the C and/or Python
types and the mask (0xFFFF or 0xFFFFFFFF) as/if necessary. In that
original specification from the manufacturer, how wide was a "word"?
Note that in most/many C compilers at the moment, "int" and "long"
*both* mean 32 bits, to get 64 bits you need "long long" [or "_int64" or
whatever in realms under the sway of the dark tower], and "short" may
get you 16 bits if you are lucky. In a typical Python environment at the
moment, "int" uses the C "long", and thus typically will be 32 bits.
Python "long" is a variable-length data type.
Also note that even if the "checksum" is 32 bits wide, the high-order 16
bits are not verifiably useful, so you could use a [faster] 16-bit
version when receiving.
>
> I changed the C function to use integer, and it is performing a little
> bit slowly than using longs (best with long: 0.614us, best with int:
> 0.629us), that is maybe as I said due pyrex glueing always the return
> values with PyObject* PyInt_FromLong for all kind of short int to long
> data types? Anyway both results are fine, and the timming gap is
> insignificant (int: 1580403 loops -> 0.973 secs, long: 1601902 loops ->
> 1.01 secs) as i usually never have to call more than 100,000 times when
> loading a full file data backup.
I'm somewhat puzzled: Do you have the facility to cross-compile C to run
on the Pocket PC? If NO, why do you continue to mention fast versions
coded in C and glued with Pyrex? If YES, why did you include a Python
version in your initial question?
Cheers,
John
More information about the Python-list
mailing list