Re: Greatest Common Divisor
| От | Fabien COELHO | 
|---|---|
| Тема | Re: Greatest Common Divisor | 
| Дата | |
| Msg-id | alpine.DEB.2.21.2001041003090.31333@pseudo обсуждение исходный текст | 
| Ответ на | Re: Greatest Common Divisor (Vik Fearing <vik.fearing@2ndquadrant.com>) | 
| Ответы | Re: Greatest Common Divisor | 
| Список | pgsql-hackers | 
Bonjour Vik,
> Here is an updated patch fixing that.
As I said, welcome to arithmetic:-)
Patch v5 applies cleanly.
Doc: I'd consider using an example the result of which is 42 instead of 
21, for obvious geek motivations. Possibly gcd(2142, 462) should be ok.
I got it wrong with my previous comment on gcd(int_min, 0). I'm okay with 
erroring on int_min.
Code comments: gcd(n, 0) = abs(n), not n?
About the code.
Add unlikely() where appropriate.
I'd deal with int_min and 0 at the beginning and then proceed with 
absoluting the values, rather than the dance around a1/arg1, a2/arg2, and 
other arg2 = -arg2, and arg1 = -arg1 anyway in various places, which does 
not make the code that easy to understand.
Pseudo code could be:
    if ((a1 == min && (a2 == min || a2 == 0)) ||
        (a2 == min && a1 == 0))
      error;
    a1 = abs(a1), a2 = abs(a2);
    euclids;
    return;
Note: in the numeric code you abs the value, ISTM consistent to do it as 
well in the other implementations.
Would it make sense that NAN is returned on NUMERIC when the computation 
cannot be performed, eg on non integer values?
Why the positive constraint on LCM(NUMERIC, NUMERIC)? Why not absoluting?
Tests: you can make LCM fail on much smaller values for int2/4/8, you do 
not need to start around max_int.
-- 
Fabien.
		
	В списке pgsql-hackers по дате отправления: