should round numbers before truncating to integer

This commit is contained in:
David Rose 2003-04-10 01:03:19 +00:00
parent 8df8b72c49
commit fb284b821f

View File

@ -3,21 +3,21 @@
# Import the type numbers
import DCSubatomicType
if subatomicType == DCSubatomicType.STInt8:
self.addInt8(int(arg*divisor))
self.addInt8(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STInt16:
self.addInt16(int(arg*divisor))
self.addInt16(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STInt32:
self.addInt32(int(arg*divisor))
self.addInt32(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STInt64:
self.addInt64(int(arg*divisor))
self.addInt64(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint8:
self.addUint8(int(arg*divisor))
self.addUint8(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint16:
self.addUint16(int(arg*divisor))
self.addUint16(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint32:
self.addUint32(int(arg*divisor))
self.addUint32(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint64:
self.addUint64(int(arg*divisor))
self.addUint64(int(arg*divisor+0.5))
elif subatomicType == DCSubatomicType.STFloat64:
self.addFloat64(arg)
elif subatomicType == DCSubatomicType.STString:
@ -27,32 +27,32 @@
elif subatomicType == DCSubatomicType.STInt8array:
self.addUint16(len(arg))
for i in arg:
self.addInt8(int(i*divisor))
self.addInt8(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STInt16array:
self.addUint16(len(arg) << 1)
for i in arg:
self.addInt16(int(i*divisor))
self.addInt16(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STInt32array:
self.addUint16(len(arg) << 2)
for i in arg:
self.addInt32(int(i*divisor))
self.addInt32(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint8array:
self.addUint16(len(arg))
for i in arg:
self.addUint8(int(i*divisor))
self.addUint8(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint16array:
self.addUint16(len(arg) << 1)
for i in arg:
self.addUint16(int(i*divisor))
self.addUint16(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint32array:
self.addUint16(len(arg) << 2)
for i in arg:
self.addUint32(int(i*divisor))
self.addUint32(int(i*divisor+0.5))
elif subatomicType == DCSubatomicType.STUint32uint8array:
self.addUint16(len(arg) * 5)
for i in arg:
self.addUint32(int(i[0]*divisor))
self.addUint8(int(i[1]*divisor))
self.addUint32(int(i[0]*divisor+0.5))
self.addUint8(int(i[1]*divisor+0.5))
else:
raise Exception("Error: No such type as: " + str(subatomicType))
return None