From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=ham autolearn_force=no version=3.4.4 X-Google-Language: ENGLISH,ASCII-7-bit X-Google-Thread: 103376,a00006d3c4735d70 X-Google-Attributes: gid103376,public X-Google-ArrivalTime: 2004-02-03 07:24:52 PST Path: archiver1.google.com!news2.google.com!fu-berlin.de!uni-berlin.de!tar-atanamir.cbb-automation.DE!not-for-mail From: Dmitry A. Kazakov Newsgroups: comp.lang.ada Subject: Re: In-Out Parameters for functions Date: Tue, 03 Feb 2004 16:32:53 +0100 Message-ID: References: <1075390647.405841@master.nyc.kbcfp.com> <1075405582.982776@master.nyc.kbcfp.com> <1075482385.142744@master.nyc.kbcfp.com> <1075732402.294581@master.nyc.kbcfp.com> <1075741279.952497@master.nyc.kbcfp.com> <16nu1099ekujjbpe9dqvs3noi9sdcfja6e@4ax.com> <1075817212.745748@master.nyc.kbcfp.com> NNTP-Posting-Host: tar-atanamir.cbb-automation.de (212.79.194.116) Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit X-Trace: news.uni-berlin.de 1075821880 32005761 212.79.194.116 ([77047]) X-Newsreader: Forte Agent 1.8/32.548 Xref: archiver1.google.com comp.lang.ada:5199 Date: 2004-02-03T16:32:53+01:00 List-Id: On Tue, 03 Feb 2004 09:06:52 -0500, Hyman Rosen wrote: >Dmitry A. Kazakov wrote: > > + is commutative > >Mathematics went beyond dogmatic statements like that many years ago. >Notice you didn't say that * is commutative. Very disingenuous. Well, on numbers with overflow + is as non-commutative as * for matrices. Commutativity is not a property of the sign "+". And compilers do not try to optimize user-defined types just because they have "+" defined, I hope. >> You want to fix the circumstances, I prefer to fix the code. > >Once the circumstances are fixed, the code is no more broken >than if the operands were evaluated in sequential statements. Nope, false => true, but this does not make false premise true. >> The results are illegal, if different [*]. > >Can you point to where the ARM says so? I believe you are wrong. I didn't talk about ARM. However, it mentions mathematically correct result. If a+b differs from b+a more than accuracy requirements allow, it is no more mathematically correct. >> When a programmer writes: x:=a+b, the postcondition of that is: >> { x=a+b & x=b+a } > >If I replace + with *, you would find no one agreeing with you if the >operands were matrices, for example. For matrices * is not commutative. We are discussing commutative operators. -- Regards, Dmitry A. Kazakov www.dmitry-kazakov.de