-
Notifications
You must be signed in to change notification settings - Fork 35
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
Make Instruction class immutable #517
Conversation
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.
I like those changes!
Unfortunately, it looks like they are introducing a noticeable performance regression:
https://github.com/dylibso/chicory/actions/runs/10754183983?pr=517
It would be great if you can verify locally if the data is accurate or we are just looking at different machines noise levels.
d0ffa45
to
b40ba24
Compare
I missed a critical place in the interpreter that calls |
b40ba24
to
e5850ea
Compare
e5850ea
to
c12d39f
Compare
This should be fixed now. I added a private |
good catch @andreaTP :) |
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.
Thanks for the double check and the quick fix @electrum
var operands = instruction.operands(); | ||
instance.onExecution(instruction, operands, stack); | ||
Operands operands = instruction::operand; | ||
instance.onExecution(instruction, stack); |
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.
nice clean up!
operands
was redundant here.
@@ -1982,4 +1982,9 @@ private static void checkInterruption() { | |||
throw new ChicoryException("Thread interrupted"); | |||
} | |||
} | |||
|
|||
@FunctionalInterface | |||
private interface Operands { |
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.
I like this trick!
This keeps the
long[]
to avoid boxing, which might have a performance impact for the interpreter. It also adds a constant for the common case of an empty array, which avoids allocations and reduces memory usage.The extra clone for instructions created during parsing could be eliminated by adding a trusted package-private constructor, but I hope we don't need to optimize to that level.