better comments

This commit is contained in:
Dmitry Vagner 2022-10-25 17:09:25 -04:00
parent 59dc9b2d8e
commit f6a30cba7c

View File

@ -37,8 +37,8 @@ ret_stack:
%jump(0xdeadbeef) %jump(0xdeadbeef)
/// fp6 macros: /// fp6 functions:
/// macro | num | ops | cost /// fn | num | ops | cost
/// ------------------------- /// -------------------------
/// load | 8 | 40 | 320 /// load | 8 | 40 | 320
/// store | 5 | 40 | 200 /// store | 5 | 40 | 200
@ -61,77 +61,81 @@ ret_stack:
/// ///
/// TOTAL: 1196 /// TOTAL: 1196
/// inputs:
/// F = f + f'z /// F = f + f'z
/// G = g + g'z /// G = g + g'z
/// ///
/// H = h + h'z = FG /// output:
/// H = h + h'z = FG
/// ///
/// h = fg + sh(f'g') /// h = fg + sh(f'g')
/// h' = (f+f')(g+g') - fg - f'g' /// h' = (f+f')(g+g') - fg - f'g'
/// ///
/// Note: f, f', g, g' consist of six terms on the stack /// memory offsets [ind' = ind+6]
/// {in0: f, in0: f', in1: g, in1':g', out: h, out': h'}
///
/// f, f', g, g' consist of six elements on the stack
global mul_Fp12: global mul_Fp12:
// stack: in0, in1, out // stack: in0, in1, out
DUP1 %add_const(6) DUP1 %add_const(6)
// stack: in0', in0, in1, out // stack: in0', in0, in1, out
%load_fp6 %load_fp6
// stack: f', in0, in1, out // stack: f', in0, in1, out
DUP8 %add_const(6) DUP8 %add_const(6)
// stack: in1', f', in0, in1, out // stack: in1', f', in0, in1, out
%load_fp6 %load_fp6
// stack: g', f', in0, in1, out // stack: g', f', in0, in1, out
PUSH ret_1 PUSH ret_1
// stack: ret_1, g', f', in0, in1, out // stack: ret_1, g', f', in0, in1, out
%dup_fp6_7 %dup_fp6_7
// stack: f', ret_1, g', f', in0, in1, out // stack: f', ret_1, g', f', in0, in1, out
%dup_fp6_7 %dup_fp6_7
// stack: g', f', ret_1, g', f', in0, in1, out // stack: g', f', ret_1, g', f', in0, in1, out
%jump(mul_fp6) %jump(mul_fp6)
ret_1: ret_1:
// stack: f'g', g' , f', in0, in1, out // stack: f'g', g' , f', in0, in1, out
%dup_fp6_0 %dup_fp6_0
// stack: f'g', f'g', g' , f', in0, in1, out // stack: f'g', f'g', g' , f', in0, in1, out
%store_fp6_sh(100) %store_fp6_sh(100)
// stack: f'g', g' , f', in0, in1, out {100: sh(f'g')} // stack: f'g', g' , f', in0, in1, out {100: sh(f'g')}
%store_fp6(106) %store_fp6(106)
// stack: g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
DUP13 DUP13
// stack: in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
DUP15 DUP15
// stack: in1, in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: in1, in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%load_fp6 %load_fp6
// stack: g , in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g , in0, g' , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%swap_fp6_hole %swap_fp6_hole
// stack: g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%dup_fp6_7 %dup_fp6_7
// stack: g,g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g,g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%add_fp6 %add_fp6
// stack: g+g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g+g', in0, g , f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%swap_fp6_hole %swap_fp6_hole
// stack: g, in0, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: g, in0, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'}
PUSH ret_2 PUSH ret_2
// stack: ret_2, g, in0, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: ret_2, g, in0, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'}
SWAP7 SWAP7
// stack: in0, g, ret_2, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: in0, g, ret_2, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%load_fp6 %load_fp6
// stack: f, g, ret_2, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: f, g, ret_2, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%jump(mul_fp6) %jump(mul_fp6)
ret_2: ret_2:
// stack: fg, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'} // stack: fg, g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g'}
%store_fp6(112) %store_fp6(112)
// stack: g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: g+g', f', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
%swap_fp6 %swap_fp6
// stack: f', g+g', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: f', g+g', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
PUSH ret_3 PUSH ret_3
// stack: ret_3, f', g+g', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: ret_3, f', g+g', in0, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
SWAP13 SWAP13
// stack: in0, f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: in0, f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
%load_fp6 %load_fp6
// stack: f,f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: f,f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
%add_fp6 %add_fp6
// stack: f+f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: f+f', g+g', ret_3, in1, out {100: sh(f'g'), 106: f'g', 112: fg}
%jump(mul_fp6) %jump(mul_fp6)
ret_3: ret_3:
// stack: (f+f')(g+g'), in1, out {100: sh(f'g'), 106: f'g', 112: fg} // stack: (f+f')(g+g'), in1, out {100: sh(f'g'), 106: f'g', 112: fg}