/tmp/bitcoin/src/arith_uint256.cpp
Line | Count | Source |
1 | | // Copyright (c) 2009-2010 Satoshi Nakamoto |
2 | | // Copyright (c) 2009-present The Bitcoin Core developers |
3 | | // Distributed under the MIT software license, see the accompanying |
4 | | // file COPYING or http://www.opensource.org/licenses/mit-license.php. |
5 | | |
6 | | #include <arith_uint256.h> |
7 | | |
8 | | #include <crypto/common.h> |
9 | | #include <uint256.h> |
10 | | #include <util/overflow.h> |
11 | | |
12 | | #include <cassert> |
13 | | |
14 | | template <unsigned int BITS> |
15 | | base_uint<BITS>& base_uint<BITS>::operator<<=(unsigned int shift) |
16 | 4.31M | { |
17 | 4.31M | base_uint<BITS> a(*this); |
18 | 38.8M | for (int i = 0; i < WIDTH; i++) |
19 | 34.4M | pn[i] = 0; |
20 | 4.31M | int k = shift / 32; |
21 | 4.31M | shift = shift % 32; |
22 | 38.8M | for (int i = 0; i < WIDTH; i++) { |
23 | 34.4M | if (i + k + 1 < WIDTH && shift != 0) |
24 | 8.09M | pn[i + k + 1] |= (a.pn[i] >> (32 - shift)); |
25 | 34.4M | if (i + k < WIDTH) |
26 | 12.5M | pn[i + k] |= (a.pn[i] << shift); |
27 | 34.4M | } |
28 | 4.31M | return *this; |
29 | 4.31M | } base_uint<256u>::operator<<=(unsigned int) Line | Count | Source | 16 | 4.31M | { | 17 | 4.31M | base_uint<BITS> a(*this); | 18 | 38.8M | for (int i = 0; i < WIDTH; i++) | 19 | 34.4M | pn[i] = 0; | 20 | 4.31M | int k = shift / 32; | 21 | 4.31M | shift = shift % 32; | 22 | 38.8M | for (int i = 0; i < WIDTH; i++) { | 23 | 34.4M | if (i + k + 1 < WIDTH && shift != 0) | 24 | 8.09M | pn[i + k + 1] |= (a.pn[i] >> (32 - shift)); | 25 | 34.4M | if (i + k < WIDTH) | 26 | 12.5M | pn[i + k] |= (a.pn[i] << shift); | 27 | 34.4M | } | 28 | 4.31M | return *this; | 29 | 4.31M | } |
Unexecuted instantiation: base_uint<6144u>::operator<<=(unsigned int) |
30 | | |
31 | | template <unsigned int BITS> |
32 | | base_uint<BITS>& base_uint<BITS>::operator>>=(unsigned int shift) |
33 | 2.38M | { |
34 | 2.38M | base_uint<BITS> a(*this); |
35 | 21.4M | for (int i = 0; i < WIDTH; i++) |
36 | 19.0M | pn[i] = 0; |
37 | 2.38M | int k = shift / 32; |
38 | 2.38M | shift = shift % 32; |
39 | 21.4M | for (int i = 0; i < WIDTH; i++) { |
40 | 19.0M | if (i - k - 1 >= 0 && shift != 0) |
41 | 14.8M | pn[i - k - 1] |= (a.pn[i] << (32 - shift)); |
42 | 19.0M | if (i - k >= 0) |
43 | 17.2M | pn[i - k] |= (a.pn[i] >> shift); |
44 | 19.0M | } |
45 | 2.38M | return *this; |
46 | 2.38M | } base_uint<256u>::operator>>=(unsigned int) Line | Count | Source | 33 | 2.38M | { | 34 | 2.38M | base_uint<BITS> a(*this); | 35 | 21.4M | for (int i = 0; i < WIDTH; i++) | 36 | 19.0M | pn[i] = 0; | 37 | 2.38M | int k = shift / 32; | 38 | 2.38M | shift = shift % 32; | 39 | 21.4M | for (int i = 0; i < WIDTH; i++) { | 40 | 19.0M | if (i - k - 1 >= 0 && shift != 0) | 41 | 14.8M | pn[i - k - 1] |= (a.pn[i] << (32 - shift)); | 42 | 19.0M | if (i - k >= 0) | 43 | 17.2M | pn[i - k] |= (a.pn[i] >> shift); | 44 | 19.0M | } | 45 | 2.38M | return *this; | 46 | 2.38M | } |
Unexecuted instantiation: base_uint<6144u>::operator>>=(unsigned int) |
47 | | |
48 | | template <unsigned int BITS> |
49 | | base_uint<BITS>& base_uint<BITS>::operator*=(uint32_t b32) |
50 | 12.9k | { |
51 | 12.9k | uint64_t carry = 0; |
52 | 116k | for (int i = 0; i < WIDTH; i++) { |
53 | 103k | uint64_t n = carry + (uint64_t)b32 * pn[i]; |
54 | 103k | pn[i] = n & 0xffffffff; |
55 | 103k | carry = n >> 32; |
56 | 103k | } |
57 | 12.9k | return *this; |
58 | 12.9k | } |
59 | | |
60 | | template <unsigned int BITS> |
61 | | base_uint<BITS>& base_uint<BITS>::operator*=(const base_uint& b) |
62 | 60.3k | { |
63 | 60.3k | base_uint<BITS> a; |
64 | 542k | for (int j = 0; j < WIDTH; j++) { |
65 | 482k | uint64_t carry = 0; |
66 | 2.65M | for (int i = 0; i + j < WIDTH; i++) { |
67 | 2.17M | uint64_t n = carry + a.pn[i + j] + (uint64_t)pn[j] * b.pn[i]; |
68 | 2.17M | a.pn[i + j] = n & 0xffffffff; |
69 | 2.17M | carry = n >> 32; |
70 | 2.17M | } |
71 | 482k | } |
72 | 60.3k | *this = a; |
73 | 60.3k | return *this; |
74 | 60.3k | } base_uint<256u>::operator*=(base_uint<256u> const&) Line | Count | Source | 62 | 60.3k | { | 63 | 60.3k | base_uint<BITS> a; | 64 | 542k | for (int j = 0; j < WIDTH; j++) { | 65 | 482k | uint64_t carry = 0; | 66 | 2.65M | for (int i = 0; i + j < WIDTH; i++) { | 67 | 2.17M | uint64_t n = carry + a.pn[i + j] + (uint64_t)pn[j] * b.pn[i]; | 68 | 2.17M | a.pn[i + j] = n & 0xffffffff; | 69 | 2.17M | carry = n >> 32; | 70 | 2.17M | } | 71 | 482k | } | 72 | 60.3k | *this = a; | 73 | 60.3k | return *this; | 74 | 60.3k | } |
Unexecuted instantiation: base_uint<6144u>::operator*=(base_uint<6144u> const&) |
75 | | |
76 | | template <unsigned int BITS> |
77 | | base_uint<BITS>& base_uint<BITS>::operator/=(const base_uint& b) |
78 | 1.01M | { |
79 | 1.01M | base_uint<BITS> div = b; // make a copy, so we can shift. |
80 | 1.01M | base_uint<BITS> num = *this; // make a copy, so we can subtract. |
81 | 1.01M | *this = 0; // the quotient. |
82 | 1.01M | int num_bits = num.bits(); |
83 | 1.01M | int div_bits = div.bits(); |
84 | 1.01M | if (div_bits == 0) |
85 | 2 | throw uint_error("Division by zero"); |
86 | 1.01M | if (div_bits > num_bits) // the result is certainly 0. |
87 | 1 | return *this; |
88 | 1.01M | int shift = num_bits - div_bits; |
89 | 1.01M | div <<= shift; // shift so that div and num align. |
90 | 3.13M | while (shift >= 0) { |
91 | 2.12M | if (num >= div) { |
92 | 1.02M | num -= div; |
93 | 1.02M | pn[shift / 32] |= (1U << (shift & 31)); // set a bit of the result. |
94 | 1.02M | } |
95 | 2.12M | div >>= 1; // shift back. |
96 | 2.12M | shift--; |
97 | 2.12M | } |
98 | | // num now contains the remainder of the division. |
99 | 1.01M | return *this; |
100 | 1.01M | } base_uint<256u>::operator/=(base_uint<256u> const&) Line | Count | Source | 78 | 1.01M | { | 79 | 1.01M | base_uint<BITS> div = b; // make a copy, so we can shift. | 80 | 1.01M | base_uint<BITS> num = *this; // make a copy, so we can subtract. | 81 | 1.01M | *this = 0; // the quotient. | 82 | 1.01M | int num_bits = num.bits(); | 83 | 1.01M | int div_bits = div.bits(); | 84 | 1.01M | if (div_bits == 0) | 85 | 2 | throw uint_error("Division by zero"); | 86 | 1.01M | if (div_bits > num_bits) // the result is certainly 0. | 87 | 1 | return *this; | 88 | 1.01M | int shift = num_bits - div_bits; | 89 | 1.01M | div <<= shift; // shift so that div and num align. | 90 | 3.13M | while (shift >= 0) { | 91 | 2.12M | if (num >= div) { | 92 | 1.02M | num -= div; | 93 | 1.02M | pn[shift / 32] |= (1U << (shift & 31)); // set a bit of the result. | 94 | 1.02M | } | 95 | 2.12M | div >>= 1; // shift back. | 96 | 2.12M | shift--; | 97 | 2.12M | } | 98 | | // num now contains the remainder of the division. | 99 | 1.01M | return *this; | 100 | 1.01M | } |
Unexecuted instantiation: base_uint<6144u>::operator/=(base_uint<6144u> const&) |
101 | | |
102 | | template <unsigned int BITS> |
103 | | int base_uint<BITS>::CompareTo(const base_uint<BITS>& b) const |
104 | 948M | { |
105 | 7.34G | for (int i = WIDTH - 1; i >= 0; i--) { |
106 | 7.33G | if (pn[i] < b.pn[i]) |
107 | 623M | return -1; |
108 | 6.71G | if (pn[i] > b.pn[i]) |
109 | 319M | return 1; |
110 | 6.71G | } |
111 | 5.38M | return 0; |
112 | 948M | } base_uint<256u>::CompareTo(base_uint<256u> const&) const Line | Count | Source | 104 | 948M | { | 105 | 7.34G | for (int i = WIDTH - 1; i >= 0; i--) { | 106 | 7.33G | if (pn[i] < b.pn[i]) | 107 | 623M | return -1; | 108 | 6.71G | if (pn[i] > b.pn[i]) | 109 | 319M | return 1; | 110 | 6.71G | } | 111 | 5.38M | return 0; | 112 | 948M | } |
Unexecuted instantiation: base_uint<6144u>::CompareTo(base_uint<6144u> const&) const |
113 | | |
114 | | template <unsigned int BITS> |
115 | | bool base_uint<BITS>::EqualTo(uint64_t b) const |
116 | 3.24M | { |
117 | 3.25M | for (int i = WIDTH - 1; i >= 2; i--) { |
118 | 3.25M | if (pn[i]) |
119 | 3.24M | return false; |
120 | 3.25M | } |
121 | 103 | if (pn[1] != (b >> 32)) |
122 | 32 | return false; |
123 | 71 | if (pn[0] != (b & 0xfffffffful)) |
124 | 32 | return false; |
125 | 39 | return true; |
126 | 71 | } |
127 | | |
128 | | template <unsigned int BITS> |
129 | | double base_uint<BITS>::getdouble() const |
130 | 131k | { |
131 | 131k | double ret = 0.0; |
132 | 131k | double fact = 1.0; |
133 | 1.18M | for (int i = 0; i < WIDTH; i++) { |
134 | 1.05M | ret += fact * pn[i]; |
135 | 1.05M | fact *= 4294967296.0; |
136 | 1.05M | } |
137 | 131k | return ret; |
138 | 131k | } |
139 | | |
140 | | template <unsigned int BITS> |
141 | | std::string base_uint<BITS>::GetHex() const |
142 | 22.1k | { |
143 | 22.1k | base_blob<BITS> b; |
144 | 199k | for (int x = 0; x < this->WIDTH; ++x) { |
145 | 177k | WriteLE32(b.begin() + x*4, this->pn[x]); |
146 | 177k | } |
147 | 22.1k | return b.GetHex(); |
148 | 22.1k | } |
149 | | |
150 | | template <unsigned int BITS> |
151 | | std::string base_uint<BITS>::ToString() const |
152 | 37 | { |
153 | 37 | return GetHex(); |
154 | 37 | } |
155 | | |
156 | | template <unsigned int BITS> |
157 | | unsigned int base_uint<BITS>::bits() const |
158 | 2.27M | { |
159 | 2.31M | for (int pos = WIDTH - 1; pos >= 0; pos--) { |
160 | 2.31M | if (pn[pos]) { |
161 | 3.61M | for (int nbits = 31; nbits > 0; nbits--) { |
162 | 3.61M | if (pn[pos] & 1U << nbits) |
163 | 2.27M | return 32 * pos + nbits + 1; |
164 | 3.61M | } |
165 | 3 | return 32 * pos + 1; |
166 | 2.27M | } |
167 | 2.31M | } |
168 | 14 | return 0; |
169 | 2.27M | } base_uint<256u>::bits() const Line | Count | Source | 158 | 2.27M | { | 159 | 2.31M | for (int pos = WIDTH - 1; pos >= 0; pos--) { | 160 | 2.31M | if (pn[pos]) { | 161 | 3.61M | for (int nbits = 31; nbits > 0; nbits--) { | 162 | 3.61M | if (pn[pos] & 1U << nbits) | 163 | 2.27M | return 32 * pos + nbits + 1; | 164 | 3.61M | } | 165 | 3 | return 32 * pos + 1; | 166 | 2.27M | } | 167 | 2.31M | } | 168 | 14 | return 0; | 169 | 2.27M | } |
Unexecuted instantiation: base_uint<6144u>::bits() const |
170 | | |
171 | | // Explicit instantiations for base_uint<256> |
172 | | template class base_uint<256>; |
173 | | |
174 | | // This implementation directly uses shifts instead of going |
175 | | // through an intermediate MPI representation. |
176 | | arith_uint256& arith_uint256::SetCompact(uint32_t nCompact, bool* pfNegative, bool* pfOverflow) |
177 | 3.24M | { |
178 | 3.24M | int nSize = nCompact >> 24; |
179 | 3.24M | uint32_t nWord = nCompact & 0x007fffff; |
180 | 3.24M | if (nSize <= 3) { |
181 | 43 | nWord >>= 8 * (3 - nSize); |
182 | 43 | *this = nWord; |
183 | 3.24M | } else { |
184 | 3.24M | *this = nWord; |
185 | 3.24M | *this <<= 8 * (nSize - 3); |
186 | 3.24M | } |
187 | 3.24M | if (pfNegative) |
188 | 3.24M | *pfNegative = nWord != 0 && (nCompact & 0x00800000) != 0; |
189 | 3.24M | if (pfOverflow) |
190 | 3.24M | *pfOverflow = nWord != 0 && ((nSize > 34) || |
191 | 3.24M | (nWord > 0xff && nSize > 33) || |
192 | 3.24M | (nWord > 0xffff && nSize > 32)); |
193 | 3.24M | return *this; |
194 | 3.24M | } |
195 | | |
196 | | uint32_t arith_uint256::GetCompact(bool fNegative) const |
197 | 253k | { |
198 | 253k | int nSize = CeilDiv(bits(), 8u); |
199 | 253k | uint32_t nCompact = 0; |
200 | 253k | if (nSize <= 3) { |
201 | 17 | nCompact = GetLow64() << 8 * (3 - nSize); |
202 | 253k | } else { |
203 | 253k | arith_uint256 bn = *this >> 8 * (nSize - 3); |
204 | 253k | nCompact = bn.GetLow64(); |
205 | 253k | } |
206 | | // The 0x00800000 bit denotes the sign. |
207 | | // Thus, if it is already set, divide the mantissa by 256 and increase the exponent. |
208 | 253k | if (nCompact & 0x00800000) { |
209 | 2.42k | nCompact >>= 8; |
210 | 2.42k | nSize++; |
211 | 2.42k | } |
212 | 253k | assert((nCompact & ~0x007fffffU) == 0); |
213 | 253k | assert(nSize < 256); |
214 | 253k | nCompact |= nSize << 24; |
215 | 253k | nCompact |= (fNegative && (nCompact & 0x007fffff) ? 0x00800000 : 0); |
216 | 253k | return nCompact; |
217 | 253k | } |
218 | | |
219 | | uint256 ArithToUint256(const arith_uint256 &a) |
220 | 281k | { |
221 | 281k | uint256 b; |
222 | 2.53M | for(int x=0; x<a.WIDTH; ++x) |
223 | 2.24M | WriteLE32(b.begin() + x*4, a.pn[x]); |
224 | 281k | return b; |
225 | 281k | } |
226 | | arith_uint256 UintToArith256(const uint256 &a) |
227 | 35.2M | { |
228 | 35.2M | arith_uint256 b; |
229 | 315M | for(int x=0; x<b.WIDTH; ++x) |
230 | 280M | b.pn[x] = ReadLE32(a.begin() + x*4); |
231 | 35.2M | return b; |
232 | 35.2M | } |
233 | | |
234 | | // Explicit instantiations for base_uint<6144> (used in test/fuzz/muhash.cpp). |
235 | | template base_uint<6144>& base_uint<6144>::operator*=(const base_uint<6144>& b); |
236 | | template base_uint<6144>& base_uint<6144>::operator/=(const base_uint<6144>& b); |