diff --git a/crypto/src/BouncyCastle.Crypto.csproj b/crypto/src/BouncyCastle.Crypto.csproj
index e45a736fb..22e97639f 100644
--- a/crypto/src/BouncyCastle.Crypto.csproj
+++ b/crypto/src/BouncyCastle.Crypto.csproj
@@ -6,6 +6,7 @@
..\..\BouncyCastle.NET.snk
true
1591
+ 10.0
BouncyCastle.Cryptography
BouncyCastle.NET Cryptography ($(TargetFramework))
@@ -87,6 +88,13 @@
+
+
+
+
+
+
+
@@ -101,6 +109,10 @@
all
runtime; build; native; contentfiles; analyzers; buildtransitive
+
+ all
+ runtime; build; native; contentfiles; analyzers; buildtransitive
+
diff --git a/crypto/src/math/raw/Bits.cs b/crypto/src/math/raw/Bits.cs
index 3efc890d6..8ee30a4a0 100644
--- a/crypto/src/math/raw/Bits.cs
+++ b/crypto/src/math/raw/Bits.cs
@@ -1,7 +1,5 @@
using System.Diagnostics;
-#if NETSTANDARD1_0_OR_GREATER || NETCOREAPP1_0_OR_GREATER
using System.Runtime.CompilerServices;
-#endif
namespace Org.BouncyCastle.Math.Raw
{
@@ -36,9 +34,7 @@ internal static ulong BitPermuteStep(ulong x, ulong m, int s)
#endif
internal static void BitPermuteStep2(ref uint hi, ref uint lo, uint m, int s)
{
-#if NETSTANDARD2_1_OR_GREATER || NETCOREAPP1_1_OR_GREATER
Debug.Assert(!Unsafe.AreSame(ref hi, ref lo) || (m & (m << s)) == 0U);
-#endif
Debug.Assert((m << s) >> s == m);
uint t = ((lo >> s) ^ hi) & m;
@@ -51,9 +47,7 @@ internal static void BitPermuteStep2(ref uint hi, ref uint lo, uint m, int s)
#endif
internal static void BitPermuteStep2(ref ulong hi, ref ulong lo, ulong m, int s)
{
-#if NETSTANDARD2_1_OR_GREATER || NETCOREAPP1_1_OR_GREATER
Debug.Assert(!Unsafe.AreSame(ref hi, ref lo) || (m & (m << s)) == 0UL);
-#endif
Debug.Assert((m << s) >> s == m);
ulong t = ((lo >> s) ^ hi) & m;
diff --git a/crypto/src/math/raw/Interleave.cs b/crypto/src/math/raw/Interleave.cs
index e71f8e394..7b7feb211 100644
--- a/crypto/src/math/raw/Interleave.cs
+++ b/crypto/src/math/raw/Interleave.cs
@@ -66,27 +66,9 @@ internal static ulong Expand32to64(uint x)
internal static void Expand64To128(ulong x, ulong[] z, int zOff)
{
-#if NETCOREAPP3_0_OR_GREATER
- if (Org.BouncyCastle.Runtime.Intrinsics.X86.Bmi2.X64.IsEnabled)
- {
- z[zOff ] = Bmi2.X64.ParallelBitDeposit(x , 0x5555555555555555UL);
- z[zOff + 1] = Bmi2.X64.ParallelBitDeposit(x >> 32, 0x5555555555555555UL);
- return;
- }
-#endif
-
- // "shuffle" low half to even bits and high half to odd bits
- x = Bits.BitPermuteStep(x, 0x00000000FFFF0000UL, 16);
- x = Bits.BitPermuteStep(x, 0x0000FF000000FF00UL, 8);
- x = Bits.BitPermuteStep(x, 0x00F000F000F000F0UL, 4);
- x = Bits.BitPermuteStep(x, 0x0C0C0C0C0C0C0C0CUL, 2);
- x = Bits.BitPermuteStep(x, 0x2222222222222222UL, 1);
-
- z[zOff ] = (x ) & M64;
- z[zOff + 1] = (x >> 1) & M64;
+ Expand64To128(x, z.AsSpan(zOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
internal static void Expand64To128(ulong x, Span z)
{
#if NETCOREAPP3_0_OR_GREATER
@@ -108,19 +90,12 @@ internal static void Expand64To128(ulong x, Span z)
z[0] = (x ) & M64;
z[1] = (x >> 1) & M64;
}
-#endif
internal static void Expand64To128(ulong[] xs, int xsOff, int xsLen, ulong[] zs, int zsOff)
{
- int xsPos = xsLen, zsPos = zsOff + (xsLen << 1);
- while (--xsPos >= 0)
- {
- zsPos -= 2;
- Expand64To128(xs[xsOff + xsPos], zs, zsPos);
- }
+ Expand64To128(xs.AsSpan(xsOff, xsLen), zs.AsSpan(zsOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
internal static void Expand64To128(ReadOnlySpan xs, Span zs)
{
int xsPos = xs.Length, zsPos = xs.Length << 1;
@@ -131,7 +106,6 @@ internal static void Expand64To128(ReadOnlySpan xs, Span zs)
Expand64To128(xs[xsPos], zs[zsPos..]);
}
}
-#endif
internal static ulong Expand64To128Rev(ulong x, out ulong low)
{
diff --git a/crypto/src/math/raw/Mod.cs b/crypto/src/math/raw/Mod.cs
index 9059e479c..f49c20fc4 100644
--- a/crypto/src/math/raw/Mod.cs
+++ b/crypto/src/math/raw/Mod.cs
@@ -22,21 +22,13 @@ internal static class Mod
private static readonly int MaxStackAlloc = Platform.Is64BitProcess ? 4096 : 1024;
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void CheckedModOddInverse(ReadOnlySpan m, ReadOnlySpan x, Span z)
-#else
- public static void CheckedModOddInverse(uint[] m, uint[] x, uint[] z)
-#endif
{
if (0 == ModOddInverse(m, x, z))
throw new ArithmeticException("Inverse does not exist.");
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void CheckedModOddInverseVar(ReadOnlySpan m, ReadOnlySpan x, Span z)
-#else
- public static void CheckedModOddInverseVar(uint[] m, uint[] x, uint[] z)
-#endif
{
if (!ModOddInverseVar(m, x, z))
throw new ArithmeticException("Inverse does not exist.");
@@ -71,11 +63,7 @@ public static ulong Inverse64(ulong d)
return x;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint ModOddInverse(ReadOnlySpan m, ReadOnlySpan x, Span z)
-#else
- public static uint ModOddInverse(uint[] m, uint[] x, uint[] z)
-#endif
{
int len32 = m.Length;
Debug.Assert(len32 > 0);
@@ -85,7 +73,6 @@ public static uint ModOddInverse(uint[] m, uint[] x, uint[] z)
int bits = (len32 << 5) - Integers.NumberOfLeadingZeros((int)m[len32 - 1]);
int len30 = (bits + 29) / 30;
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
int allocSize = len30 * 5;
Span alloc = (allocSize * Integers.NumBytes <= MaxStackAlloc)
? stackalloc int[allocSize]
@@ -97,24 +84,12 @@ public static uint ModOddInverse(uint[] m, uint[] x, uint[] z)
Span F = alloc[..len30]; alloc = alloc[len30..];
Span G = alloc[..len30]; alloc = alloc[len30..];
Span M = alloc[..len30];
-#else
- int[] t = new int[4];
- int[] D = new int[len30];
- int[] E = new int[len30];
- int[] F = new int[len30];
- int[] G = new int[len30];
- int[] M = new int[len30];
-#endif
E[0] = 1;
Encode30(bits, x, G);
Encode30(bits, m, M);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
M.CopyTo(F);
-#else
- Array.Copy(M, 0, F, 0, len30);
-#endif
// We use the "half delta" variant here, with theta == delta - 1/2
int theta = 0;
@@ -139,11 +114,7 @@ public static uint ModOddInverse(uint[] m, uint[] x, uint[] z)
return (uint)(EqualTo(len30, F, 1) & EqualTo(len30, G, 0));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static bool ModOddInverseVar(ReadOnlySpan m, ReadOnlySpan x, Span z)
-#else
- public static bool ModOddInverseVar(uint[] m, uint[] x, uint[] z)
-#endif
{
int len32 = m.Length;
Debug.Assert(len32 > 0);
@@ -156,7 +127,6 @@ public static bool ModOddInverseVar(uint[] m, uint[] x, uint[] z)
int clz = bits - Nat.GetBitLength(len32, x);
Debug.Assert(clz >= 0);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
int allocSize = len30 * 5;
Span alloc = (allocSize * Integers.NumBytes <= MaxStackAlloc)
? stackalloc int[allocSize]
@@ -168,24 +138,12 @@ public static bool ModOddInverseVar(uint[] m, uint[] x, uint[] z)
Span F = alloc[..len30]; alloc = alloc[len30..];
Span G = alloc[..len30]; alloc = alloc[len30..];
Span M = alloc[..len30];
-#else
- int[] t = new int[4];
- int[] D = new int[len30];
- int[] E = new int[len30];
- int[] F = new int[len30];
- int[] G = new int[len30];
- int[] M = new int[len30];
-#endif
E[0] = 1;
Encode30(bits, x, G);
Encode30(bits, m, M);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
M.CopyTo(F);
-#else
- Array.Copy(M, 0, F, 0, len30);
-#endif
// We use the original safegcd here, with eta == 1 - delta
// For shorter x, configure as if low zeros of x had been shifted away by divsteps
@@ -242,11 +200,7 @@ public static bool ModOddInverseVar(uint[] m, uint[] x, uint[] z)
return true;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint ModOddIsCoprime(ReadOnlySpan m, ReadOnlySpan x)
-#else
- public static uint ModOddIsCoprime(uint[] m, uint[] x)
-#endif
{
int len32 = m.Length;
Debug.Assert(len32 > 0);
@@ -256,7 +210,6 @@ public static uint ModOddIsCoprime(uint[] m, uint[] x)
int bits = (len32 << 5) - Integers.NumberOfLeadingZeros((int)m[len32 - 1]);
int len30 = (bits + 29) / 30;
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
int allocSize = len30 * 3;
Span alloc = (allocSize * Integers.NumBytes <= MaxStackAlloc)
? stackalloc int[allocSize]
@@ -266,21 +219,11 @@ public static uint ModOddIsCoprime(uint[] m, uint[] x)
Span F = alloc[..len30]; alloc = alloc[len30..];
Span G = alloc[..len30]; alloc = alloc[len30..];
Span M = alloc[..len30];
-#else
- int[] t = new int[4];
- int[] F = new int[len30];
- int[] G = new int[len30];
- int[] M = new int[len30];
-#endif
Encode30(bits, x, G);
Encode30(bits, m, M);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
M.CopyTo(F);
-#else
- Array.Copy(M, 0, F, 0, len30);
-#endif
// We use the "half delta" variant here, with theta == delta - 1/2
int theta = 0;
@@ -298,11 +241,7 @@ public static uint ModOddIsCoprime(uint[] m, uint[] x)
return (uint)(EqualTo(len30, F, 1) & EqualTo(len30, G, 0));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static bool ModOddIsCoprimeVar(ReadOnlySpan m, ReadOnlySpan x)
-#else
- public static bool ModOddIsCoprimeVar(uint[] m, uint[] x)
-#endif
{
int len32 = m.Length;
Debug.Assert(len32 > 0);
@@ -315,7 +254,6 @@ public static bool ModOddIsCoprimeVar(uint[] m, uint[] x)
int clz = bits - Nat.GetBitLength(len32, x);
Debug.Assert(clz >= 0);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
int allocSize = len30 * 3;
Span alloc = (allocSize * Integers.NumBytes <= MaxStackAlloc)
? stackalloc int[allocSize]
@@ -325,21 +263,11 @@ public static bool ModOddIsCoprimeVar(uint[] m, uint[] x)
Span F = alloc[..len30]; alloc = alloc[len30..];
Span G = alloc[..len30]; alloc = alloc[len30..];
Span M = alloc[..len30];
-#else
- int[] t = new int[4];
- int[] F = new int[len30];
- int[] G = new int[len30];
- int[] M = new int[len30];
-#endif
Encode30(bits, x, G);
Encode30(bits, m, M);
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
M.CopyTo(F);
-#else
- Array.Copy(M, 0, F, 0, len30);
-#endif
// We use the original safegcd here, with eta == 1 - delta
// For shorter x, configure as if low zeros of x had been shifted away by divsteps
@@ -425,11 +353,7 @@ public static void Random(SecureRandom random, ReadOnlySpan p, Span
}
#endif
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int Add30(int len30, Span D, ReadOnlySpan M)
-#else
- private static int Add30(int len30, int[] D, int[] M)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(D.Length >= len30);
@@ -446,11 +370,7 @@ private static int Add30(int len30, int[] D, int[] M)
return c;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void CNegate30(int len30, int cond, Span D)
-#else
- private static void CNegate30(int len30, int cond, int[] D)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(D.Length >= len30);
@@ -465,11 +385,7 @@ private static void CNegate30(int len30, int cond, int[] D)
D[last] = c;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void CNormalize30(int len30, int condNegate, Span D, ReadOnlySpan M)
-#else
- private static void CNormalize30(int len30, int condNegate, int[] D, int[] M)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(D.Length >= len30);
@@ -513,11 +429,7 @@ private static void CNormalize30(int len30, int condNegate, int[] D, int[] M)
}
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void Decode30(int bits, ReadOnlySpan x, Span z)
-#else
- private static void Decode30(int bits, int[] x, uint[] z)
-#endif
{
Debug.Assert(bits > 0);
@@ -539,11 +451,7 @@ private static void Decode30(int bits, int[] x, uint[] z)
}
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int Divsteps30Var(int eta, int f0, int g0, Span t)
-#else
- private static int Divsteps30Var(int eta, int f0, int g0, int[] t)
-#endif
{
int u = 1, v = 0, q = 0, r = 1;
int f = f0, g = g0, m, w, x, y, z;
@@ -606,11 +514,7 @@ private static int Divsteps30Var(int eta, int f0, int g0, int[] t)
return eta;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void Encode30(int bits, ReadOnlySpan x, Span z)
-#else
- private static void Encode30(int bits, uint[] x, int[] z)
-#endif
{
Debug.Assert(bits > 0);
@@ -632,11 +536,7 @@ private static void Encode30(int bits, uint[] x, int[] z)
}
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int EqualTo(int len, ReadOnlySpan x, int y)
-#else
- private static int EqualTo(int len, int[] x, int y)
-#endif
{
int d = x[0] ^ y;
for (int i = 1; i < len; ++i)
@@ -647,11 +547,7 @@ private static int EqualTo(int len, int[] x, int y)
return (d - 1) >> 31;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static bool EqualToVar(int len, ReadOnlySpan x, int y)
-#else
- private static bool EqualToVar(int len, int[] x, int y)
-#endif
{
int d = x[0] ^ y;
if (d != 0)
@@ -676,11 +572,7 @@ private static int GetMaximumHDDivsteps(int bits)
return (int)((150964L * bits + 99243) >> 16);
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int HDDivsteps30(int theta, int f0, int g0, Span t)
-#else
- private static int HDDivsteps30(int theta, int f0, int g0, int[] t)
-#endif
{
int u = 1 << 30, v = 0, q = 0, r = 1 << 30;
int f = f0, g = g0;
@@ -722,11 +614,7 @@ private static int HDDivsteps30(int theta, int f0, int g0, int[] t)
return theta;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int Negate30(int len30, Span D)
-#else
- private static int Negate30(int len30, int[] D)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(D.Length >= len30);
@@ -742,11 +630,7 @@ private static int Negate30(int len30, int[] D)
return c;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static int TrimFG30Var(int len30, Span F, Span G)
-#else
- private static int TrimFG30Var(int len30, int[] F, int[] G)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(F.Length >= len30);
@@ -769,12 +653,8 @@ private static int TrimFG30Var(int len30, int[] F, int[] G)
return len30;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void UpdateDE30(int len30, Span D, Span E, ReadOnlySpan t, int m0Inv32,
ReadOnlySpan M)
-#else
- private static void UpdateDE30(int len30, int[] D, int[] E, int[] t, int m0Inv32, int[] M)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(D.Length >= len30);
@@ -838,11 +718,7 @@ private static void UpdateDE30(int len30, int[] D, int[] E, int[] t, int m0Inv32
E[len30 - 1] = (int)ce;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
private static void UpdateFG30(int len30, Span F, Span G, ReadOnlySpan t)
-#else
- private static void UpdateFG30(int len30, int[] F, int[] G, int[] t)
-#endif
{
Debug.Assert(len30 > 0);
Debug.Assert(F.Length >= len30);
diff --git a/crypto/src/math/raw/Nat.cs b/crypto/src/math/raw/Nat.cs
index 48bf3b2e1..09a4b3be1 100644
--- a/crypto/src/math/raw/Nat.cs
+++ b/crypto/src/math/raw/Nat.cs
@@ -14,19 +14,6 @@ internal static class Nat
{
private const ulong M = 0xFFFFFFFFUL;
- public static uint Add(int len, uint[] x, uint[] y, uint[] z)
- {
- ulong c = 0UL;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[i] + y[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Add(int len, ReadOnlySpan x, ReadOnlySpan y, Span z)
{
ulong c = 0UL;
@@ -38,33 +25,7 @@ public static uint Add(int len, ReadOnlySpan x, ReadOnlySpan y, Span
}
return (uint)c;
}
-#endif
-
- public static uint Add33At(int len, uint x, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- ulong c = (ulong)z[zPos + 0] + x;
- z[zPos + 0] = (uint)c;
- c >>= 32;
- c += (ulong)z[zPos + 1] + 1;
- z[zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zPos + 2);
- }
- public static uint Add33At(int len, uint x, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- ulong c = (ulong)z[zOff + zPos] + x;
- z[zOff + zPos] = (uint)c;
- c >>= 32;
- c += (ulong)z[zOff + zPos + 1] + 1;
- z[zOff + zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, zPos + 2);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Add33At(int len, uint x, Span z, int zPos)
{
Debug.Assert(zPos <= (len - 2));
@@ -76,31 +37,7 @@ public static uint Add33At(int len, uint x, Span z, int zPos)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, zPos + 2);
}
-#endif
-
- public static uint Add33To(int len, uint x, uint[] z)
- {
- ulong c = (ulong)z[0] + x;
- z[0] = (uint)c;
- c >>= 32;
- c += (ulong)z[1] + 1;
- z[1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, 2);
- }
-
- public static uint Add33To(int len, uint x, uint[] z, int zOff)
- {
- ulong c = (ulong)z[zOff + 0] + x;
- z[zOff + 0] = (uint)c;
- c >>= 32;
- c += (ulong)z[zOff + 1] + 1;
- z[zOff + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, 2);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Add33To(int len, uint x, Span z)
{
ulong c = (ulong)z[0] + x;
@@ -111,33 +48,7 @@ public static uint Add33To(int len, uint x, Span z)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, 2);
}
-#endif
-
- public static uint AddBothTo(int len, uint[] x, uint[] y, uint[] z)
- {
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[i] + y[i] + z[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-
- public static uint AddBothTo(int len, uint[] x, int xOff, uint[] y, int yOff, uint[] z, int zOff)
- {
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[xOff + i] + y[yOff + i] + z[zOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddBothTo(int len, ReadOnlySpan x, ReadOnlySpan y, Span z)
{
ulong c = 0;
@@ -149,33 +60,7 @@ public static uint AddBothTo(int len, ReadOnlySpan x, ReadOnlySpan y
}
return (uint)c;
}
-#endif
-
- public static uint AddDWordAt(int len, ulong x, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- ulong c = z[zPos + 0] + (x & M);
- z[zPos + 0] = (uint)c;
- c >>= 32;
- c += z[zPos + 1] + (x >> 32);
- z[zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zPos + 2);
- }
-
- public static uint AddDWordAt(int len, ulong x, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- ulong c = z[zOff + zPos] + (x & M);
- z[zOff + zPos] = (uint)c;
- c >>= 32;
- c += z[zOff + zPos + 1] + (x >> 32);
- z[zOff + zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, zPos + 2);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddDWordAt(int len, ulong x, Span z, int zPos)
{
Debug.Assert(zPos <= (len - 2));
@@ -187,31 +72,7 @@ public static uint AddDWordAt(int len, ulong x, Span z, int zPos)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, zPos + 2);
}
-#endif
-
- public static uint AddDWordTo(int len, ulong x, uint[] z)
- {
- ulong c = (ulong)z[0] + (x & M);
- z[0] = (uint)c;
- c >>= 32;
- c += (ulong)z[1] + (x >> 32);
- z[1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, 2);
- }
-
- public static uint AddDWordTo(int len, ulong x, uint[] z, int zOff)
- {
- ulong c = (ulong)z[zOff + 0] + (x & M);
- z[zOff + 0] = (uint)c;
- c >>= 32;
- c += (ulong)z[zOff + 1] + (x >> 32);
- z[zOff + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, 2);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddDWordTo(int len, ulong x, Span z)
{
ulong c = z[0] + (x & M);
@@ -222,33 +83,12 @@ public static uint AddDWordTo(int len, ulong x, Span z)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, 2);
}
-#endif
-
- public static uint AddTo(int len, uint[] x, uint[] z)
- {
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[i] + z[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
public static uint AddTo(int len, uint[] x, int xOff, uint[] z, int zOff)
{
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[xOff + i] + z[zOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
+ return AddTo(len, x.AsSpan(xOff), z.AsSpan(zOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddTo(int len, ReadOnlySpan x, Span z)
{
ulong c = 0;
@@ -260,21 +100,7 @@ public static uint AddTo(int len, ReadOnlySpan x, Span z)
}
return (uint)c;
}
-#endif
-
- public static uint AddTo(int len, uint[] x, int xOff, uint[] z, int zOff, uint cIn)
- {
- ulong c = cIn;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[xOff + i] + z[zOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddTo(int len, ReadOnlySpan x, Span z, uint cIn)
{
ulong c = cIn;
@@ -286,22 +112,6 @@ public static uint AddTo(int len, ReadOnlySpan x, Span z, uint cIn)
}
return (uint)c;
}
-#endif
-
- public static uint AddToEachOther(int len, uint[] u, int uOff, uint[] v, int vOff)
- {
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)u[uOff + i] + v[vOff + i];
- u[uOff + i] = (uint)c;
- v[vOff + i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddToEachOther(int len, Span u, Span v)
{
ulong c = 0;
@@ -314,27 +124,7 @@ public static uint AddToEachOther(int len, Span u, Span v)
}
return (uint)c;
}
-#endif
-
- public static uint AddWordAt(int len, uint x, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= (len - 1));
- ulong c = (ulong)x + z[zPos];
- z[zPos] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zPos + 1);
- }
-
- public static uint AddWordAt(int len, uint x, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= (len - 1));
- ulong c = (ulong)x + z[zOff + zPos];
- z[zOff + zPos] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, zPos + 1);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddWordAt(int len, uint x, Span z, int zPos)
{
Debug.Assert(zPos <= (len - 1));
@@ -343,25 +133,7 @@ public static uint AddWordAt(int len, uint x, Span z, int zPos)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, zPos + 1);
}
-#endif
-
- public static uint AddWordTo(int len, uint x, uint[] z)
- {
- ulong c = (ulong)x + z[0];
- z[0] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, 1);
- }
-
- public static uint AddWordTo(int len, uint x, uint[] z, int zOff)
- {
- ulong c = (ulong)x + z[zOff];
- z[zOff] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zOff, 1);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint AddWordTo(int len, uint x, Span z)
{
ulong c = (ulong)x + z[0];
@@ -369,23 +141,7 @@ public static uint AddWordTo(int len, uint x, Span z)
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, 1);
}
-#endif
-
- public static uint CAdd(int len, int mask, uint[] x, uint[] y, uint[] z)
- {
- uint MASK = (uint)-(mask & 1);
-
- ulong c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (ulong)x[i] + (y[i] & MASK);
- z[i] = (uint)c;
- c >>= 32;
- }
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint CAdd(int len, int mask, ReadOnlySpan x, ReadOnlySpan y, Span z)
{
uint MASK = (uint)-(mask & 1);
@@ -399,23 +155,7 @@ public static uint CAdd(int len, int mask, ReadOnlySpan x, ReadOnlySpan>= 32;
- }
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint CAddTo(int len, int mask, ReadOnlySpan x, Span z)
{
uint MASK = (uint)-(mask & 1);
@@ -429,31 +169,7 @@ public static uint CAddTo(int len, int mask, ReadOnlySpan x, Span z)
}
return (uint)c;
}
-#endif
-
- public static void CMov(int len, int mask, uint[] x, int xOff, uint[] z, int zOff)
- {
- uint MASK = (uint)-(mask & 1);
-
- for (int i = 0; i < len; ++i)
- {
- uint z_i = z[zOff + i], diff = z_i ^ x[xOff + i];
- z_i ^= diff & MASK;
- z[zOff + i] = z_i;
- }
-
- //uint half = 0x55555555U, rest = half << (-(int)MASK);
-
- //for (int i = 0; i < len; ++i)
- //{
- // uint z_i = z[zOff + i], diff = z_i ^ x[xOff + i];
- // z_i ^= (diff & half);
- // z_i ^= (diff & rest);
- // z[zOff + i] = z_i;
- //}
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void CMov(int len, int mask, ReadOnlySpan x, Span z)
{
uint MASK = (uint)-(mask & 1);
@@ -475,9 +191,8 @@ public static void CMov(int len, int mask, ReadOnlySpan x, Span z)
// z[i] = z_i;
//}
}
-#endif
- public static int Compare(int len, uint[] x, uint[] y)
+ public static int Compare(int len, ReadOnlySpan x, ReadOnlySpan y)
{
for (int i = len - 1; i >= 0; --i)
{
@@ -491,87 +206,24 @@ public static int Compare(int len, uint[] x, uint[] y)
return 0;
}
- public static int Compare(int len, uint[] x, int xOff, uint[] y, int yOff)
+ public static void Copy(int len, uint[] x, int xOff, uint[] z, int zOff)
{
- for (int i = len - 1; i >= 0; --i)
- {
- uint x_i = x[xOff + i];
- uint y_i = y[yOff + i];
- if (x_i < y_i)
- return -1;
- if (x_i > y_i)
- return 1;
- }
- return 0;
+ Array.Copy(x, xOff, z, zOff, len);
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static int Compare(int len, ReadOnlySpan x, ReadOnlySpan y)
+ public static void Copy(int len, ReadOnlySpan x, Span z)
{
- for (int i = len - 1; i >= 0; --i)
- {
- uint x_i = x[i];
- uint y_i = y[i];
- if (x_i < y_i)
- return -1;
- if (x_i > y_i)
- return 1;
- }
- return 0;
+ x[..len].CopyTo(z);
}
-#endif
- public static uint[] Copy(int len, uint[] x)
+ public static void Copy64(int len, ReadOnlySpan x, Span z)
{
- uint[] z = new uint[len];
- Array.Copy(x, 0, z, 0, len);
- return z;
+ x[..len].CopyTo(z);
}
- public static void Copy(int len, uint[] x, uint[] z)
+ public static uint[] Create(int len)
{
- Array.Copy(x, 0, z, 0, len);
- }
-
- public static void Copy(int len, uint[] x, int xOff, uint[] z, int zOff)
- {
- Array.Copy(x, xOff, z, zOff, len);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static void Copy(int len, ReadOnlySpan x, Span z)
- {
- x[..len].CopyTo(z);
- }
-#endif
-
- public static ulong[] Copy64(int len, ulong[] x)
- {
- ulong[] z = new ulong[len];
- Array.Copy(x, 0, z, 0, len);
- return z;
- }
-
- public static void Copy64(int len, ulong[] x, ulong[] z)
- {
- Array.Copy(x, 0, z, 0, len);
- }
-
- public static void Copy64(int len, ulong[] x, int xOff, ulong[] z, int zOff)
- {
- Array.Copy(x, xOff, z, zOff, len);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static void Copy64(int len, ReadOnlySpan x, Span z)
- {
- x[..len].CopyTo(z);
- }
-#endif
-
- public static uint[] Create(int len)
- {
- return new uint[len];
+ return new uint[len];
}
public static ulong[] Create64(int len)
@@ -579,33 +231,6 @@ public static ulong[] Create64(int len)
return new ulong[len];
}
- public static int CSub(int len, int mask, uint[] x, uint[] y, uint[] z)
- {
- long MASK = (uint)-(mask & 1);
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += x[i] - (y[i] & MASK);
- z[i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-
- public static int CSub(int len, int mask, uint[] x, int xOff, uint[] y, int yOff, uint[] z, int zOff)
- {
- long MASK = (uint)-(mask & 1);
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += x[xOff + i] - (y[yOff + i] & MASK);
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int CSub(int len, int mask, ReadOnlySpan x, ReadOnlySpan y, Span z)
{
long MASK = (uint)-(mask & 1);
@@ -618,19 +243,7 @@ public static int CSub(int len, int mask, ReadOnlySpan x, ReadOnlySpan z)
{
for (int i = 0; i < len; ++i)
@@ -640,30 +253,7 @@ public static int Dec(int len, Span z)
}
return -1;
}
-#endif
-
- public static int Dec(int len, uint[] x, uint[] z)
- {
- int i = 0;
- while (i < len)
- {
- uint c = x[i] - 1;
- z[i] = c;
- ++i;
- if (c != uint.MaxValue)
- {
- while (i < len)
- {
- z[i] = x[i];
- ++i;
- }
- return 0;
- }
- }
- return -1;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int Dec(int len, ReadOnlySpan x, Span z)
{
int i = 0;
@@ -684,31 +274,7 @@ public static int Dec(int len, ReadOnlySpan x, Span z)
}
return -1;
}
-#endif
-
- public static int DecAt(int len, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= len);
- for (int i = zPos; i < len; ++i)
- {
- if (--z[i] != uint.MaxValue)
- return 0;
- }
- return -1;
- }
-
- public static int DecAt(int len, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= len);
- for (int i = zPos; i < len; ++i)
- {
- if (--z[zOff + i] != uint.MaxValue)
- return 0;
- }
- return -1;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int DecAt(int len, Span z, int zPos)
{
Debug.Assert(zPos <= len);
@@ -719,19 +285,7 @@ public static int DecAt(int len, Span z, int zPos)
}
return -1;
}
-#endif
-
- public static bool Eq(int len, uint[] x, uint[] y)
- {
- for (int i = len - 1; i >= 0; --i)
- {
- if (x[i] != y[i])
- return false;
- }
- return true;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static bool Eq(int len, ReadOnlySpan x, ReadOnlySpan y)
{
for (int i = len - 1; i >= 0; --i)
@@ -741,13 +295,8 @@ public static bool Eq(int len, ReadOnlySpan x, ReadOnlySpan y)
}
return true;
}
-#endif
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint EqualTo(int len, ReadOnlySpan x, uint y)
-#else
- public static uint EqualTo(int len, uint[] x, uint y)
-#endif
{
uint d = x[0] ^ y;
for (int i = 1; i < len; ++i)
@@ -758,22 +307,7 @@ public static uint EqualTo(int len, uint[] x, uint y)
return (uint)(((int)d - 1) >> 31);
}
- public static uint EqualTo(int len, uint[] x, int xOff, uint y)
- {
- uint d = x[xOff] ^ y;
- for (int i = 1; i < len; ++i)
- {
- d |= x[xOff + i];
- }
- d = (d >> 1) | (d & 1);
- return (uint)(((int)d - 1) >> 31);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint EqualTo(int len, ReadOnlySpan x, ReadOnlySpan y)
-#else
- public static uint EqualTo(int len, uint[] x, uint[] y)
-#endif
{
uint d = 0;
for (int i = 0; i < len; ++i)
@@ -784,23 +318,7 @@ public static uint EqualTo(int len, uint[] x, uint[] y)
return (uint)(((int)d - 1) >> 31);
}
- public static uint EqualTo(int len, uint[] x, int xOff, uint[] y, int yOff)
- {
- uint d = 0;
- for (int i = 0; i < len; ++i)
- {
- d |= x[xOff + i] ^ y[yOff + i];
- }
- d = (d >> 1) | (d & 1);
- return (uint)(((int)d - 1) >> 31);
- }
-
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint EqualToZero(int len, ReadOnlySpan x)
-#else
- public static uint EqualToZero(int len, uint[] x)
-#endif
{
uint d = 0;
for (int i = 0; i < len; ++i)
@@ -811,17 +329,6 @@ public static uint EqualToZero(int len, uint[] x)
return (uint)(((int)d - 1) >> 31);
}
- public static uint EqualToZero(int len, uint[] x, int xOff)
- {
- uint d = 0;
- for (int i = 0; i < len; ++i)
- {
- d |= x[xOff + i];
- }
- d = (d >> 1) | (d & 1);
- return (uint)(((int)d - 1) >> 31);
- }
-
public static uint[] FromBigInteger(int bits, BigInteger x)
{
if (x.SignValue < 0 || x.BitLength > bits)
@@ -901,20 +408,6 @@ public static void FromBigInteger64(int bits, BigInteger x, Span z)
}
#endif
- public static uint GetBit(uint[] x, int bit)
- {
- if (bit == 0)
- return x[0] & 1;
-
- int w = bit >> 5;
- if (w < 0 || w >= x.Length)
- return 0;
-
- int b = bit & 31;
- return (x[w] >> b) & 1;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint GetBit(ReadOnlySpan x, int bit)
{
if (bit == 0)
@@ -927,13 +420,8 @@ public static uint GetBit(ReadOnlySpan x, int bit)
int b = bit & 31;
return (x[w] >> b) & 1;
}
-#endif
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int GetBitLength(int len, ReadOnlySpan x)
-#else
- public static int GetBitLength(int len, uint[] x)
-#endif
{
for (int i = len - 1; i >= 0; --i)
{
@@ -944,17 +432,6 @@ public static int GetBitLength(int len, uint[] x)
return 0;
}
- public static int GetBitLength(int len, uint[] x, int xOff)
- {
- for (int i = len - 1; i >= 0; --i)
- {
- uint x_i = x[xOff + i];
- if (x_i != 0)
- return i * 32 + 32 - Integers.NumberOfLeadingZeros((int)x_i);
- }
- return 0;
- }
-
public static int GetLengthForBits(int bits)
{
if (bits < 1)
@@ -971,20 +448,6 @@ public static int GetLengthForBits64(int bits)
return (int)(((uint)bits + 63) >> 6);
}
- public static bool Gte(int len, uint[] x, uint[] y)
- {
- for (int i = len - 1; i >= 0; --i)
- {
- uint x_i = x[i], y_i = y[i];
- if (x_i < y_i)
- return false;
- if (x_i > y_i)
- return true;
- }
- return true;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static bool Gte(int len, ReadOnlySpan x, ReadOnlySpan y)
{
for (int i = len - 1; i >= 0; --i)
@@ -997,19 +460,7 @@ public static bool Gte(int len, ReadOnlySpan x, ReadOnlySpan y)
}
return true;
}
-#endif
-
- public static uint Inc(int len, uint[] z)
- {
- for (int i = 0; i < len; ++i)
- {
- if (++z[i] != uint.MinValue)
- return 0;
- }
- return 1;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Inc(int len, Span z)
{
for (int i = 0; i < len; ++i)
@@ -1019,30 +470,6 @@ public static uint Inc(int len, Span z)
}
return 1;
}
-#endif
-
- public static uint Inc(int len, uint[] x, uint[] z)
- {
- int i = 0;
- while (i < len)
- {
- uint c = x[i] + 1;
- z[i] = c;
- ++i;
- if (c != 0)
- {
- while (i < len)
- {
- z[i] = x[i];
- ++i;
- }
- return 0;
- }
- }
- return 1;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Inc(int len, ReadOnlySpan x, Span z)
{
int i = 0;
@@ -1063,31 +490,7 @@ public static uint Inc(int len, ReadOnlySpan x, Span z)
}
return 1;
}
-#endif
-
- public static uint IncAt(int len, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= len);
- for (int i = zPos; i < len; ++i)
- {
- if (++z[i] != uint.MinValue)
- return 0;
- }
- return 1;
- }
-
- public static uint IncAt(int len, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= len);
- for (int i = zPos; i < len; ++i)
- {
- if (++z[zOff + i] != uint.MinValue)
- return 0;
- }
- return 1;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint IncAt(int len, Span z, int zPos)
{
Debug.Assert(zPos <= len);
@@ -1098,9 +501,8 @@ public static uint IncAt(int len, Span z, int zPos)
}
return 1;
}
-#endif
- public static bool IsOne(int len, uint[] x)
+ public static bool IsOne(int len, ReadOnlySpan x)
{
if (x[0] != 1)
return false;
@@ -1113,35 +515,6 @@ public static bool IsOne(int len, uint[] x)
return true;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static bool IsOne(int len, ReadOnlySpan x)
- {
- if (x[0] != 1)
- return false;
-
- for (int i = 1; i < len; ++i)
- {
- if (x[i] != 0)
- return false;
- }
- return true;
- }
-#endif
-
- public static bool IsZero(int len, uint[] x)
- {
- if (x[0] != 0)
- return false;
-
- for (int i = 1; i < len; ++i)
- {
- if (x[i] != 0)
- return false;
- }
- return true;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static bool IsZero(int len, ReadOnlySpan x)
{
if (x[0] != 0)
@@ -1154,33 +527,7 @@ public static bool IsZero(int len, ReadOnlySpan x)
}
return true;
}
-#endif
-
- public static int LessThan(int len, uint[] x, uint[] y)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)x[i] - y[i];
- c >>= 32;
- }
- Debug.Assert(c == 0L || c == -1L);
- return (int)c;
- }
-
- public static int LessThan(int len, uint[] x, int xOff, uint[] y, int yOff)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)x[xOff + i] - y[yOff + i];
- c >>= 32;
- }
- Debug.Assert(c == 0L || c == -1L);
- return (int)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int LessThan(int len, ReadOnlySpan x, ReadOnlySpan y)
{
long c = 0;
@@ -1192,29 +539,7 @@ public static int LessThan(int len, ReadOnlySpan x, ReadOnlySpan y)
Debug.Assert(c == 0L || c == -1L);
return (int)c;
}
-#endif
-
- public static void Mul(int len, uint[] x, uint[] y, uint[] zz)
- {
- zz[len] = MulWord(len, x[0], y, zz);
-
- for (int i = 1; i < len; ++i)
- {
- zz[i + len] = MulWordAddTo(len, x[i], y, 0, zz, i);
- }
- }
-
- public static void Mul(int len, uint[] x, int xOff, uint[] y, int yOff, uint[] zz, int zzOff)
- {
- zz[zzOff + len] = MulWord(len, x[xOff], y, yOff, zz, zzOff);
-
- for (int i = 1; i < len; ++i)
- {
- zz[zzOff + i + len] = MulWordAddTo(len, x[xOff + i], y, yOff, zz, zzOff + i);
- }
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void Mul(int len, ReadOnlySpan x, ReadOnlySpan y, Span zz)
{
zz[len] = MulWord(len, x[0], y, zz);
@@ -1224,19 +549,12 @@ public static void Mul(int len, ReadOnlySpan x, ReadOnlySpan y, Span
zz[i + len] = MulWordAddTo(len, x[i], y, zz[i..]);
}
}
-#endif
public static void Mul(uint[] x, int xOff, int xLen, uint[] y, int yOff, int yLen, uint[] zz, int zzOff)
{
- zz[zzOff + yLen] = MulWord(yLen, x[xOff], y, yOff, zz, zzOff);
-
- for (int i = 1; i < xLen; ++i)
- {
- zz[zzOff + i + yLen] = MulWordAddTo(yLen, x[xOff + i], y, yOff, zz, zzOff + i);
- }
+ Mul(x.AsSpan(xOff, xLen), y.AsSpan(yOff, yLen), zz.AsSpan(zzOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void Mul(ReadOnlySpan x, ReadOnlySpan y, Span zz)
{
int xLen = x.Length, yLen = y.Length;
@@ -1247,36 +565,7 @@ public static void Mul(ReadOnlySpan x, ReadOnlySpan y, Span zz
zz[i + yLen] = MulWordAddTo(yLen, x[i], y, zz[i..]);
}
}
-#endif
-
- public static uint MulAddTo(int len, uint[] x, uint[] y, uint[] zz)
- {
- ulong zc = 0;
- for (int i = 0; i < len; ++i)
- {
- zc += MulWordAddTo(len, x[i], y, 0, zz, i) & M;
- zc += zz[i + len] & M;
- zz[i + len] = (uint)zc;
- zc >>= 32;
- }
- return (uint)zc;
- }
-
- public static uint MulAddTo(int len, uint[] x, int xOff, uint[] y, int yOff, uint[] zz, int zzOff)
- {
- ulong zc = 0;
- for (int i = 0; i < len; ++i)
- {
- zc += MulWordAddTo(len, x[xOff + i], y, yOff, zz, zzOff) & M;
- zc += zz[zzOff + len] & M;
- zz[zzOff + len] = (uint)zc;
- zc >>= 32;
- ++zzOff;
- }
- return (uint)zc;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint MulAddTo(int len, ReadOnlySpan x, ReadOnlySpan y, Span zz)
{
ulong zc = 0;
@@ -1289,23 +578,12 @@ public static uint MulAddTo(int len, ReadOnlySpan x, ReadOnlySpan y,
}
return (uint)zc;
}
-#endif
public static uint Mul31BothAdd(int len, uint a, uint[] x, uint b, uint[] y, uint[] z, int zOff)
{
- ulong c = 0, aVal = a, bVal = b;
- int i = 0;
- do
- {
- c += aVal * x[i] + bVal * y[i] + z[zOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- while (++i < len);
- return (uint)c;
+ return Mul31BothAdd(len, a, x, b, y, z.AsSpan(zOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint Mul31BothAdd(int len, uint a, ReadOnlySpan x, uint b, ReadOnlySpan y,
Span z)
{
@@ -1320,37 +598,7 @@ public static uint Mul31BothAdd(int len, uint a, ReadOnlySpan x, uint b, R
while (++i < len);
return (uint)c;
}
-#endif
-
- public static uint MulWord(int len, uint x, uint[] y, uint[] z)
- {
- ulong c = 0, xVal = x;
- int i = 0;
- do
- {
- c += xVal * y[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- while (++i < len);
- return (uint)c;
- }
-
- public static uint MulWord(int len, uint x, uint[] y, int yOff, uint[] z, int zOff)
- {
- ulong c = 0, xVal = x;
- int i = 0;
- do
- {
- c += xVal * y[yOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- while (++i < len);
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint MulWord(int len, uint x, ReadOnlySpan y, Span z)
{
ulong c = 0, xVal = x;
@@ -1364,23 +612,12 @@ public static uint MulWord(int len, uint x, ReadOnlySpan y, Span z)
while (++i < len);
return (uint)c;
}
-#endif
public static uint MulWordAddTo(int len, uint x, uint[] y, int yOff, uint[] z, int zOff)
{
- ulong c = 0, xVal = x;
- int i = 0;
- do
- {
- c += xVal * y[yOff + i] + z[zOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- while (++i < len);
- return (uint)c;
+ return MulWordAddTo(len, x, y.AsSpan(yOff), z.AsSpan(zOff));
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint MulWordAddTo(int len, uint x, ReadOnlySpan y, Span z)
{
ulong c = 0, xVal = x;
@@ -1394,25 +631,7 @@ public static uint MulWordAddTo(int len, uint x, ReadOnlySpan y, Span>= 32;
- c += xVal * (y >> 32) + z[zPos + 1];
- z[zPos + 1] = (uint)c;
- c >>= 32;
- c += z[zPos + 2];
- z[zPos + 2] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : IncAt(len, z, zPos + 3);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint MulWordDwordAddAt(int len, uint x, ulong y, Span z, int zPos)
{
Debug.Assert(zPos <= (len - 3));
@@ -1428,21 +647,7 @@ public static uint MulWordDwordAddAt(int len, uint x, ulong y, Span z, int
c >>= 32;
return c == 0 ? 0 : IncAt(len, z, zPos + 3);
}
-#endif
-
- public static int Negate(int len, uint[] x, uint[] z)
- {
- long c = 0L;
- for (int i = 0; i < len; ++i)
- {
- c -= x[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static int Negate(int len, ReadOnlySpan x, Span z)
{
long c = 0L;
@@ -1454,33 +659,7 @@ public static int Negate(int len, ReadOnlySpan x, Span z)
}
return (int)c;
}
-#endif
-
- public static uint ShiftDownBit(int len, uint[] z, uint c)
- {
- int i = len;
- while (--i >= 0)
- {
- uint next = z[i];
- z[i] = (next >> 1) | (c << 31);
- c = next;
- }
- return c << 31;
- }
-
- public static uint ShiftDownBit(int len, uint[] z, int zOff, uint c)
- {
- int i = len;
- while (--i >= 0)
- {
- uint next = z[zOff + i];
- z[zOff + i] = (next >> 1) | (c << 31);
- c = next;
- }
- return c << 31;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint ShiftDownBit(int len, Span z, uint c)
{
int i = len;
@@ -1492,9 +671,8 @@ public static uint ShiftDownBit(int len, Span z, uint c)
}
return c << 31;
}
-#endif
- public static uint ShiftDownBit(int len, uint[] x, uint c, uint[] z)
+ public static uint ShiftDownBit(int len, ReadOnlySpan x, uint c, Span z)
{
int i = len;
while (--i >= 0)
@@ -1506,302 +684,88 @@ public static uint ShiftDownBit(int len, uint[] x, uint c, uint[] z)
return c << 31;
}
- public static uint ShiftDownBit(int len, uint[] x, int xOff, uint c, uint[] z, int zOff)
+ public static uint ShiftDownBits(int len, Span z, int bits, uint c)
{
+ Debug.Assert(bits > 0 && bits < 32);
int i = len;
while (--i >= 0)
{
- uint next = x[xOff + i];
- z[zOff + i] = (next >> 1) | (c << 31);
+ uint next = z[i];
+ z[i] = (next >> bits) | (c << -bits);
c = next;
}
- return c << 31;
+ return c << -bits;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftDownBit(int len, ReadOnlySpan x, uint c, Span z)
+ public static uint ShiftDownBits(int len, uint[] x, int xOff, int bits, uint c, uint[] z, int zOff)
{
- int i = len;
- while (--i >= 0)
- {
- uint next = x[i];
- z[i] = (next >> 1) | (c << 31);
- c = next;
- }
- return c << 31;
+ return ShiftDownBits(len, x.AsSpan(xOff), bits, c, z.AsSpan(zOff));
}
-#endif
- public static uint ShiftDownBits(int len, uint[] z, int bits, uint c)
+ public static uint ShiftDownBits(int len, ReadOnlySpan x, int bits, uint c, Span z)
{
Debug.Assert(bits > 0 && bits < 32);
int i = len;
while (--i >= 0)
{
- uint next = z[i];
+ uint next = x[i];
z[i] = (next >> bits) | (c << -bits);
c = next;
}
return c << -bits;
}
- public static uint ShiftDownBits(int len, uint[] z, int zOff, int bits, uint c)
+ public static ulong ShiftDownBits64(int len, ulong[] z, int zOff, int bits, ulong c)
{
- Debug.Assert(bits > 0 && bits < 32);
+ Debug.Assert(bits > 0 && bits < 64);
int i = len;
while (--i >= 0)
{
- uint next = z[zOff + i];
+ ulong next = z[zOff + i];
z[zOff + i] = (next >> bits) | (c << -bits);
c = next;
}
return c << -bits;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftDownBits(int len, Span z, int bits, uint c)
+ public static uint ShiftDownWord(int len, Span z, uint c)
{
- Debug.Assert(bits > 0 && bits < 32);
int i = len;
while (--i >= 0)
{
uint next = z[i];
- z[i] = (next >> bits) | (c << -bits);
+ z[i] = c;
c = next;
}
- return c << -bits;
+ return c;
}
-#endif
- public static uint ShiftDownBits(int len, uint[] x, int bits, uint c, uint[] z)
+ public static uint ShiftUpBit(int len, Span z, uint c)
{
- Debug.Assert(bits > 0 && bits < 32);
- int i = len;
- while (--i >= 0)
+ int i = 0, limit4 = len - 4;
+ while (i <= limit4)
{
- uint next = x[i];
- z[i] = (next >> bits) | (c << -bits);
+ uint next0 = z[i + 0];
+ uint next1 = z[i + 1];
+ uint next2 = z[i + 2];
+ uint next3 = z[i + 3];
+ z[i + 0] = (next0 << 1) | (c >> 31);
+ z[i + 1] = (next1 << 1) | (next0 >> 31);
+ z[i + 2] = (next2 << 1) | (next1 >> 31);
+ z[i + 3] = (next3 << 1) | (next2 >> 31);
+ c = next3;
+ i += 4;
+ }
+ while (i < len)
+ {
+ uint next = z[i];
+ z[i] = (next << 1) | (c >> 31);
c = next;
+ ++i;
}
- return c << -bits;
+ return c >> 31;
}
- public static uint ShiftDownBits(int len, uint[] x, int xOff, int bits, uint c, uint[] z, int zOff)
- {
- Debug.Assert(bits > 0 && bits < 32);
- int i = len;
- while (--i >= 0)
- {
- uint next = x[xOff + i];
- z[zOff + i] = (next >> bits) | (c << -bits);
- c = next;
- }
- return c << -bits;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftDownBits(int len, ReadOnlySpan x, int bits, uint c, Span z)
- {
- Debug.Assert(bits > 0 && bits < 32);
- int i = len;
- while (--i >= 0)
- {
- uint next = x[i];
- z[i] = (next >> bits) | (c << -bits);
- c = next;
- }
- return c << -bits;
- }
-#endif
-
- public static ulong ShiftDownBits64(int len, ulong[] z, int zOff, int bits, ulong c)
- {
- Debug.Assert(bits > 0 && bits < 64);
- int i = len;
- while (--i >= 0)
- {
- ulong next = z[zOff + i];
- z[zOff + i] = (next >> bits) | (c << -bits);
- c = next;
- }
- return c << -bits;
- }
-
- public static uint ShiftDownWord(int len, uint[] z, uint c)
- {
- int i = len;
- while (--i >= 0)
- {
- uint next = z[i];
- z[i] = c;
- c = next;
- }
- return c;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftDownWord(int len, Span z, uint c)
- {
- int i = len;
- while (--i >= 0)
- {
- uint next = z[i];
- z[i] = c;
- c = next;
- }
- return c;
- }
-#endif
-
- public static uint ShiftUpBit(int len, uint[] z, uint c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBit(len, z.AsSpan(0, len), c);
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[i + 0];
- uint next1 = z[i + 1];
- uint next2 = z[i + 2];
- uint next3 = z[i + 3];
- z[i + 0] = (next0 << 1) | (c >> 31);
- z[i + 1] = (next1 << 1) | (next0 >> 31);
- z[i + 2] = (next2 << 1) | (next1 >> 31);
- z[i + 3] = (next3 << 1) | (next2 >> 31);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[i];
- z[i] = (next << 1) | (c >> 31);
- c = next;
- ++i;
- }
- return c >> 31;
-#endif
- }
-
- public static uint ShiftUpBit(int len, uint[] z, int zOff, uint c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBit(len, z.AsSpan(zOff, len), c);
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[zOff + i + 0];
- uint next1 = z[zOff + i + 1];
- uint next2 = z[zOff + i + 2];
- uint next3 = z[zOff + i + 3];
- z[zOff + i + 0] = (next0 << 1) | (c >> 31);
- z[zOff + i + 1] = (next1 << 1) | (next0 >> 31);
- z[zOff + i + 2] = (next2 << 1) | (next1 >> 31);
- z[zOff + i + 3] = (next3 << 1) | (next2 >> 31);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[zOff + i];
- z[zOff + i] = (next << 1) | (c >> 31);
- c = next;
- ++i;
- }
- return c >> 31;
-#endif
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftUpBit(int len, Span z, uint c)
- {
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[i + 0];
- uint next1 = z[i + 1];
- uint next2 = z[i + 2];
- uint next3 = z[i + 3];
- z[i + 0] = (next0 << 1) | (c >> 31);
- z[i + 1] = (next1 << 1) | (next0 >> 31);
- z[i + 2] = (next2 << 1) | (next1 >> 31);
- z[i + 3] = (next3 << 1) | (next2 >> 31);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[i];
- z[i] = (next << 1) | (c >> 31);
- c = next;
- ++i;
- }
- return c >> 31;
- }
-#endif
-
- public static uint ShiftUpBit(int len, uint[] x, uint c, uint[] z)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBit(len, x.AsSpan(0, len), c, z.AsSpan(0, len));
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = x[i + 0];
- uint next1 = x[i + 1];
- uint next2 = x[i + 2];
- uint next3 = x[i + 3];
- z[i + 0] = (next0 << 1) | (c >> 31);
- z[i + 1] = (next1 << 1) | (next0 >> 31);
- z[i + 2] = (next2 << 1) | (next1 >> 31);
- z[i + 3] = (next3 << 1) | (next2 >> 31);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = x[i];
- z[i] = (next << 1) | (c >> 31);
- c = next;
- ++i;
- }
- return c >> 31;
-#endif
- }
-
- public static uint ShiftUpBit(int len, uint[] x, int xOff, uint c, uint[] z, int zOff)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBit(len, x.AsSpan(xOff, len), c, z.AsSpan(zOff, len));
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = x[xOff + i + 0];
- uint next1 = x[xOff + i + 1];
- uint next2 = x[xOff + i + 2];
- uint next3 = x[xOff + i + 3];
- z[zOff + i + 0] = (next0 << 1) | (c >> 31);
- z[zOff + i + 1] = (next1 << 1) | (next0 >> 31);
- z[zOff + i + 2] = (next2 << 1) | (next1 >> 31);
- z[zOff + i + 3] = (next3 << 1) | (next2 >> 31);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = x[xOff + i];
- z[zOff + i] = (next << 1) | (c >> 31);
- c = next;
- ++i;
- }
- return c >> 31;
-#endif
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint ShiftUpBit(int len, ReadOnlySpan x, uint c, Span z)
{
int i = 0, limit4 = len - 4;
@@ -1827,69 +791,12 @@ public static uint ShiftUpBit(int len, ReadOnlySpan x, uint c, Span
}
return c >> 31;
}
-#endif
-
- public static ulong ShiftUpBit64(int len, ulong[] x, ulong c, ulong[] z)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBit64(len, x.AsSpan(0, len), c, z.AsSpan(0, len));
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- ulong next0 = x[i + 0];
- ulong next1 = x[i + 1];
- ulong next2 = x[i + 2];
- ulong next3 = x[i + 3];
- z[i + 0] = (next0 << 1) | (c >> 63);
- z[i + 1] = (next1 << 1) | (next0 >> 63);
- z[i + 2] = (next2 << 1) | (next1 >> 63);
- z[i + 3] = (next3 << 1) | (next2 >> 63);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- ulong next = x[i];
- z[i] = (next << 1) | (c >> 63);
- c = next;
- ++i;
- }
- return c >> 63;
-#endif
- }
public static ulong ShiftUpBit64(int len, ulong[] x, int xOff, ulong c, ulong[] z, int zOff)
{
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
return ShiftUpBit64(len, x.AsSpan(xOff, len), c, z.AsSpan(zOff, len));
-#else
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- ulong next0 = x[xOff + i + 0];
- ulong next1 = x[xOff + i + 1];
- ulong next2 = x[xOff + i + 2];
- ulong next3 = x[xOff + i + 3];
- z[zOff + i + 0] = (next0 << 1) | (c >> 63);
- z[zOff + i + 1] = (next1 << 1) | (next0 >> 63);
- z[zOff + i + 2] = (next2 << 1) | (next1 >> 63);
- z[zOff + i + 3] = (next3 << 1) | (next2 >> 63);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- ulong next = x[xOff + i];
- z[zOff + i] = (next << 1) | (c >> 63);
- c = next;
- ++i;
- }
- return c >> 63;
-#endif
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static ulong ShiftUpBit64(int len, ReadOnlySpan x, ulong c, Span z)
{
int i = 0, limit4 = len - 4;
@@ -1912,266 +819,20 @@ public static ulong ShiftUpBit64(int len, ReadOnlySpan x, ulong c, Span> 63);
c = next;
++i;
- }
- return c >> 63;
- }
-#endif
-
- public static uint ShiftUpBits(int len, uint[] z, int bits, uint c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits(len, z.AsSpan(0, len), bits, c);
-#else
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[i + 0];
- uint next1 = z[i + 1];
- uint next2 = z[i + 2];
- uint next3 = z[i + 3];
- z[i + 0] = (next0 << bits) | (c >> -bits);
- z[i + 1] = (next1 << bits) | (next0 >> -bits);
- z[i + 2] = (next2 << bits) | (next1 >> -bits);
- z[i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[i];
- z[i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
- }
-
- public static uint ShiftUpBits(int len, uint[] z, int zOff, int bits, uint c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits(len, z.AsSpan(zOff, len), bits, c);
-#else
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[zOff + i + 0];
- uint next1 = z[zOff + i + 1];
- uint next2 = z[zOff + i + 2];
- uint next3 = z[zOff + i + 3];
- z[zOff + i + 0] = (next0 << bits) | (c >> -bits);
- z[zOff + i + 1] = (next1 << bits) | (next0 >> -bits);
- z[zOff + i + 2] = (next2 << bits) | (next1 >> -bits);
- z[zOff + i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[zOff + i];
- z[zOff + i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftUpBits(int len, Span z, int bits, uint c)
- {
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = z[i + 0];
- uint next1 = z[i + 1];
- uint next2 = z[i + 2];
- uint next3 = z[i + 3];
- z[i + 0] = (next0 << bits) | (c >> -bits);
- z[i + 1] = (next1 << bits) | (next0 >> -bits);
- z[i + 2] = (next2 << bits) | (next1 >> -bits);
- z[i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = z[i];
- z[i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
- }
-#endif
-
- public static uint ShiftUpBits(int len, uint[] x, int bits, uint c, uint[] z)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits(len, x.AsSpan(0, len), bits, c, z.AsSpan(0, len));
-#else
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = x[i + 0];
- uint next1 = x[i + 1];
- uint next2 = x[i + 2];
- uint next3 = x[i + 3];
- z[i + 0] = (next0 << bits) | (c >> -bits);
- z[i + 1] = (next1 << bits) | (next0 >> -bits);
- z[i + 2] = (next2 << bits) | (next1 >> -bits);
- z[i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = x[i];
- z[i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
- }
-
- public static uint ShiftUpBits(int len, uint[] x, int xOff, int bits, uint c, uint[] z, int zOff)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits(len, x.AsSpan(xOff, len), bits, c, z.AsSpan(zOff, len));
-#else
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = x[xOff + i + 0];
- uint next1 = x[xOff + i + 1];
- uint next2 = x[xOff + i + 2];
- uint next3 = x[xOff + i + 3];
- z[zOff + i + 0] = (next0 << bits) | (c >> -bits);
- z[zOff + i + 1] = (next1 << bits) | (next0 >> -bits);
- z[zOff + i + 2] = (next2 << bits) | (next1 >> -bits);
- z[zOff + i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = x[xOff + i];
- z[zOff + i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static uint ShiftUpBits(int len, ReadOnlySpan x, int bits, uint c, Span z)
- {
- Debug.Assert(bits > 0 && bits < 32);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- uint next0 = x[i + 0];
- uint next1 = x[i + 1];
- uint next2 = x[i + 2];
- uint next3 = x[i + 3];
- z[i + 0] = (next0 << bits) | (c >> -bits);
- z[i + 1] = (next1 << bits) | (next0 >> -bits);
- z[i + 2] = (next2 << bits) | (next1 >> -bits);
- z[i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- uint next = x[i];
- z[i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
- }
-#endif
-
- public static ulong ShiftUpBits64(int len, ulong[] z, int bits, ulong c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits64(len, z.AsSpan(0, len), bits, c);
-#else
- Debug.Assert(bits > 0 && bits < 64);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- ulong next0 = z[i + 0];
- ulong next1 = z[i + 1];
- ulong next2 = z[i + 2];
- ulong next3 = z[i + 3];
- z[i + 0] = (next0 << bits) | (c >> -bits);
- z[i + 1] = (next1 << bits) | (next0 >> -bits);
- z[i + 2] = (next2 << bits) | (next1 >> -bits);
- z[i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- ulong next = z[i];
- z[i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
- }
-
- public static ulong ShiftUpBits64(int len, ulong[] z, int zOff, int bits, ulong c)
- {
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits64(len, z.AsSpan(zOff, len), bits, c);
-#else
- Debug.Assert(bits > 0 && bits < 64);
- int i = 0, limit4 = len - 4;
- while (i <= limit4)
- {
- ulong next0 = z[zOff + i + 0];
- ulong next1 = z[zOff + i + 1];
- ulong next2 = z[zOff + i + 2];
- ulong next3 = z[zOff + i + 3];
- z[zOff + i + 0] = (next0 << bits) | (c >> -bits);
- z[zOff + i + 1] = (next1 << bits) | (next0 >> -bits);
- z[zOff + i + 2] = (next2 << bits) | (next1 >> -bits);
- z[zOff + i + 3] = (next3 << bits) | (next2 >> -bits);
- c = next3;
- i += 4;
- }
- while (i < len)
- {
- ulong next = z[zOff + i];
- z[zOff + i] = (next << bits) | (c >> -bits);
- c = next;
- ++i;
- }
- return c >> -bits;
-#endif
+ }
+ return c >> 63;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static ulong ShiftUpBits64(int len, Span z, int bits, ulong c)
+ public static uint ShiftUpBits(int len, Span z, int bits, uint c)
{
- Debug.Assert(bits > 0 && bits < 64);
+ Debug.Assert(bits > 0 && bits < 32);
int i = 0, limit4 = len - 4;
while (i <= limit4)
{
- ulong next0 = z[i + 0];
- ulong next1 = z[i + 1];
- ulong next2 = z[i + 2];
- ulong next3 = z[i + 3];
+ uint next0 = z[i + 0];
+ uint next1 = z[i + 1];
+ uint next2 = z[i + 2];
+ uint next3 = z[i + 3];
z[i + 0] = (next0 << bits) | (c >> -bits);
z[i + 1] = (next1 << bits) | (next0 >> -bits);
z[i + 2] = (next2 << bits) | (next1 >> -bits);
@@ -2181,28 +842,24 @@ public static ulong ShiftUpBits64(int len, Span z, int bits, ulong c)
}
while (i < len)
{
- ulong next = z[i];
+ uint next = z[i];
z[i] = (next << bits) | (c >> -bits);
c = next;
++i;
}
return c >> -bits;
}
-#endif
- public static ulong ShiftUpBits64(int len, ulong[] x, int bits, ulong c, ulong[] z)
+ public static uint ShiftUpBits(int len, ReadOnlySpan x, int bits, uint c, Span z)
{
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits64(len, x.AsSpan(0, len), bits, c, z.AsSpan(0, len));
-#else
- Debug.Assert(bits > 0 && bits < 64);
+ Debug.Assert(bits > 0 && bits < 32);
int i = 0, limit4 = len - 4;
while (i <= limit4)
{
- ulong next0 = x[i + 0];
- ulong next1 = x[i + 1];
- ulong next2 = x[i + 2];
- ulong next3 = x[i + 3];
+ uint next0 = x[i + 0];
+ uint next1 = x[i + 1];
+ uint next2 = x[i + 2];
+ uint next3 = x[i + 3];
z[i + 0] = (next0 << bits) | (c >> -bits);
z[i + 1] = (next1 << bits) | (next0 >> -bits);
z[i + 2] = (next2 << bits) | (next1 >> -bits);
@@ -2212,47 +869,51 @@ public static ulong ShiftUpBits64(int len, ulong[] x, int bits, ulong c, ulong[]
}
while (i < len)
{
- ulong next = x[i];
+ uint next = x[i];
z[i] = (next << bits) | (c >> -bits);
c = next;
++i;
}
return c >> -bits;
-#endif
}
- public static ulong ShiftUpBits64(int len, ulong[] x, int xOff, int bits, ulong c, ulong[] z, int zOff)
+ public static ulong ShiftUpBits64(int len, ulong[] z, int zOff, int bits, ulong c)
+ {
+ return ShiftUpBits64(len, z.AsSpan(zOff, len), bits, c);
+ }
+
+ public static ulong ShiftUpBits64(int len, Span z, int bits, ulong c)
{
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- return ShiftUpBits64(len, x.AsSpan(xOff, len), bits, c, z.AsSpan(zOff, len));
-#else
Debug.Assert(bits > 0 && bits < 64);
int i = 0, limit4 = len - 4;
while (i <= limit4)
{
- ulong next0 = x[xOff + i + 0];
- ulong next1 = x[xOff + i + 1];
- ulong next2 = x[xOff + i + 2];
- ulong next3 = x[xOff + i + 3];
- z[zOff + i + 0] = (next0 << bits) | (c >> -bits);
- z[zOff + i + 1] = (next1 << bits) | (next0 >> -bits);
- z[zOff + i + 2] = (next2 << bits) | (next1 >> -bits);
- z[zOff + i + 3] = (next3 << bits) | (next2 >> -bits);
+ ulong next0 = z[i + 0];
+ ulong next1 = z[i + 1];
+ ulong next2 = z[i + 2];
+ ulong next3 = z[i + 3];
+ z[i + 0] = (next0 << bits) | (c >> -bits);
+ z[i + 1] = (next1 << bits) | (next0 >> -bits);
+ z[i + 2] = (next2 << bits) | (next1 >> -bits);
+ z[i + 3] = (next3 << bits) | (next2 >> -bits);
c = next3;
i += 4;
}
while (i < len)
{
- ulong next = x[xOff + i];
- z[zOff + i] = (next << bits) | (c >> -bits);
+ ulong next = z[i];
+ z[i] = (next << bits) | (c >> -bits);
c = next;
++i;
}
return c >> -bits;
-#endif
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
+ public static ulong ShiftUpBits64(int len, ulong[] x, int xOff, int bits, ulong c, ulong[] z, int zOff)
+ {
+ return ShiftUpBits64(len, x.AsSpan(xOff, len), bits, c, z.AsSpan(zOff, len));
+ }
+
public static ulong ShiftUpBits64(int len, ReadOnlySpan x, int bits, ulong c, Span z)
{
Debug.Assert(bits > 0 && bits < 64);
@@ -2279,71 +940,7 @@ public static ulong ShiftUpBits64(int len, ReadOnlySpan x, int bits, ulon
}
return c >> -bits;
}
-#endif
-
- public static void Square(int len, uint[] x, uint[] zz)
- {
- int extLen = len << 1;
- uint c = 0;
- int j = len, k = extLen;
- do
- {
- ulong xVal = (ulong)x[--j];
- ulong p = xVal * xVal;
- zz[--k] = (c << 31) | (uint)(p >> 33);
- zz[--k] = (uint)(p >> 1);
- c = (uint)p;
- }
- while (j > 0);
-
- ulong d = 0UL;
- int zzPos = 2;
-
- for (int i = 1; i < len; ++i)
- {
- d += SquareWordAddTo(x, i, zz);
- d += zz[zzPos];
- zz[zzPos++] = (uint)d; d >>= 32;
- d += zz[zzPos];
- zz[zzPos++] = (uint)d; d >>= 32;
- }
- Debug.Assert(0UL == d);
-
- ShiftUpBit(extLen, zz, x[0] << 31);
- }
-
- public static void Square(int len, uint[] x, int xOff, uint[] zz, int zzOff)
- {
- int extLen = len << 1;
- uint c = 0;
- int j = len, k = extLen;
- do
- {
- ulong xVal = (ulong)x[xOff + --j];
- ulong p = xVal * xVal;
- zz[zzOff + --k] = (c << 31) | (uint)(p >> 33);
- zz[zzOff + --k] = (uint)(p >> 1);
- c = (uint)p;
- }
- while (j > 0);
-
- ulong d = 0UL;
- int zzPos = zzOff + 2;
-
- for (int i = 1; i < len; ++i)
- {
- d += SquareWordAddTo(x, xOff, i, zz, zzOff);
- d += zz[zzPos];
- zz[zzPos++] = (uint)d; d >>= 32;
- d += zz[zzPos];
- zz[zzPos++] = (uint)d; d >>= 32;
- }
- Debug.Assert(0UL == d);
-
- ShiftUpBit(extLen, zz, zzOff, x[xOff] << 31);
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static void Square(int len, ReadOnlySpan x, Span zz)
{
int extLen = len << 1;
@@ -2374,38 +971,7 @@ public static void Square(int len, ReadOnlySpan x, Span zz)
ShiftUpBit(extLen, zz, x[0] << 31);
}
-#endif
-
- public static uint SquareWordAddTo(uint[] x, int xPos, uint[] z)
- {
- ulong c = 0, xVal = (ulong)x[xPos];
- int i = 0;
- do
- {
- c += xVal * x[i] + z[xPos + i];
- z[xPos + i] = (uint)c;
- c >>= 32;
- }
- while (++i < xPos);
- return (uint)c;
- }
-
- public static uint SquareWordAddTo(uint[] x, int xOff, int xPos, uint[] z, int zOff)
- {
- ulong c = 0, xVal = (ulong)x[xOff + xPos];
- int i = 0;
- do
- {
- c += xVal * (x[xOff + i] & M) + (z[xPos + zOff] & M);
- z[xPos + zOff] = (uint)c;
- c >>= 32;
- ++zOff;
- }
- while (++i < xPos);
- return (uint)c;
- }
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
public static uint SquareWordAddTo(ReadOnlySpan x, int xPos, Span z)
{
ulong c = 0, xVal = x[xPos];
@@ -2417,184 +983,56 @@ public static uint SquareWordAddTo(ReadOnlySpan x, int xPos, Span z)
c >>= 32;
}
while (++i < xPos);
- return (uint)c;
- }
-#endif
-
- public static int Sub(int len, uint[] x, uint[] y, uint[] z)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)x[i] - y[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-
- public static int Sub(int len, uint[] x, int xOff, uint[] y, int yOff, uint[] z, int zOff)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)x[xOff + i] - y[yOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static int Sub(int len, ReadOnlySpan x, ReadOnlySpan y, Span z)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)x[i] - y[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-#endif
-
- public static int Sub33At(int len, uint x, uint[] z, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- long c = (long)z[zPos + 0] - x;
- z[zPos + 0] = (uint)c;
- c >>= 32;
- c += (long)z[zPos + 1] - 1;
- z[zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, zPos + 2);
- }
-
- public static int Sub33At(int len, uint x, uint[] z, int zOff, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- long c = (long)z[zOff + zPos] - x;
- z[zOff + zPos] = (uint)c;
- c >>= 32;
- c += (long)z[zOff + zPos + 1] - 1;
- z[zOff + zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, zOff, zPos + 2);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static int Sub33At(int len, uint x, Span z, int zPos)
- {
- Debug.Assert(zPos <= (len - 2));
- long c = (long)z[zPos + 0] - x;
- z[zPos + 0] = (uint)c;
- c >>= 32;
- c += (long)z[zPos + 1] - 1;
- z[zPos + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, zPos + 2);
- }
-#endif
-
- public static int Sub33From(int len, uint x, uint[] z)
- {
- long c = (long)z[0] - x;
- z[0] = (uint)c;
- c >>= 32;
- c += (long)z[1] - 1;
- z[1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, 2);
- }
-
- public static int Sub33From(int len, uint x, uint[] z, int zOff)
- {
- long c = (long)z[zOff + 0] - x;
- z[zOff + 0] = (uint)c;
- c >>= 32;
- c += (long)z[zOff + 1] - 1;
- z[zOff + 1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, zOff, 2);
- }
-
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static int Sub33From(int len, uint x, Span z)
- {
- long c = (long)z[0] - x;
- z[0] = (uint)c;
- c >>= 32;
- c += (long)z[1] - 1;
- z[1] = (uint)c;
- c >>= 32;
- return c == 0 ? 0 : DecAt(len, z, 2);
- }
-#endif
-
- public static int SubBothFrom(int len, uint[] x, uint[] y, uint[] z)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)z[i] - x[i] - y[i];
- z[i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
- }
-
- public static int SubBothFrom(int len, uint[] x, int xOff, uint[] y, int yOff, uint[] z, int zOff)
- {
- long c = 0;
- for (int i = 0; i < len; ++i)
- {
- c += (long)z[zOff + i] - x[xOff + i] - y[yOff + i];
- z[zOff + i] = (uint)c;
- c >>= 32;
- }
- return (int)c;
+ return (uint)c;
}
-#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
- public static int SubBothFrom(int len, ReadOnlySpan x, ReadOnlySpan y, Span z)
+ public static int Sub(int len, ReadOnlySpan x, ReadOnlySpan