Ejemplo n.º 1
0
 /// <summary>
 /// Create a new integer, importing it from an array of input values and setting the sign.
 /// The most significant byte is given first.
 /// This option is here for saving and loading the integer.
 /// The sign is specified seperately because GMP uses magnitude/sign format.
 /// </summary>
 public GmpInteger(byte[] initialValue, bool isNegative = false)
 {
     if (initialValue == null) throw new ArgumentException("initialValue");
     Interop.mpz_import(ref _Storage, initialValue.Length, 1, 1, 0, 0, initialValue);
     if (isNegative) {
         mpz_t negStorage = new mpz_t();
         Interop.mpz_neg(ref negStorage, ref _Storage);
         Interop.mpz_clear(ref _Storage);
         _Storage = negStorage;
     }
     DisposeContext.AddDisposeObject(this);
 }
Ejemplo n.º 2
0
 /// <summary>
 /// Create a new integer, importing it from an array of input values and setting the sign.
 /// The most significant byte is given first.
 /// This option is here for saving and loading the integer.
 /// The sign is specified seperately because GMP uses magnitude/sign format.
 /// </summary>
 public GmpInteger(byte[] initialValue, bool isNegative = false)
 {
     if (initialValue == null)
     {
         throw new ArgumentException("initialValue");
     }
     Interop.mpz_import(ref _Storage, initialValue.Length, 1, 1, 0, 0, initialValue);
     if (isNegative)
     {
         mpz_t negStorage = new mpz_t();
         Interop.mpz_neg(ref negStorage, ref _Storage);
         Interop.mpz_clear(ref _Storage);
         _Storage = negStorage;
     }
     DisposeContext.AddDisposeObject(this);
 }
Ejemplo n.º 3
0
 public static extern int mpz_sizeinbase(ref mpz_t op, int base_);
Ejemplo n.º 4
0
 public static extern void mpz_mod(ref mpz_t rop, ref mpz_t op1, ref mpz_t op2);
Ejemplo n.º 5
0
 public static extern void mpz_sub(ref mpz_t w, ref mpz_t u, ref mpz_t v);
Ejemplo n.º 6
0
 public static extern void mpz_sub(ref mpz_t w, ref mpz_t u, ref mpz_t v);
Ejemplo n.º 7
0
 public static extern void mpz_neg(ref mpz_t negV, ref mpz_t v);
Ejemplo n.º 8
0
 public static extern bool mpz_init(ref mpz_t x);
Ejemplo n.º 9
0
 public static extern bool mpz_clear(ref mpz_t x);
Ejemplo n.º 10
0
 public static extern IntPtr mpz_export(byte[] rop, ref int countp, int order, int size, int endian, int nails, ref mpz_t op);
Ejemplo n.º 11
0
 public static extern IntPtr mpz_get_str([MarshalAs(UnmanagedType.LPStr)] StringBuilder str, int base_, ref mpz_t op);
Ejemplo n.º 12
0
 public static extern bool mpz_clear(ref mpz_t x);
Ejemplo n.º 13
0
 public static extern int mpz_cmp(ref mpz_t op1, ref mpz_t op2);
Ejemplo n.º 14
0
 public static extern void mpz_add(ref mpz_t w, ref mpz_t u, ref mpz_t v);
Ejemplo n.º 15
0
 public static extern void mpz_abs(ref mpz_t absV, ref mpz_t v);
Ejemplo n.º 16
0
 public static extern void mpz_tdiv_q(ref mpz_t q, ref mpz_t n, ref mpz_t d);
Ejemplo n.º 17
0
 public static extern IntPtr mpz_get_str([MarshalAs(UnmanagedType.LPStr)] StringBuilder str, int base_, ref mpz_t op);
Ejemplo n.º 18
0
 public static extern void mpz_import(ref mpz_t rop, int count, int order, int size, int endian, int nails, byte[] op);
Ejemplo n.º 19
0
 public static extern IntPtr mpz_export(byte[] rop, ref int countp, int order, int size, int endian, int nails, ref mpz_t op);
Ejemplo n.º 20
0
 public static extern bool mpz_init(ref mpz_t x);
Ejemplo n.º 21
0
 public static extern int mpz_set_str(ref mpz_t rop, string str, int base_);
Ejemplo n.º 22
0
 public static extern void mpz_mul(ref mpz_t rop, ref mpz_t op1, ref mpz_t op2);
Ejemplo n.º 23
0
 public static extern void mpz_add(ref mpz_t w, ref mpz_t u, ref mpz_t v);
Ejemplo n.º 24
0
 public static extern void mpz_mul_2exp(ref mpz_t rop, ref mpz_t op1, uint op2);
Ejemplo n.º 25
0
 public static extern void mpz_abs(ref mpz_t absV, ref mpz_t v);
Ejemplo n.º 26
0
 public static extern int mpz_cmp(ref mpz_t op1, ref mpz_t op2);
Ejemplo n.º 27
0
 public static extern void mpz_mul_2exp(ref mpz_t rop, ref mpz_t op1, uint op2);
Ejemplo n.º 28
0
 public static extern int mpz_set_str(ref mpz_t rop, string str, int base_);
Ejemplo n.º 29
0
 public static extern void mpz_tdiv_q(ref mpz_t q, ref mpz_t n, ref mpz_t d);
Ejemplo n.º 30
0
 public static extern int mpz_sizeinbase(ref mpz_t op, int base_);
Ejemplo n.º 31
0
 public static extern void mpz_import(ref mpz_t rop, int count, int order, int size, int endian, int nails, byte[] op);
Ejemplo n.º 32
0
 public static extern void mpz_neg(ref mpz_t negV, ref mpz_t v);