2022-10-17 11:02:24 -04:00
|
|
|
global test_mul_Fp12:
|
|
|
|
|
// stack: f, f', g, g'
|
|
|
|
|
%store_fp6(0)
|
|
|
|
|
%store_fp6(6)
|
|
|
|
|
%store_fp6(12)
|
|
|
|
|
%store_fp6(18)
|
|
|
|
|
PUSH return_on_stack
|
|
|
|
|
// stack: return_on_stack
|
|
|
|
|
%jump(mul_Fp12)
|
|
|
|
|
return_on_stack:
|
|
|
|
|
// stack:
|
|
|
|
|
%load_fp6(30)
|
2022-10-17 15:58:56 -04:00
|
|
|
%load_fp6(24)
|
2022-10-17 11:02:24 -04:00
|
|
|
// stack: h, h'
|
|
|
|
|
%jump(0xdeadbeef)
|
2022-10-13 20:06:19 -04:00
|
|
|
|
2022-10-07 15:41:46 -07:00
|
|
|
|
2022-10-18 11:23:43 -04:00
|
|
|
/// macro | num | ops | cost
|
|
|
|
|
/// -------------------------
|
2022-10-18 12:47:31 -04:00
|
|
|
/// load | 8 | 40 | 320
|
|
|
|
|
/// store | 5 | 40 | 200
|
|
|
|
|
/// dup | 5 | 6 | 30
|
|
|
|
|
/// swap | 4 | 16 | 64
|
|
|
|
|
/// add | 3 | 16 | 48
|
|
|
|
|
/// sub | 2 | 17 | 34
|
|
|
|
|
/// mul | 3 | 156 | 468
|
|
|
|
|
/// i9 | 1 | 9 | 9
|
|
|
|
|
/// jump | 1 | 1 | 1
|
2022-10-18 11:23:43 -04:00
|
|
|
///
|
|
|
|
|
/// TOTAL: 1174
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// F = f + f'z
|
|
|
|
|
/// G = g + g'z
|
|
|
|
|
///
|
|
|
|
|
/// H = h + h'z = FG
|
|
|
|
|
///
|
|
|
|
|
/// h = fg + sh(f'g')
|
|
|
|
|
/// h' = (f+f')(g+g') - fg - f'g'
|
|
|
|
|
///
|
|
|
|
|
/// Note: each symbol in the stack comments consists of six words
|
|
|
|
|
|
2022-10-17 11:02:24 -04:00
|
|
|
global mul_Fp12:
|
2022-10-07 15:41:46 -07:00
|
|
|
%load_fp6(6)
|
|
|
|
|
%load_fp6(18)
|
|
|
|
|
%dup2_fp6
|
|
|
|
|
%dup2_fp6
|
|
|
|
|
// stack: g', f', g', f'
|
|
|
|
|
%mul_fp6
|
|
|
|
|
%dup1_fp6
|
2022-10-17 15:58:56 -04:00
|
|
|
// stack: f'g', f'g', g', f'
|
2022-10-07 15:41:46 -07:00
|
|
|
%store_fp6_sh(36)
|
|
|
|
|
%store_fp6(42)
|
|
|
|
|
// stack: g', f'
|
|
|
|
|
%load_fp6(12)
|
|
|
|
|
// stack: g , g', f'
|
|
|
|
|
%swap_fp6
|
|
|
|
|
// stack: g', g , f'
|
|
|
|
|
%dup2_fp6
|
|
|
|
|
// stack: g , g', g , f'
|
|
|
|
|
%add_fp6
|
|
|
|
|
// stack: g + g', g , f'
|
|
|
|
|
%swap_fp6
|
|
|
|
|
// stack: g , g + g', f'
|
|
|
|
|
%load_fp6(0)
|
2022-10-17 15:58:56 -04:00
|
|
|
// stack: f, g , g + g', f'
|
2022-10-07 15:41:46 -07:00
|
|
|
%mul_fp6
|
|
|
|
|
%store_fp6(48)
|
2022-10-17 15:58:56 -04:00
|
|
|
// stack: g + g', f'
|
2022-10-07 15:41:46 -07:00
|
|
|
%swap_fp6
|
|
|
|
|
%load_fp6(0)
|
|
|
|
|
%add_fp6
|
2022-10-17 15:58:56 -04:00
|
|
|
// stack: f+f', g+g'
|
2022-10-07 15:41:46 -07:00
|
|
|
%mul_fp6
|
|
|
|
|
// stack: (f+f')(g+g')
|
|
|
|
|
%load_fp6(42)
|
2022-10-17 15:58:56 -04:00
|
|
|
// stack: f'g', (f+f')(g+g')
|
2022-10-17 11:02:24 -04:00
|
|
|
%bus_fp6
|
2022-10-07 15:41:46 -07:00
|
|
|
// stack: (f+f')(g+g') - f'g'
|
|
|
|
|
%load_fp6(48)
|
|
|
|
|
%swap_fp6
|
|
|
|
|
// stack: (f+f')(g+g') - f'g' , fg
|
|
|
|
|
%dup2_fp6
|
|
|
|
|
%bus_fp6
|
|
|
|
|
// stack: (f+f')(g+g') - f'g' - fg, fg
|
|
|
|
|
%store_fp6(30)
|
|
|
|
|
// stack: fg
|
|
|
|
|
%load_fp6(36)
|
|
|
|
|
// stack: sh(f'g') , fg
|
|
|
|
|
%add_fp6
|
|
|
|
|
// stack: sh(f'g') + fg
|
|
|
|
|
%store_fp6(24)
|
2022-10-17 11:02:24 -04:00
|
|
|
JUMP
|