IntersectMBO/plutus
View on GitHubThe evaluate-builtins optimization isn't conservative
Open
#6,167 opened on Jun 3, 2024
Good first issueInternalPlutus IRbugoptimizationstatus: triagedtech debt
Repository metrics
- Stars
- (1,637 stars)
- PR merge metrics
- (Avg merge 6d 1h) (15 merged PRs in 30d)
Description
PlutusIR.Transform.EvaluateBuiltins turns ifThenElse True x y into x. That is not conservative: if y throws then the former term will throw and the latter one won't. So this is a bug that needs to be fixed. It wasn't discussed in the original PR.
More importantly, this looks like something that the proper property testing should catch. Look like a perfect opportunity for the PIR generators to show their power. So it'd be best to first write a failing property, then fix the bug.