blob: c4af9f66c739f677d7178d7b40dc7c3d70477ec6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
Require Import Crypto.Arithmetic.PrimeFieldTheorems.
Require Import Crypto.Specific.solinas32_2e383m31_16limbs.Synthesis.
(* TODO : change this to field once field isomorphism happens *)
Definition square :
{ square : feBW_loose -> feBW_tight
| forall a, phiBW_tight (square a) = F.mul (phiBW_loose a) (phiBW_loose a) }.
Proof.
Set Ltac Profiling.
Time synthesize_square ().
Show Ltac Profile.
Time Defined.
Print Assumptions square.
|