-
Notifications
You must be signed in to change notification settings - Fork 226
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: use more efficient field merger code #6815
Conversation
Peak Memory Sample
|
Compilation Report
|
dfg.insert_instruction_and_results(merged_field, block, None, call_stack.clone()) | ||
.first() | ||
} else { | ||
let cast = Instruction::Cast(else_condition, else_type); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Related to this I found that when we were casting to Field
we saved a lot of range constraints implied on the binary operations performed on Unsigned
types. First I thought that must be unsafe as it would mask a potential overflow, but with the c*a + !c*b
formula below it seems safe (or actually it has an else_condition
below, but assuming that they are mutually exclusive).
I assume you're not doing the c * (a-b) + b
trick because of a potential overflow, but isn't it true that mathematically this should be okay, if the cost of the extra Cast
s to Field
would be acceptable?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, we're not concerned about overflows here as the merged value is constrained to then_value
or else_value
and any underflow in the difference term will disappear (This is why we needed to cast to Fields as the integer types imply checked arithmetic)
I did this just for fields in this PR as this doesn't need the inputs to be casted to fields and back (as it's already the correct type).
I think we should wait for #6817 before pushing this further due to negligible changes within the test suite. |
Execution Report
|
Compilation Memory Report
|
Execution Memory Report
|
Changes to circuit sizes
🧾 Summary (10% most significant diffs)
Full diff report 👇
|
Description
Problem*
Resolves
Summary*
This PR replaces the value merger code reverted in #6673 but solely for fields.
Additional Context
Documentation*
Check one:
PR Checklist*
cargo fmt
on default settings.