miracl
所属分类:编译器/解释器
开发工具:Visual C++
文件大小:1674KB
下载次数:16
上传日期:2009-12-12 14:38:08
上 传 者:
pritamgshah
说明: ECC Implmentation . The programme works without any problem on compiler Dev C++ available at bloodshed.
文件列表:
miracl (0, 2004-10-04)
miracl\amd64.txt (4939, 2008-05-26)
miracl\arm.txt (7116, 2008-05-26)
miracl\borland.txt (1474, 2001-11-06)
miracl\config.c (35251, 2009-03-09)
miracl\cygwin.txt (460, 2008-01-07)
miracl\doubig.txt (2590, 2008-08-12)
miracl\double.txt (2251, 2004-06-21)
miracl\edwards.txt (1371, 2009-03-25)
miracl\first.txt (2566, 2009-03-24)
miracl\float.txt (1936, 2003-12-18)
miracl\itanium.txt (2822, 2008-05-26)
miracl\kcmcomba.txt (5043, 2007-09-21)
miracl\linux.txt (1536, 2008-10-20)
miracl\mac.txt (127, 2007-09-17)
miracl\makemcs.txt (12302, 2008-07-02)
miracl\manual.doc (839168, 2007-06-08)
miracl\mex.c (30055, 2008-08-25)
miracl\msvisual.txt (5467, 2004-11-02)
miracl\powerpc.txt (2216, 2008-05-26)
miracl\problems.txt (4601, 2007-09-19)
miracl\smartmip.txt (2788, 2006-02-09)
miracl\sparc.txt (5712, 2008-05-26)
miracl\sse2.txt (2845, 2004-09-27)
miracl\st22.txt (2542, 2008-02-06)
miracl\update.txt (12789, 2009-03-24)
miracl\vc2005.txt (2653, 2008-05-26)
miracl\win64.txt (708, 2009-03-25)
miracl\exe (0, 2004-10-04)
miracl\exe\deciph.exe (53248, 2002-08-28)
miracl\exe\enciph.exe (49152, 2002-08-28)
miracl\exe\fact.exe (49152, 2008-01-08)
miracl\exe\private.key (260, 2007-02-07)
miracl\exe\public.key (258, 2007-02-07)
miracl\free (0, 2004-10-04)
miracl\free\factor.exe (98304, 2008-10-14)
miracl\free\ratcalc.exe (109966, 2003-12-22)
miracl\free\read.txt (239, 2003-11-13)
miracl\include (0, 2004-10-04)
... ...
IMPORTANT! See UPDATE.DOC for latest changes
The distribution media contains the following files
README.TXT - This file
FIRST.TXT - Read this next
MSVISUAL.TXT - Microsoft Visual C++ V6.0 quick-start instructions
VC2005.TXT - Microsoft Visual C++ V8.0 quick-start instructions
BORLAND.TXT - Borland C quick-start instructions
ARM.TXT - ARM processor advice
SPARC.TXT - SPARC processor advise
ITANIUM.TXT - ITANIUM processor advise
WIN***.TXT - ***-bit Windows advise
AMD***.TXT - AMD*** processor advise
SSE2.TXT - SSE2 extensions advise
POWERPC.TXT - POWERPC processor advice
LINUX.TXT - Some advice for Linux users
CYGWIN.TXT - How to install MIRACL using Cygwin
MANUAL.DOC - The Manual - read it!
PROBLEMS.TXT - Known problems with MIRACL
UPDATE.TXT - MIRACL Update History
KCMCOMBA.TXT - Using super-fast techniques
MAKEMCS.TXT - How to create your own .mcs file
DOUBLE.TXT - Using a double underlying type
FLOAT.TXT - Multiprecision floating-point
DOUBIG.TXT - How to allow "Double Precision" big types
EDWARDS.TXT - How to use Edwards curves for Elliptic curve crypto over Fp
CONFIG.C - Program to automatically generate a mirdef.h file
MEX.C - Program to insert fast macros into mrcomba.c/mrkcm.c
In the subdirectory SOURCE
MRMULDV.ANY - Contains assembly language versions of muldiv,muldvm,
muldvd and muldvd2
MRMULDV.S - Version of the above for Linux i386 GCC
MRMULDV.S*** - Version of the above for Linux x86_*** GCC
MRMULDV.W*** - Version of the above for Windows x86-*** Visual Studio
MRMULDV.C - Version of the above for Win32
MRMULDV.CCC - Standard C version
MRMULDV.GPP - Version of the above for DJGPP GCC
MR*.C - MIRACL library source files
MRCOMBA.TPL - Template file for fast Comba method
MRKCM.TPL - Template file for fast KCM method
C.MCS - C macros for use with above
C1.MCS - Alternate C macros
MS86.MCS - Microsoft/Borland 80*86/Pentium macros for use with above
GCC386.MCS - GCC compiler compatible Pentium macros
ARM.MCS - ARM processor macros
GCCARM.MCS - GCC compatable version of the above
AVR.MCS - Atmel Atmega128 processor macros
MSP430.MCS - TI msp430 support (uses hardware multiplier)
GCCMSP430.MCS - GCC compatable version of the above
SPARC32.MCS - 32-bit Sparc processor macros
SPARC***.MCS - ***-bit Sparc processor macros
ITANIUM.MCS - ***-bit Itanium processor macros
WIN***.MCS - ***-bit x86-*** Windows macros
AMD***.MCS - ***-bit AMD*** procesor macros
SSE2.MCS - Pentium 4 SSE2 instructions for Microsoft compiler
GCCPPC.MCS - PowerPC processor macros
GCCSSE2.MCS - Pentium 4 SSE2 instructions for GCC compiler
BMARK.C - Benchmark program for Public Key methods
IMRATIO.C - Benchmark program. Calculates S/M, I/M and J/M ratios over GF(p)
IMRATIO2.C - Benchmark program. Calculates S/M and I/M ratios over GF(2^m)
MERSENNE.C - Mersenne primes
FACT.C - Factorials
BRUTE.C - Brute-force factorisation
BRENT.C - Brent-pollard factoring
BRENT_MT.C - Example of generic Multi-Threading
HAIL.C - Hailstone numbers
PALIN.C - Palindromic numbers
GENKEY.C - Generate Public and Private keys
ENCODE.C - Encode using RSA method
DECODE.C - Decode using RSA method
ENCIPH.C - Encipher using Probabalistic method
DECIPH.C - Decipher using Probabalistic method
PK-DEMO.C - Demo of RSA/El Gamal/Diffie-Hellman/Elliptic Curve...
IDENTITY.C - ID based key exchange program
HILBERT.C - Solve special system of equations
SAMPLE.C - Example of Flash arithmetic
ROOTS.C - Square roots
POLLARD.C - Pollard's factoring method
WILLIAMS.C - William's factoring method
LENSTRA.C - Lenstra's factoring method
QSIEVE.C - The Quadratic Sieve
RATCALC.C - Rational Scientific Calculator
FACTOR.C - Factoring Program source
KANGAROO.C - Pollards Lambda method for discrete logs
INDEX.C - Pollards rho method for discrete logs
GENPRIME.C - Generates prime for above
LIMLEE.C - Lim-Lee prime generation
DSSETUP.C - Digital Signature Standard setup program
DSSGEN.C - Digital Signature Standard key generator program
DSSIGN.C - Digital Signature Standard signature program
DSSVER.C - Digital Signature Standard verification program
ECDH2M.C - Example EC Diffie-Hellman program for constrained environments (static stack-only)
ECDH2M16.C - 16-bit version of the above
ECDH2M8.c - 8-bit version of the above
ROMAKER2.C - Program to automatically generate ROMS for above programs
ECDHP.C - ditto, over GF(p) - 32-bit
ECDHP32.C - ditto, over GF(p) - Nice ARM example (32-bits)
ECDHP8.C - ditto, over GF(p), 8-bit version
ECDHP16.C - ditto, over GF(p), 16-bit version
ROMAKER.C - Program to automatically generate ROMS for above programs
ECSGEN.C - DSS (Elliptic Curve GF(p) variation) key generator program
ECSIGN.C - DSS (Elliptic Curve GF(p) variation) signature program
ECSVER.C - DSS (Elliptic Curve GF(p) variation) verification program
ECSGEN_S.C - DSS (Elliptic Curve GF(p) variation) key generator program (static stack-only version)
ECSIGN_S.C - DSS (Elliptic Curve GF(p) variation) signature program (static stack-only version)
ECSVER_S.C - DSS (Elliptic Curve GF(p) variation) verification program (static stack-only version)
ECSGEN2.C - DSS (Elliptic Curve GF(2^m) variation) key generator program
ECSIGN2.C - DSS (Elliptic Curve GF(2^m) variation) signature program
ECSVER2.C - DSS (Elliptic Curve GF(2^m) variation) verification program
ECSGEN2S.C - DSS (Elliptic Curve GF(2^m) variation) key generator program (static stack-only version)
ECSIGN2S.C - DSS (Elliptic Curve GF(2^m) variation) signature program (static stack-only version)
ECSVER2S.C - DSS (Elliptic Curve GF(2^m) variation) verification program (static stack-only version)
BRICK.C - Brickell's method for fast exponentiation
EBRICK.C - Same for GF(p) Elliptic Curves
EBRICK2.C - Same for GF(2^m) Elliptic Curves
BIG.CPP - Big function implementations
ZZN.CPP - ZZn function implementations
ECN.CPP - ECn function implementations
EC2.CPP - EC2 function implementations
GF2M.CPP - GF(2^m) function implementations
CRT.CPP - Crt function implementations
FLASH.CPP - Flash function implementations
FLOATING.CPP - Float function implementations
PAL_ENC.CPP - Paillier Homomorphic Encryption Program
PAL_DEC.CPP - Paillier Homomorphic Decryption Program
THREADWN.CPP - Example of Windows Multi-threading
THREADUX.CPP - Example of Unix Multi-Threading
THREADMP.CPP - Example of openMP Multi-Threading
FINDBASE.CPP - Find irreducible polynomial for GF(2^m) programs
IRP.CPP - Generates code to implement irreducible polynomial
NEWBASIS.CPP - Converts from one irreducible polynomial representation to another
FACT.CPP - Example C++ source (uses BIG.H)
HAIL.CPP - " "
PALIN.CPP - " "
BRUTE.CPP - " "
MERSENNE.CPP - " "
QSIEVE.CPP - " "
GENKEY.CPP - " "
ENCODE.CPP - " "
DECODE.CPP - " "
ENCIPH.CPP - " "
DECIPH.CPP - " "
PK-DEMO.CPP - " "
LIMLEE.CPP - " "
DSSETUP.CPP - " "
DSSGEN.CPP - " "
DSSIGN.CPP - " "
DSSVER.CPP - " "
KANGAROO.CPP - " "
INDEX.CPP - " "
GENPRIME.CPP - " "
BRICK.CPP - " "
EBRICK.CPP - Example C++ source (uses ECN.H)
ECSGEN.CPP - " "
ECSIGN.CPP - " "
ECSVER.CPP - " "
EBRICK2.CPP - Example C++ source (uses EC2.H)
ECSGEN2.CPP - " "
ECSIGN2.CPP - " "
ECSVER2.CPP - " "
POLLARD.CPP - Example C++ source (uses ZZN.H)
WILLIAMS.CPP - " "
LENSTRA.CPP - " "
BRENT.CPP - " "
SAMPLE.CPP - Example C++ source (uses FLASH.H)
ROOTS.CPP - " "
HILBERT.CPP - " "
FSAMPLE.CPP - Example C++ source (uses FLOATING.H)
CARDANO.CPP - Example C++ source (uses ZZn2.H)
Note how readable the C++ versions of the example programs look.
In the subdirectory SOURCE/CURVE
CM.CPP - Complex Multiplication - creates elliptic curves
VARIABLE.H - Dummy Variable class
POLY.H - Polynomial Class definition, elements from ZZn
POLY.CPP - Polynomial Arithmetic with ZZn coefficients
POLY2.H - Polynomial Class definition, elements from GF(2^m)
POLY2.CPP - Polynomial Arithmetic with GF(2^m) coefficients
FLPOLY.H - Polynomial Class definition, float elements
FLPOLY.CPP - Polynomial arithmetic with float coefficients
COMPLEX.H - Complex Float class definition
COMPLEX.CPP - Complex Float class arithmetic
CM.TXT - How to build the CM application
POLYMOD.H - Polynomials mod a Polynomial - Class Definition
POLYMOD.CPP - ZZn Polynomial arithmetic wrt a Polynomial Modulus
POLY2MOD.H - Polynomials mod a Polynomial - Class Definition
POLY2MOD.CPP - GF(2^m) Polynomial arithmetic wrt a Polynomial Modulus
TRANS.CPP - A simple utility to convert elliptic curve to Weierstrass
SCHOOF.CPP - Schoof's method for counting points on a GF(p) elliptic curve
SCHOOF2.CPP - Schoof's method for counting points on a GF(2^m) elliptic curve
SCHOOF.TXT - How to build the schoof Application
SCHOOF2.TXT - How to build the schoof2 Application
PS_BIG.H - Power series with Big coefficients - Class Definition
PS_BIG.CPP - Power Series Arithmetic
PS_ZZN.H - Power series with ZZN coefficients - Class Definition
PS_ZZN.CPP - Power Series Arithmetic
POLYXY.H - Bivariate Polynomials - Class Definition
POLYXY.CPP - Bivariate Polynomilas - Implementation
POLY2XY.H - Bivariate Polynomials - Class Definition
POLY2XY.CPP - Bivariate Polynomilas - Implementation
MUELLER.CPP - Program to generate Modular Polynomials
PROCESS.CPP - Program to process Modular Polynomials wrt a prime modulus
SEA.CPP - Schoof-Elkies-Atkin-Mueller algorithm
SEA.TXT - How to build the MUELLER/PROCESS/SEA applications
WEIL.CPP - Calculates number of points on curve over extension field
GLV.CPP - Calculates a GLV decomposition
In the subdirectory SOURCE\P1363
P1363.H - P1363 Header File
P1363.C - P1363 implementation file
TEST1363.c - test driver for P1363 implementation
RSA.C - quick start RSA application
In the subdirectory SOURCE\IBE
IBE.TXT - Read this first
IBE_SET.CPP - Create IBE paramters, and master key
IBE_EXT.CPP - Extract a private key from the Identity
IBE_ENC.CPP - Encrypt a file using identity
IBE_DEC.CPP - Decrypt a file using the private key
IBE_DECP.CPP - Decrypt using precomputation
IBE_DECB.CPP - Decrypt using batching
IBE_ENCP.CPP - Demonstrate Encryption using precomputation
BLS_GEN.CPP - Boneh-Lynn-Shacham Short Signature key generation
BLS_SIGN.CPP - Boneh-Lynn-Shacham signature
BLS_VER.CPP - Boneh-Lynn-Shacham signature verification
ECN2.H - Elliptic curves over Fp2 - Header file
ECN2.CPP - Elliptic curves over Fp2 - Implementation file
ECN4.H - Elliptic curves over Fp4 - Header file
ECN4.CPP - Elliptic curves over Fp4 - Implementation file
ZZN2.H - Fp2 arithmetic - Header file
ZZN2.CPP - Fp2 arithmetic - Implementation file
ZZN3.H - Fp3 arithmetic - Header file
ZZN3.CPP - Fp3 arithmetic - Implementation file
ZZN4.H - Fp4 arithmetic - Header file
ZZN4.CPP - Fp4 arithmetic - Implementation file
ZZN8.H - Fp8 arithmetic - Header file
ZZN8.CPP - Fp8 arithmetic - Implementation file
ECN3.H/.CPP - Elliptic curves over Fp3
ZZN6.H/.CPP - Fp6 arithmetic - 2 over 3
ZZN6a.H/.CPP - Fp6 arithmetic - 3 over 2
ZZN12.H/.CPP - Fp12 arithmetic - 2 over 3 over 2
ZZN12a.H/.CPP- Fp12 arithmetic - 3 over 2 over 2
MNT.CPP - Program to generate MNT elliptic curves
MNT.ECS - Non-supersingular curve, k=6, created by CM from MNT output
FREEMAN.CPP - Program to generate k=10 Freeman curves
FOLKLORE.CPP - program to create pairing-friendly non-SS curves
IRRED.CPP - Finds irreducible polynomial - Experimental!
AKE.TXT - Some explanation for these programs.
AKE6MNTT.CPP - Authenticated Key Exchange, MNT k=6 curve - Experimental! 1-3-6 tower
AKE6MNTX.CPP - Authenticated Key Exchange, MNT k=6 curve - Experimental! Uses "compositum" tower.
AKE6MNTT.C - Partial C version of the above
AKE4MNTT.CPP - Authenticated Key Exchange, k=4 - Experimental!
AKE4MNTT.C - Partial C version of the above
AKE4MNTA.CPP - Authenticated Key Exchange, k=4 - Experimental! - Ate pairing
AKE4MNTT.C - Partial C version of the above
AKE6FSTA.CPP - Authenticated Key Exchange, k=6, Ate pairing, sextic twist!
BN.CPP - Program to generate BN curves
AKE12BNE.CPP - Authenticated Key Exchange, k=12, BN curve - Experimental!
AKE12BNA.CPP - Authenticated Key Exchange, k=12, BN curve, Ate pairing, sextic twist!
AKE12BNR.CPP - Authenticated Key Exchange, k=12, BN curve, R-ate pairing, sextic twist! 1-2-6-12 tower
AKE12BNX.CPP - Authenticated Key Exchange, k=12, BN curve, R-ate pairing, sextic twist! 1-2-4-12 tower
AKE12BLST.CPP - Authenticated Key Exchange, k=12, BLS curve, Tate pairing, sextic twist!
AKE2CPT.CPP - Same as above, but k=2 Cocks-Pinch curve
AKE2SST.CPP - Same as above, but uses a supersingular curve
AKE4CPT.CPP - Same as above, but k=4
AKEW4.CPP - Variation on the above
AKE8CPT.CPP - Same as above, but k=8 based
AKE8BWT.CPP - Variation on the above - uses Brezing-Weng curve
K2.ECS - Non-supersingular curve, k=2
K2SS.ECS - Supersingular curve, k=2
K4.ECS - Non-supersingular curve, k=4
K4MNT.ECS - MNT k=4 curve
K8.ECS - Non-supersingular curve, k=8
WENG.ECS - Non-supersingular curve, k=8
DL.CPP - Duursma-Lee Char 2 pairings
DL2.CPP - Truncnated-loop eta_T char 2 pairings
ETAT271.c - C version of eta_T pairing
BANDW.CPP - Brezing & Weng curves
AKE2NSST.CPP - Faster k=2 key exchange program - Not Superingular Curves
AKE2CPW.CPP - Uses New Weil pairing, k=2
AKE1KMT.CPP - Key Exchange program, for k=1 Koblitz-Menezes curve
MAKE_K1.CPP - Creates curves for the above
XK1.ECS - k=1 curve details
PAIRINGS.TXT - Details of pairing-based resources
In the subdirectory INCLUDE
MIRDEF.H16 - Standard hardware specific header file for 16-bit computer
MIRDEF.H32 - Header file for full 32-bit Computer
MIRDEF.H - Same as above
MIRDEF.HPC - Header file for pseudo-32 bit computer
MIRDEF.HAF - Header file for 16 bit use of 32 bit computer
MIRDEF.HIO - Integer-Only 32-bit header file
MIRACL.H - Main MIRACL header
BIG.H - C++ header for 'big' numbers
FLASH.H - C++ header for 'flash' numbers
FLOATING.H - C++ header for 'float' numbers
ZZN.H - C++ header for 'big' numbers mod n
CRT.H - C++ header for chinese remainder thereom
ECN.H - C++ header for GF(p) Elliptic Curves
EC2.H - C++ header for GF(2^m) Elliptic Curves
GF2M.H - C++ header for GF(2^m)
BRICK.H - C++ header for Brickell's method
EBRICK.H - C++ header for Brickell's method (Elliptic Curve GF(p) version)
EBRICK2.H - C++ header for Brickell's method (Elliptic Curve GF(2^m) version)
In the subdirectory LIB
*DOIT.BAT - Batch files for constructing libraries and sample progs.
MIRACL.MAK - John Kennedy's UNIX make file
BC32.LIB - Borland C++ V5.5 32 bit flat memory model MIRACL library
MS32.LIB - Microsoft C 32 bit MIRACL library (for Win95/WinNT)
MIRACL.A - DJGPP GNU C MIRACL Library
If using 16-bit Borland C++ V5.5 then use BCLDOIT.BAT to build MIRACL.LIB
Then copy MIRDEF.H16 to MIRDEF.H, and you're in business. Use BCXDOIT.BAT to
build a library for use with MIRDEF.HPC, to provide pseudo 32-bit performance
from a 16-bit compiler. BC32.LIB is a true 32-bit flat model library for use
with MIRDEF.H32. It was compiled with the Borland 32 bit compiler BCC32.
Programs generated in this way require a DOS Extender program (e.g. Borland
Powerpack for DOS), or Win32, or a Windows '95/***/NT environment.
MS32.LIB is for use with the MicroSoft 32 bit compiler and MIRDEF.H32
(for use with Windows95/*** or WinNT).
Older versions of these compilers may also work with these precompiled
libraries (try it and see). If using another compiler then you must execute
an appropriate xxDOIT.BAT file to create the MIRACL library.
If a pre-compiled library is not available:-
(1) Determine which of mirdef.h32/mirdef.h16/mirdef.haf/mirdef.hpc is
suitable for you, and/or compile and run config.c to automatically
generate a suitable mirdef.h.
(2) If for performance reasons a non-portable version is to be built,
select suitable assembly language routines from mrmuldv.any, or
write them yourself (send us a copy!). Even better - produce a
,mcs file for the processor and use either the KCM or Comba method.
(3) Compile and link together the mr*.c components into an object library.
Also assemble and link in the assemble language component from
mrmuldv.any (if needed).
In the subdirectory EXE some precompiled example programs
FACT.EXE - Factorial program
ROOTS.EXE - Roots program
PK-DEMO.EXE - Public Key Demo program (32-bit)
ENCIPH.EXE - Enciphering program
DECIPH.EXE - Deciphering program
PUBLIC.KEY - Public key for use by enciphering program
PRIVATE.KEY - Private key for use by deciphering program
SECP160/192/224/256/521.ecs - Param ... ...
近期下载者:
相关文件:
收藏者: