Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations gkittelson on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Modulo Arithmetic in VB6?

Status
Not open for further replies.

victoryhighway2

Programmer
Jul 18, 2005
42
US
Hello,
I'm working on an application that requires modulo-32 bit arithmetic to compute a value in an equation similar to the following:

x = ((a * b) / c) + d

This looks simple on the surface, but even if I define X as a long, it will always overflow (because VB will try to perform standard arithmetic operations and can't store the result in a 32-bit signed integer.)

How can I get VB to perform this computation using modulo-32 bit operations? I've done numerous searches on Google and can't find any information.

Thanks in advance,
Geoffrey
 
Hi dilettante,
You may be correct in calling it modulo 32 arithmetic. However, I'm just following a spec that plainly states:
All computations are performed on unsigned 32-bit variables using modulo-32-bit operations.

Regards,
Geoffrey
 
Nope. Mod 32 is something entirely different. I suspect it's a misstatement or typo.

Sounds as if they want unsigned 32-bit arithmetic done though. Is this class work? Might try another teacher. ;-)
 
Hi Dilettante,
No, this isn't for a class. This is for my work.
I'll just talk to the engineer who wrote up the spec when he comes in. Maybe he'll be able to give me some advice.

Regards,
Geoffrey
 
>>but even if I define X as a long, it will always overflow (because VB will try to perform standard arithmetic operations and can't store the result in a 32-bit signed integer.)

I guess you should have all other variables in the expression to be long, too.
 
Hello all,
I've gotten some clarification on this. Apparently, this calculation is to be performed as modular arithmetic operating on 32 bit unsigned integers. The result value is expected to overflow.

Obviously, since VB doesn't support any unsigned integer data types larger than 1 byte, we will need to use doubles to store our results. However, the bounds of a double are not the same as a UINT32, we'll need to do some kind of work around to get the overflow to occur at the correct point.

I've looked at a code sample from the other engineer. It is extremely straight-forward and it looks like his C compiler is handling the overflow by just allowing it to happen (ie. performing the modular arithmetic automatically) whereas VB throws an exception.

Regards,
Geoffrey
 
Indeed. VB doesn't natively handle unsigned maths particularly well. It is perhaps the wrong language to choose if you are doing a lot of unsigned arithmetic.
 
Google on the terms "long integer modular arithmetic vb" and you'll get more results than you can use.
 
>it looks like his C compiler is handling the overflow by just allowing it to happen ... whereas VB throws an exception

I don't know your exact requirements, but you can also instruct VB to ignore overflow by setting advanced compiler options.

Start a new project, and try running the following code.
___
[tt]
Private Sub Form_Load()
Dim L As Long
L = 12345678
L = L * L
MsgBox L
Unload Me
End Sub[/tt]
___

The assignment L = L * L throws an overflow error in IDE because the result is obviously much too larger than the capacity of a VB Long.

Now go to advanced compiler options in project properties and select the option "Remove Integer Overflow Checks".

Compile an EXE and see the results in compiled version. The program runs without an error displaying 260846532. Reason for this result is this:

12345678 * 12345678 = 152415765279684 = 0x8A9F0F8C33C4

Since the overflow check is disabled, VB ignores the fact that an overflow has occurred in multiplication and retains the value in the lower 4 bytes, i.e. 0x0F8C33C4 = 260846532, which is reported by the message box.
 
Which is great if it's what's intended, and very very bad when it isn't. :)
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top