Shadowrun: Awakened 29 September 2011 - Build 871
BigPseudoMersenne.hpp
Go to the documentation of this file.
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.

GNU Lesser General Public License 3 Sourceforge.net