MISRA work on maths.ino
This commit is contained in:
parent
7fb7d83f5f
commit
8db54c9c22
|
@ -24,35 +24,37 @@ Ref: http://www.hackersdelight.org/divcMore.pdf
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//Unsigned divide by 10
|
//Unsigned divide by 10
|
||||||
unsigned int divu10(unsigned int n) {
|
unsigned int divu10(unsigned int n)
|
||||||
|
{
|
||||||
unsigned long q, r;
|
unsigned long q, r;
|
||||||
q = (n >> 1) + (n >> 2);
|
q = (n >> 1) + (n >> 2);
|
||||||
q = q + (q >> 4);
|
q = q + (q >> 4);
|
||||||
q = q + (q >> 8);
|
q = q + (q >> 8);
|
||||||
q = q + (q >> 16);
|
q = q + (q >> 16);
|
||||||
q = q >> 3;
|
q = q >> 3;
|
||||||
r = n - q*10;
|
r = n - (q * 10);
|
||||||
return q + ((r + 6) >> 4);
|
return q + ((r + 6) >> 4);
|
||||||
// return q + (r > 9);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Signed divide by 10
|
//Signed divide by 10
|
||||||
int divs10(long n) {
|
int divs10(long n)
|
||||||
long q, r;
|
{
|
||||||
n = n + (n>>31 & 9);
|
long q, r, p;
|
||||||
q = (n >> 1) + (n >> 2);
|
p = n + (n>>31 & 9);
|
||||||
|
q = (p >> 1) + (p >> 2);
|
||||||
q = q + (q >> 4);
|
q = q + (q >> 4);
|
||||||
q = q + (q >> 8);
|
q = q + (q >> 8);
|
||||||
q = q + (q >> 16);
|
q = q + (q >> 16);
|
||||||
q = q >> 3;
|
q = q >> 3;
|
||||||
r = n - q*10;
|
r = p - (q * 10);
|
||||||
return q + ((r + 6) >> 4);
|
return q + ((r + 6) >> 4);
|
||||||
// return q + (r > 9);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Signed divide by 100
|
//Signed divide by 100
|
||||||
int divs100(long n) {
|
int divs100(long n)
|
||||||
|
{
|
||||||
return (n / 100); // Amazingly, gcc is producing a better /divide by 100 function than this
|
return (n / 100); // Amazingly, gcc is producing a better /divide by 100 function than this
|
||||||
|
/*
|
||||||
long q, r;
|
long q, r;
|
||||||
n = n + (n>>31 & 99);
|
n = n + (n>>31 & 99);
|
||||||
q = (n >> 1) + (n >> 3) + (n >> 6) - (n >> 10) +
|
q = (n >> 1) + (n >> 3) + (n >> 6) - (n >> 10) +
|
||||||
|
@ -61,20 +63,20 @@ int divs100(long n) {
|
||||||
q = q >> 6;
|
q = q >> 6;
|
||||||
r = n - q*100;
|
r = n - q*100;
|
||||||
return q + ((r + 28) >> 7);
|
return q + ((r + 28) >> 7);
|
||||||
// return q + (r > 99);
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
//Unsigned divide by 100
|
//Unsigned divide by 100
|
||||||
unsigned long divu100(unsigned long n) {
|
unsigned long divu100(unsigned long n)
|
||||||
//return (n / 100); // No difference with this on/off
|
{
|
||||||
|
//return (n / 100);
|
||||||
unsigned long q, r;
|
unsigned long q, r;
|
||||||
q = (n >> 1) + (n >> 3) + (n >> 6) - (n >> 10) +
|
q = (n >> 1) + (n >> 3) + (n >> 6) - (n >> 10) +
|
||||||
(n >> 12) + (n >> 13) - (n >> 16);
|
(n >> 12) + (n >> 13) - (n >> 16);
|
||||||
q = q + (q >> 20);
|
q = q + (q >> 20);
|
||||||
q = q >> 6;
|
q = q >> 6;
|
||||||
r = n - q*100;
|
r = n - (q * 100);
|
||||||
return q + ((r + 28) >> 7);
|
return q + ((r + 28) >> 7);
|
||||||
// return q + (r > 99);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Return x percent of y
|
//Return x percent of y
|
||||||
|
@ -91,7 +93,8 @@ unsigned long percentage(byte x, unsigned long y)
|
||||||
inline long powint(int factor, unsigned int exponent)
|
inline long powint(int factor, unsigned int exponent)
|
||||||
{
|
{
|
||||||
long product = 1;
|
long product = 1;
|
||||||
while (exponent--)
|
unsigned int counter = exponent;
|
||||||
|
while ( (counter--) > 0)
|
||||||
product *= factor;
|
product *= factor;
|
||||||
return product;
|
return product;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue