FreeNOS
lib
libposix
math
sqrt.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2015 Niek Linnenbank
3
*
4
* This program is free software: you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation, either version 3 of the License, or
7
* (at your option) any later version.
8
*
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with this program. If not, see <http://www.gnu.org/licenses/>.
16
*/
17
18
#include "
math.h
"
19
20
u32
sqrt
(
u32
number)
21
{
22
u32
op = number;
23
u32
res = 0;
24
u32
one = 1uL << 30;
// The second-to-top bit is set: use 1u << 14 for uint16_t type; use 1uL<<30 for u32 type
25
26
if
(number == 0)
27
return
0;
28
29
// "one" starts at the highest power of four <= than the argument.
30
while
(one > op)
31
{
32
one >>= 2;
33
}
34
35
while
(one != 0)
36
{
37
if
(op >= res + one)
38
{
39
op = op - (res + one);
40
res = res + 2 * one;
41
}
42
res >>= 1;
43
one >>= 2;
44
}
45
return
res;
46
}
sqrt
u32 sqrt(u32 number)
Compute the square root of a number.
Definition:
sqrt.cpp:20
math.h
u32
unsigned int u32
Unsigned 32-bit number.
Definition:
Types.h:53
Generated by
1.8.17