package octez-libs
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  A package that contains multiple base libraries used by the Octez suite
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      tezos-18.1.tar.gz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=aa2f5bc99cc4ca2217c52a1af2a2cdfd3b383208cb859ca2e79ca0903396ca1d
    
    
  sha512=d68bb3eb615e3dcccc845fddfc9901c95b3c6dc8e105e39522ce97637b1308a7fa7aa1d271351d5933febd7476b2819e1694f31198f1f0919681f1f9cc97cb3a
    
    
  doc/src/octez-libs.mec/bn254.ml.html
Source file bn254.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122(** https://neuromancer.sk/std/bn/bn254 https://tools.ietf.org/id/draft-yonezawa-pairing-friendly-curves-00.html Base field: 16798108731015832284940804142231733909889187121439069848933715426072753864723 (254 bits - 32 bytes) Scalar field: 16798108731015832284940804142231733909759579603404752749028378864165570215949 (254 bits - 32 bytes) Base field multiplicative subgroup decomposition: TODO Prime field multiplication subgroup decomposition: TODO *) module Fq = Ff.MakeFp (struct let prime_order = Z.of_string "0x2523648240000001BA344D80000000086121000000000013A700000000000013" end) module Fp = Ff.MakeFp (struct let prime_order = Z.of_string "0x2523648240000001BA344D8000000007FF9F800000000010A10000000000000D" end) module Projective = Ec.MakeProjectiveWeierstrass (Fq) (Fp) (struct let a = Fq.zero let b = Fq.of_z (Z.of_int 2) let cofactor = Z.one (* x = 0x2523648240000001BA344D80000000086121000000000013A700000000000012 y = 0x0000000000000000000000000000000000000000000000000000000000000001 *) let bytes_generator = Bytes.concat Bytes.empty [ Fq.( to_bytes (of_string "0x2523648240000001BA344D80000000086121000000000013A700000000000012")); Fq.(to_bytes (of_string "1")); Fq.(to_bytes one); ] end) module Jacobian = Ec.MakeJacobianWeierstrass (Fq) (Fp) (struct let a = Fq.zero let b = Fq.of_z (Z.of_int 2) let cofactor = Z.one (* x = 0x2523648240000001BA344D80000000086121000000000013A700000000000012 y = 0x0000000000000000000000000000000000000000000000000000000000000001 *) let bytes_generator = Bytes.concat Bytes.empty [ Fq.( to_bytes (of_string "0x2523648240000001BA344D80000000086121000000000013A700000000000012")); Fq.(to_bytes (of_string "1")); Fq.(to_bytes one); ] end) module Affine = Ec.MakeAffineWeierstrass (Fq) (Fp) (struct let a = Fq.zero let b = Fq.of_z (Z.of_int 2) let cofactor = Z.one (* x = 0x2523648240000001BA344D80000000086121000000000013A700000000000012 y = 0x0000000000000000000000000000000000000000000000000000000000000001 *) let bytes_generator = Bytes.concat Bytes.empty [ Fq.( to_bytes (of_string "0x2523648240000001BA344D80000000086121000000000013A700000000000012")); Fq.(to_bytes (of_string "1")); ] end) let from_affine_weierstrass_to_jacobian_weierstrass p = Ec.from_affine_weierstrass_to_jacobian_weierstrass (module Affine) (module Jacobian) p let from_affine_weierstrass_to_projective_weierstrass p = Ec.from_affine_weierstrass_to_projective_weierstrass (module Affine) (module Projective) p let from_jacobian_weierstrass_to_affine_weierstrass p = Ec.from_jacobian_weierstrass_to_affine_weierstrass (module Jacobian) (module Affine) p let from_projective_weierstrass_to_affine_weierstrass p = Ec.from_projective_weierstrass_to_affine_weierstrass (module Projective) (module Affine) p
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >