![]() |
Shadowrun: Awakened 29 September 2011 - Build 871
|
00001 /* 00002 Copyright (c) 2009-2010 Christopher A. Taylor. All rights reserved. 00003 00004 Redistribution and use in source and binary forms, with or without 00005 modification, are permitted provided that the following conditions are met: 00006 00007 * Redistributions of source code must retain the above copyright notice, 00008 this list of conditions and the following disclaimer. 00009 * Redistributions in binary form must reproduce the above copyright notice, 00010 this list of conditions and the following disclaimer in the documentation 00011 and/or other materials provided with the distribution. 00012 * Neither the name of LibCat nor the names of its contributors may be used 00013 to endorse or promote products derived from this software without 00014 specific prior written permission. 00015 00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00017 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00018 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00019 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00020 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00021 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00022 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00023 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00024 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00025 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00026 POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00029 /* 00030 Several algorithms based on ideas from the "Handbook of Applied Cryptography" 00031 http://www.cacr.math.uwaterloo.ca/hac/ 00032 00033 Several algorithms based on ideas from the 00034 "Handbook of Elliptic and Hyperelliptic Curve Cryptography" 00035 http://www.hyperelliptic.org/HEHCC/ 00036 */ 00037 00038 #ifndef CAT_BIG_PSEUDO_MERSENNE_HPP 00039 #define CAT_BIG_PSEUDO_MERSENNE_HPP 00040 00041 #include <cat/math/BigRTL.hpp> 00042 00043 namespace cat { 00044 00045 00046 // Performs fast arithmetic modulo 2^bits-C, C = 1 (mod 4) or 3 (mod 8), C < 16384 00047 class BigPseudoMersenne : public BigRTL 00048 { 00049 static const int PM_OVERHEAD = 6; // overhead for MrSquareRoot() 00050 int pm_regs; 00051 00052 protected: 00053 Leg *CachedModulus; 00054 Leg modulus_c; 00055 00056 void CAT_FASTCALL MrReduceProductX(Leg overflow, Leg *inout); 00057 void CAT_FASTCALL MrReduceProduct(const Leg *in_hi, const Leg *in_lo, Leg *out); 00058 00059 public: 00060 BigPseudoMersenne(int regs, int bits, int C); 00061 00062 public: 00063 const Leg *GetModulus() { return CachedModulus; } 00064 void CAT_FASTCALL CopyModulus(Leg *out); 00065 00066 public: 00067 // Result may be one modulus too large, so efficiently correct that 00068 void CAT_FASTCALL MrReduce(Leg *inout); 00069 00070 public: 00071 void CAT_FASTCALL MrAdd(const Leg *in_a, const Leg *in_b, Leg *out); 00072 void CAT_FASTCALL MrAddX(Leg *inout, Leg x); 00073 void CAT_FASTCALL MrSubtract(const Leg *in_a, const Leg *in_b, Leg *out); 00074 void CAT_FASTCALL MrSubtractX(Leg *inout, Leg x); 00075 void CAT_FASTCALL MrNegate(const Leg *in, Leg *out); 00076 00077 public: 00078 void CAT_FASTCALL MrDouble(const Leg *in, Leg *out); 00079 00080 public: 00081 void CAT_FASTCALL MrMultiply(const Leg *in_a, const Leg *in_b, Leg *out); 00082 void CAT_FASTCALL MrMultiplyX(const Leg *in_a, Leg in_b, Leg *out); 00083 void CAT_FASTCALL MrSquare(const Leg *in, Leg *out); 00084 00085 public: 00086 void CAT_FASTCALL MrInvert(const Leg *in, Leg *out); 00087 00088 public: 00089 void CAT_FASTCALL MrSquareRoot(const Leg *in, Leg *out); 00090 }; 00091 00092 00093 } // namespace cat 00094 00095 #endif // CAT_BIG_PSEUDO_MERSENNE_HPP
Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.