Speed things up? has_equal_x: make copy=False the default?
filipsch opened this issue · 2 comments
Every time an SCT uses has_equal_value()
, has_equal_output()
or has_equal_error()
, by default it sets copy = True
, which means that all variables that are in the environment are copied over to a new environment in which the actual focused expression is executed. This was done to make sure there were no nasty side effects of running expressions that were focused on, but from an efficiency standpoint is pretty terrible. I wonder what would happen if we'd make copy=False
the default, and somehow figure out which exercises need the explicit copy=True
value set. The performance benefits could be huge, but we should proceed with care. FYI, There are 64 exercises that use copy=False
.
@machow do you have any thoughts on this?
This one seems tricky, since I think issues that pop up will come from running submissions that are different from the solution code--so won't be picked up by the validator.
On the other hand, it seems possible that setting copy = True was just way too defensive, and the concern I just mentioned is purely theoretical :p
One way to check might be to make a branch for a course that runs a lot of these SCTs, and then kick the tires on some of the exercises. I'm happy to spend 30 mins or so trying different submissions