Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(hints): Implement NewHint#40 #1038

Merged
merged 52 commits into from
Apr 25, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
17716c4
Add test
fmoletta Apr 20, 2023
e867c2b
Ignore builtin segments in get_memory_holes
fmoletta Apr 20, 2023
c560497
Improve test
fmoletta Apr 20, 2023
ed5329f
Add memory holes check for cairo_run_test tests
fmoletta Apr 20, 2023
c15445b
Fix broken condition
fmoletta Apr 20, 2023
f252960
Make memory_holes check optional & customizable
fmoletta Apr 20, 2023
063f9c4
Fix bounds
fmoletta Apr 20, 2023
6e3ed8b
Add a test with deliberately created memory holes
fmoletta Apr 20, 2023
9fa2dc8
Fix test value
fmoletta Apr 20, 2023
d36bf3f
Remove duplicated tests + add memory hole value to some tests
fmoletta Apr 20, 2023
ece99eb
Add memory holes value + remove duplicated tests + fix typo
fmoletta Apr 20, 2023
1f867fb
Fix test values
fmoletta Apr 20, 2023
ac9c795
Add changelog entry
fmoletta Apr 20, 2023
356a187
Link PR in Changelog
fmoletta Apr 20, 2023
0f89514
Merge branch 'main' of github.com:lambdaclass/cairo-rs into fix-get-m…
fmoletta Apr 20, 2023
67e2622
Mark breaking change in changelog
fmoletta Apr 21, 2023
4a17d58
Merge branch 'main' of github.com:lambdaclass/cairo-rs into fix-get-m…
fmoletta Apr 21, 2023
e114745
fmt
fmoletta Apr 21, 2023
3ecf882
Fix test value
fmoletta Apr 21, 2023
342efdb
Fix codecov-patch diff
fmoletta Apr 21, 2023
67e3b70
Add hint code
fmoletta Apr 21, 2023
4779307
Add integration test
fmoletta Apr 21, 2023
cbe3b5d
Add untracked file
fmoletta Apr 21, 2023
81a99e5
Merge branch 'main' into div-mod-n-packed-hint
fmoletta Apr 21, 2023
a71552d
Add changelog entry
fmoletta Apr 21, 2023
75bb911
Rename hint
fmoletta Apr 21, 2023
53ade42
Merge branch 'main' into div-mod-n-packed-hint
fmoletta Apr 21, 2023
23c7d8f
Fix test
fmoletta Apr 21, 2023
992c7fe
Fix test
fmoletta Apr 21, 2023
b434052
Add hint code + hint impl + unit test
fmoletta Apr 21, 2023
ad46d43
fmt
fmoletta Apr 21, 2023
c078fc2
Add integration test
fmoletta Apr 21, 2023
ad87b73
Add changelog entry
fmoletta Apr 21, 2023
86f7094
Merge branch 'main' into new-hint-38
fmoletta Apr 21, 2023
1ad1716
Implement hint + add tests
fmoletta Apr 21, 2023
2f60b81
Add changelog entry
fmoletta Apr 21, 2023
d183b6b
Remove indent from hint string
fmoletta Apr 21, 2023
535f9c8
Merge branch 'div-mod-n-packed-hint' into new-hint-38
fmoletta Apr 21, 2023
5ee243b
Merge branch 'new-hint-38' into new-hint-39
fmoletta Apr 21, 2023
6cd45c2
Add wasm import
fmoletta Apr 21, 2023
7316d57
Merge branch 'div-mod-n-packed-hint' into new-hint-38
fmoletta Apr 21, 2023
a44b045
Merge branch 'new-hint-38' into new-hint-39
fmoletta Apr 21, 2023
d4da292
Fix prev hint + implement new hint
fmoletta Apr 21, 2023
c9bb1ec
Add tests
fmoletta Apr 21, 2023
b446c39
Add changelog entry
fmoletta Apr 21, 2023
1545cc7
Update CHANGELOG.md
fmoletta Apr 21, 2023
050b6bf
Update CHANGELOG.md
fmoletta Apr 21, 2023
717ab60
Fix Pr numbers
fmoletta Apr 21, 2023
6327388
Merge branch 'new-hint-39' into new-hint-40
fmoletta Apr 21, 2023
51e065b
Update src/hint_processor/builtin_hint_processor/ec_recover.rs
fmoletta Apr 21, 2023
6c7b84a
Merge branch 'main' of github.com:lambdaclass/cairo-rs into new-hint-40
fmoletta Apr 25, 2023
93e5145
Fix changelog
fmoletta Apr 25, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 21 additions & 11 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,22 @@

#### Upcoming Changes

<<<<<<< HEAD
* Implement hint on ec_recover.json whitelist [#1038](https://github.com/lambdaclass/cairo-rs/pull/1038):

`BuiltinHintProcessor` now supports the following hint:

```python
%{
value = k = product // m
%}
```

* Implement hint on ec_recover.json whitelist [#1037](https://github.com/lambdaclass/cairo-rs/pull/1037):
=======
* Implement hint for `starkware.cairo.common.cairo_keccak.keccak.finalize_keccak` as described by whitelist `starknet/security/whitelists/cairo_keccak.json` [#1041](https://github.com/lambdaclass/cairo-rs/pull/1041)
>>>>>>> 50c90d944bc090578824bb50bed1b1ada5a5fbc0

`BuiltinHintProcessor` now supports the following hint:

```python
%{
<<<<<<< HEAD
from starkware.cairo.common.cairo_secp.secp_utils import pack
from starkware.python.math_utils import div_mod, safe_div

Expand All @@ -22,7 +27,16 @@
m = pack(ids.m, PRIME)

value = res = product % m
=======

%}
```

* Implement hint for `starkware.cairo.common.cairo_keccak.keccak.finalize_keccak` as described by whitelist `starknet/security/whitelists/cairo_keccak.json` [#1041](https://github.com/lambdaclass/cairo-rs/pull/1041)

`BuiltinHintProcessor` now supports the following hint:

```python
%{
# Add dummy pairs of input and output.
_keccak_state_size_felts = int(ids.KECCAK_STATE_SIZE_FELTS)
_block_size = int(ids.BLOCK_SIZE)
Expand All @@ -31,7 +45,6 @@
inp = [0] * _keccak_state_size_felts
padding = (inp + keccak_func(inp)) * _block_size
segments.write_arg(ids.keccak_ptr_end, padding)
>>>>>>> 50c90d944bc090578824bb50bed1b1ada5a5fbc0
%}
```

Expand Down Expand Up @@ -68,8 +81,6 @@
%}
```

<<<<<<< HEAD
=======
* Implement hints on field_arithmetic lib (Part 2) [#1004](https://github.com/lambdaclass/cairo-rs/pull/1004)

`BuiltinHintProcessor` now supports the following hint:
Expand Down Expand Up @@ -128,7 +139,6 @@
ids.x_inverse_mod_p.high = x_inverse_mod_p_split[1]
```

>>>>>>> fb731257da6fc2842abff103fccab964ae87bb38
* BREAKING CHANGE: Fix `CairoRunner::get_memory_holes` [#1027](https://github.com/lambdaclass/cairo-rs/pull/1027):

* Skip builtin segements when counting memory holes
Expand Down Expand Up @@ -869,4 +879,4 @@
* `pub fn from_vm_error(runner: &CairoRunner, error: VirtualMachineError, pc: usize) -> Self` is now `pub fn from_vm_error(runner: &CairoRunner, vm: &VirtualMachine, error: VirtualMachineError) -> Self`
* `pub fn get_location(pc: &usize, runner: &CairoRunner) -> Option<Location>` is now `pub fn get_location(pc: usize, runner: &CairoRunner) -> Option<Location>`
* `pub fn decode_instruction(encoded_instr: i64, mut imm: Option<BigInt>) -> Result<instruction::Instruction, VirtualMachineError>` is now `pub fn decode_instruction(encoded_instr: i64, mut imm: Option<&BigInt>) -> Result<instruction::Instruction, VirtualMachineError>`
* `VmExcepion` field's string format now mirror their cairo-lang conterparts.
* `VmExcepion` field's string format now mirror their cairo-lang conterparts.
11 changes: 9 additions & 2 deletions cairo_programs/ec_recover.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ func test_sub_a_b_hint{range_check_ptr: felt}() {
return();
}

func test_product_mod_hint{range_check_ptr: felt}() {
func test_product_hints{range_check_ptr: felt}() {

tempvar a = BigInt3(60, 0, 0);
tempvar b = BigInt3(2, 0, 0);
Expand All @@ -64,12 +64,19 @@ func test_product_mod_hint{range_check_ptr: felt}() {
let (res) = nondet_bigint3();
assert res = BigInt3(20,0,0);

%{
value = k = product // m
%}

let (k) = nondet_bigint3();
assert k = BigInt3(1,0,0);

return();
}

func main{range_check_ptr: felt}() {
test_div_mod_n_packed_hint();
test_sub_a_b_hint();
test_product_mod_hint();
test_product_hints();
return();
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
use super::{
ec_recover::{ec_recover_divmod_n_packed, ec_recover_product_mod, ec_recover_sub_a_b},
ec_recover::{
ec_recover_divmod_n_packed, ec_recover_product_div_m, ec_recover_product_mod,
ec_recover_sub_a_b,
},
field_arithmetic::uint384_div,
vrf::{fq::uint512_unsigned_div_rem, inv_mod_p_uint512::inv_mod_p_uint512},
};
Expand Down Expand Up @@ -606,6 +609,7 @@ impl HintProcessor for BuiltinHintProcessor {
hint_code::EC_RECOVER_PRODUCT_MOD => {
ec_recover_product_mod(vm, exec_scopes, &hint_data.ids_data, &hint_data.ap_tracking)
}
hint_code::EC_RECOVER_PRODUCT_DIV_M => ec_recover_product_div_m(exec_scopes),
#[cfg(feature = "skip_next_instruction_hint")]
hint_code::SKIP_NEXT_INSTRUCTION => skip_next_instruction(vm),
code => Err(HintError::UnknownHint(code.to_string())),
Expand Down
45 changes: 43 additions & 2 deletions src/hint_processor/builtin_hint_processor/ec_recover.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use crate::{
types::exec_scope::ExecutionScopes,
vm::{errors::hint_errors::HintError, vm_core::VirtualMachine},
};
use num_bigint::BigInt;

/* Implements Hint:
%{
Expand Down Expand Up @@ -87,13 +88,28 @@ pub fn ec_recover_product_mod(
let m = bigint3_pack(BigInt3::from_var_name("m", vm, ids_data, ap_tracking)?);

let product = a * b;
exec_scopes.insert_value("product", product.clone());
let value = product.mod_floor(&m);
exec_scopes.insert_value("product", product);
exec_scopes.insert_value("m", m);
exec_scopes.insert_value("value", value.clone());
exec_scopes.insert_value("res", value);
Ok(())
}

/* Implements Hint:
%{
value = k = product // m
%}
*/
pub fn ec_recover_product_div_m(exec_scopes: &mut ExecutionScopes) -> Result<(), HintError> {
let product: &BigInt = exec_scopes.get_ref("product")?;
let m: &BigInt = exec_scopes.get_ref("m")?;
let value = product.div_floor(m);
exec_scopes.insert_value("k", value.clone());
exec_scopes.insert_value("value", value);
Ok(())
}

#[cfg(test)]
mod tests {
use num_bigint::BigInt;
Expand Down Expand Up @@ -226,8 +242,33 @@ mod tests {
[
("value", BigInt::from(20)),
("res", BigInt::from(20)),
("product", BigInt::from(120))
("product", BigInt::from(120)),
("m", BigInt::from(100))
]
);
}

#[test]
#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test)]
fn run_ec_recover_product_div_m_ok() {
let mut vm = vm!();
let mut exec_scopes = ExecutionScopes::new();
exec_scopes.insert_value("product", BigInt::from(250));
exec_scopes.insert_value("m", BigInt::from(100));

let ids_data = ids_data!["none"];

assert!(run_hint!(
vm,
ids_data,
hint_code::EC_RECOVER_PRODUCT_DIV_M,
&mut exec_scopes
)
.is_ok());

check_scope!(
&exec_scopes,
[("value", BigInt::from(2)), ("k", BigInt::from(2))]
);
}
}
2 changes: 2 additions & 0 deletions src/hint_processor/builtin_hint_processor/hint_code.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1044,5 +1044,7 @@ product = a * b
m = pack(ids.m, PRIME)

value = res = product % m"#;

pub const EC_RECOVER_PRODUCT_DIV_M: &str = "value = k = product // m";
#[cfg(feature = "skip_next_instruction_hint")]
pub const SKIP_NEXT_INSTRUCTION: &str = "skip_next_instruction()";