× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



"Weber, Richard" wrote:
> 
> I'm having trouble with the following line of code:
> 
> Sum_x_PJS = SumOProjD * P1_PjSlsDol;
> 
> Where the input variables are:
> 
> P1_PJSLSDOL = 0000000000000.01
> SUMOPROJD = 0000000000000.0005
> ...
> D  Sum_x_PJS      S             20P 7

P1_PjSlsDol is (15,2) and SumOProjD is (17,4).  The natural precision of
their product is 32,6 (add the lengths and the decimals of the
operands).  The compiler has to adjust the length of the actual
temporary used to hold the product down to 31 (v5r2) or 30 (v5r1 and
before)*.  By default it adjusts the number of decimal places to
minimize the possibility of overflow, so it uses a temporary of 31,5. 
Your product is actually .000005, but it gets truncated to .00000 in the
temporary.  Using the (R) extender would fix you up, because then the
temporary would be guaranteed to have at least as many decimals (7) as
your result field.

* The maximum is 63 for v5r3, so no adjustment is necessary, and you
wouldn't have this problem with this particular expression.


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.