Skip to content

Commit

Permalink
fixed divZ
Browse files Browse the repository at this point in the history
blueh4mster committed Dec 15, 2023
1 parent 6bae8f3 commit cbcec51
Showing 6 changed files with 117 additions and 97 deletions.
4 changes: 2 additions & 2 deletions script/Deploy.s.sol
Original file line number Diff line number Diff line change
@@ -14,9 +14,9 @@ interface WRAPPER {
function toPolar(int256, int256) external returns (int256, int256);
function fromPolar(int256, int256) external returns (int256, int256);

// function p_atan2(int256, int256) external returns (int256);
function p_atan2(int256, int256) external returns (int256);

// function atan1to1(int256) external returns (int256);
function atan1to1(int256) external returns (int256);

function ln(int256, int256) external returns (int256, int256);

107 changes: 56 additions & 51 deletions src/ComplexHuff/Complex.huff
Original file line number Diff line number Diff line change
@@ -43,10 +43,10 @@
//INPUT STACK => [RE(a),RE(b),IM(a),IM(b)]

0x02 // [2,Re(A),Re(B),Im(A),Im(B)]
dup2 // [Re(B),2,Re(A),Re(B),Im(A),Im(B)]
dup3 // [Re(B),2,Re(A),Re(B),Im(A),Im(B)]
exp // [Re(B)**2 ,Re(A),Re(B),Im(A),Im(B)]
0x02 // [2,Re(B)**2 ,Re(A),Re(B),Im(A),Im(B)]
dup5 // [Im(B),2,Re(B)**2,Re(A),Re(B),Im(A),Im(B)]
dup6 // [Im(B),2,Re(B)**2,Re(A),Re(B),Im(A),Im(B)]
exp // [Im(B)**2,Re(B)**2,Re(A),Re(B),Im(A),Im(B)]
add // [Im(B)**2+Re(B)**2,Re(A),Re(B),Im(A),Im(B)] , Let Im(B)**2+Re(B)**2 be X
swap4 // [Im(B),Re(A),Re(B),Im(A),X]
@@ -252,55 +252,60 @@
0x40 0x00 return
}

// #define macro P_ATAN2() = takes(2) returns(1) {
// // INPUT STACK => [y,x]

// dup1 // [y,y,x]
// swap2 // [x,y,y]
// P_ATAN2_INNER_CALC() // [T,y]
// swap1 // [y,T]
// 0x00 // [0,y,T]
// sgt // [0>y,T]
// case3
// jumpi

// case3:
// PUT_NEG1() // [-1,T]
// mul // [-T]

// }

// #define macro ATAN1TO1() = takes(1) returns(1){
// // INPUT STACK => [x]

// [X7] // [X7,x]
// dup1 // [x,X7,x]
// mul // [x*X7,x]
// [X3] // [1e18,x*X7,x]
// swap1 // [x*X7,1e18,x]
// sdiv // [x*X7/1e18,x]
// [X6] // [X6,x*X7/1e18,x]
// add // [X6+x*X7/1e18,x]
// [X3] // [1e18,X6+x*X7/1e18,x]
// dup3 // [x,1e18,X6+x*X7/1e18,x]
// sub // [x-1e18,X6+x*X7/1e18,x]
// dup3 // [x,x-1e18,X6+x*X7/1e18,x]
// mul // [x*(x-1e18),X6+x*X7/1e18,x]
// [X3] // [1e18,x*(x-1e18),X6+x*X7/1e18,x]
// swap1 // [x*(x-1e18),1e18,X6+x*X7/1e18,x]
// sdiv // [x*(x-1e18)/1e18,X6+x*X7/1e18,x]
// mul // [(x*(x-1e18)/1e18)*(X6+x*X7/1e18),x]
// swap1 // [x,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// [X5] // [X5,x,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// mul // [X5*x,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// [X3] // [1e18,X5*x,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// swap1 // [X5*x,1e18,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// sdiv // [X5*x/1e18,(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// sub // [X5*x/1e18-(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// [X3] // [1e18,X5*x/1e18-(x*(x-1e18)/1e18)*(X6+x*X7/1e18)]
// swap1 // [X5*x/1e18-(x*(x-1e18)/1e18)*(X6+x*X7/1e18),1e18]
// sdiv // [X5*x/1e18-(x*(x-1e18)/1e18)*(X6+x*X7/1e18)/1e18]
// }
#define macro P_ATAN2() = takes(2) returns(1) {
// INPUT STACK => [y,x]

dup1 // [y,y,x]
swap2 // [x,y,y]
P_ATAN2_INNER_CALC() // [T,y]
swap1 // [y,T]
0x00 // [0,y,T]
sgt // [0>y,T]
case3
jumpi
0x01 // [1,T]
finish
jumpi


case3:
PUT_NEG1() // [-1,T]
mul // [-T]

finish: // [Appropriate T]
}

#define macro ATAN1TO1() = takes(1) returns(1){
// INPUT STACK => [x]

[X7] // [X7,x]
dup2 // [x,X7,x]
mul // [x*X7,x]
[X3] // [1e18,x*X7,x]
swap1 // [x*X7,1e18,x]
sdiv // [x*X7/1e18,x]
[X6] // [X6,x*X7/1e18,x]
add // [X6+x*X7/1e18,x]
[X3] // [1e18,X6+x*X7/1e18,x]
dup3 // [x,1e18,X6+x*X7/1e18,x]
sub // [x-1e18,X6+x*X7/1e18,x]
dup3 // [x,x-1e18,X6+x*X7/1e18,x]
mul // [x*(x-1e18),X6+x*X7/1e18,x]
[X3] // [1e18,x*(x-1e18),X6+x*X7/1e18,x]
swap1 // [x*(x-1e18),1e18,X6+x*X7/1e18,x]
sdiv // [x*(x-1e18)/1e18,X6+x*X7/1e18,x]
mul // [(x*(x-1e18)/1e18)*(X6+x*X7/1e18),x]
[X3] // [1e18,(x*(x-1e18)/1e18)*(X6+x*X7/1e18),x]
swap1 // [(x*(x-1e18)/1e18)*(X6+x*X7/1e18),1e18,x]
sdiv // [((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18,x]
swap1 // [x,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
[X5] // [X5,x,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
mul // [X5*x,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
[X3] // [1e18,X5*x,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
swap1 // [X5*x,1e18,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
sdiv // [X5*x/1e18,((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
sub // [X5*x/1e18-((x*(x-1e18)/1e18)*(X6+x*X7/1e18))/1e18]
}

#define macro LN() = takes(2) returns(1) {
//INPUT STACK => [Re(A),Im(A)]
1 change: 1 addition & 0 deletions src/ComplexHuff/Constants.huff
Original file line number Diff line number Diff line change
@@ -6,6 +6,7 @@
#define constant X11 = 0xE8D4A51000 // 1e12
#define constant X12 = 0xE47469D8BC6E // 1e(18*4/5)
#define constant X4 = 0x9C2007651B2500000 // 180e18
#define constant X5 = 0xAE4E15744AE8000 // 7.85e17
#define constant e = 0x25B946EBC0B36173 // euler's number
#define constant PI_QUARTER = 0xAE4E15744AE8000 // 7.851e17
#define constant X6 = 0x365595A8089C000 // 2.447e17
42 changes: 23 additions & 19 deletions src/ComplexHuff/Helper.huff
Original file line number Diff line number Diff line change
@@ -52,28 +52,14 @@

dup1 // [x,x,y]
0x00 // [0,x,x,y]
slt // [x<0,x,y]
swap1 // [x,0,x,y]
slt // [x < 0,x,y]
diff_case
jumpi
swap1 // [y,x]
P_ATAN2_ABS() // [abs_y,x]
dup2 // [x,abs_y,x]
dup2 // [abs_y,x,abs_y,x]
sub // [abs_y-x,abs_y,x]
swap2 // [x,abs_y,abs_y-x]
add // [x+abs_y,abs_y-x]
[X3] // [1e18,x+abs_y,abs_y-x]
mul // [1e18*(x+abs_y),abs_y-x]
sdiv // [(1e18*(x+abs_y))/(abs_y-x)] , Let (1e18*(x+abs_y))/(abs_y-x) = r
P_ATAN2_INNER_T() // [T]
PUT_C2() // [c2,T]
add // [c2+T]

diff_case: // [x,y] and x<0 condition
swap1 // [y,x]
P_ATAN2_ABS() // [abs_y,x]
dup2 // [x,abs_y,x]
dup2 // [abs_y,x,abs_y,x]
add // [abs_y+x,abs_y,x]
swap2 // [x,abs_y,abs_y+x]
sub // [x-abs_y,abs_y+x]
@@ -83,14 +69,32 @@
P_ATAN2_INNER_T() // [T]
PUT_C1() // [c1,T]
add // [c1+T]
0x01
finish
jumpi

diff_case: // [x,y] and x<0 condition
swap1 // [y,x]
P_ATAN2_ABS() // [abs_y,x]
dup2 // [x,abs_y,x]
dup2 // [abs_y,x,abs_y,x]
sub // [abs_y-x,abs_y,x]
swap2 // [x,abs_y,abs_y-x]
add // [x+abs_y,abs_y-x]
[X3] // [1e18,x+abs_y,abs_y-x]
mul // [1e18*(x+abs_y),abs_y-x]
sdiv // [(1e18*(x+abs_y))/(abs_y-x)] , Let (1e18*(x+abs_y))/(abs_y-x) = r
P_ATAN2_INNER_T() // [T]
PUT_C2() // [c2,T]
add // [c2+T]
finish:
}

#define macro P_ATAN2_INNER_T() = takes(1) returns(1){
//Input Stack => [r]

[X3] // [1e18,r]
dup1 // [r,1e18,r]
[X2] // [X2,r,1e18,r]
dup2 // [r,1e18,r]
[X2] // [X2,r,1e18,r] // x2 == 9817e14
mul // [X2*r,1e18,r]
sdiv // [(X2*r)/1e18,r]
PUT_X3_CUBE() // [1e54,(X2*r)/1e18,r]
42 changes: 21 additions & 21 deletions src/ComplexHuff/WRAPPER.huff
Original file line number Diff line number Diff line change
@@ -7,8 +7,8 @@
#define function calcR(int256,int256) view returns (uint256)
#define function toPolar(int256,int256) view returns (int256,int256)
#define function fromPolar(int256,int256) view returns (int256,int256)
// #define function p_atan2(int256 , int256) returns (int256)
// #define function atan1to1(int256 ) returns (int256)
#define function p_atan2(int256 , int256) view returns (int256)
#define function atan1to1(int256) view returns (int256)
#define function ln(int256,int256) view returns (int256,int256)
#define function sqrt(int256,int256) view returns (int256,int256)
#define function expZ(int256,int256) view returns (int256,int256)
@@ -94,22 +94,22 @@
FROM_POLAR()
}

// #define macro P_ATAN2_LOCAL() = takes(0) returns(0){
// 0x04 calldataload
// 0x24 calldataload
// P_ATAN2()
// 0x00 mstore
// 0x20 0x00 return
#define macro P_ATAN2_LOCAL() = takes(0) returns(0){
0x04 calldataload
0x24 calldataload
P_ATAN2()
0x00 mstore
0x20 0x00 return

// }
}

// #define macro ATAN1TO1_LOCAL() = takes(0) returns(0){
// 0x04 calldataload
// ATAN1TO1()
// 0x00 mstore
// 0x20 0x00 return
#define macro ATAN1TO1_LOCAL() = takes(0) returns(0){
0x04 calldataload
ATAN1TO1()
0x00 mstore
0x20 0x00 return

// }
}

#define macro LN_LOCAL() = takes(0) returns(0){
0x04 calldataload
@@ -159,8 +159,8 @@
dup1 __FUNC_SIG(calcR) eq calc_R jumpi
dup1 __FUNC_SIG(toPolar) eq to_Polar jumpi
dup1 __FUNC_SIG(fromPolar) eq from_Polar jumpi
// dup1 __FUNC_SIG(p_atan2) eq p_atan2 jumpi
// dup1 __FUNC_SIG(atan1to1) eq atan1to1 jumpi
dup1 __FUNC_SIG(p_atan2) eq p__atan2 jumpi
dup1 __FUNC_SIG(atan1to1) eq a_tan1to1 jumpi
dup1 __FUNC_SIG(ln) eq ln_Z jumpi
dup1 __FUNC_SIG(sqrt) eq sqrt_jump jumpi
dup1 __FUNC_SIG(expZ) eq exp_Z jumpi
@@ -189,11 +189,11 @@
from_Polar:
FROM_POLAR_LOCAL()

// p_atan2:
// P_ATAN2_LOCAL()
p__atan2:
P_ATAN2_LOCAL()

// atan1to1:
// ATAN1TO1_LOCAL()
a_tan1to1:
ATAN1TO1_LOCAL()

ln_Z:
LN_LOCAL()
18 changes: 14 additions & 4 deletions test/Complex.t.sol
Original file line number Diff line number Diff line change
@@ -34,8 +34,8 @@ contract ComplexTest is Test {

function testDivZ() public {
(int256 r, int256 i) = complex.divz(7 * scale, 1 * scale, 5 * scale, 2 * scale);
assertEq((r * 10) / scale, 34); // 17/5
assertEq((i * 10) / scale, -18); // -8/5
assertEq((r * 10) / scale, 2); // 17/74
assertEq((i * 10) / scale, -1); // -8/74
}

function testCalcR() public {
@@ -78,6 +78,16 @@ contract ComplexTest is Test {
assertEq(r * 100 / scale, 391); // ln(50) = 3.912..
assertEq(i * 100 / scale, 65);
}

function testAtan2() public {
int256 r = complex.p_atan2(4 * scale, 3 * scale);
assertEq((r * 100) / scale, 6124);
}

function testAtan1to1() public {
int256 r = complex.atan1to1(9 * 1e17);
assertEq((r * 100) / scale, 73);
}
}

interface WRAPPER {
@@ -95,9 +105,9 @@ interface WRAPPER {

function fromPolar(int256, int256) external returns (int256, int256);

// function p_atan2(int256, int256) external returns (int256);
function p_atan2(int256, int256) external returns (int256);

// function atan1to1(int256) external returns (int256);
function atan1to1(int256) external returns (int256);

function ln(int256, int256) external returns (int256, int256);

0 comments on commit cbcec51

Please sign in to comment.