You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
and it turns out merging from a file is let happen although the config node is allegedly frozen. I looked into the code and this makes sense since setattr (which is the only place that actually checks whether the object is immutable) is never called explicitly, but rather lines like this are used instead. Basically in the current, form frozen is only checked for one-time assignments (like cfg.lr=0.1).
There is another behavior which I doubt is intended: judging by the code, both merge_from_list and _merge_a_into_b descent into the tree structure without passing down the immutability information, so one could freeze the global (root) cfg but then be able to modify a grand child of it since the parent hasn't been frozen. Am I missing something? These two points deem freeze() in its current form almost useless.
The text was updated successfully, but these errors were encountered:
I was reading the comments in the issue section and this might help.
From #56 (comment):
YACS also allows you to enforce immutability so that once you've started your experiment/app and you handle user input, everything is frozen. This is very useful for repeatable experiments because you can log/store the config and you should be able to trust that the parameters weren't modified later on.
Basically, it's to avoid a user accidentally modifying some value in the config later on in the experiment. So if a user is already using merge_from_list, they would know that it's a yacs config and intend to modify it anyway. This might not be what freeze() is designed to prevent.
I was just trying to test out the freeze function and did something like this:
and it turns out merging from a file is let happen although the config node is allegedly frozen. I looked into the code and this makes sense since setattr (which is the only place that actually checks whether the object is immutable) is never called explicitly, but rather lines like this are used instead. Basically in the current, form frozen is only checked for one-time assignments (like
cfg.lr=0.1
).There is another behavior which I doubt is intended: judging by the code, both
merge_from_list
and_merge_a_into_b
descent into the tree structure without passing down the immutability information, so one could freeze the global (root) cfg but then be able to modify a grand child of it since the parent hasn't been frozen. Am I missing something? These two points deem freeze() in its current form almost useless.The text was updated successfully, but these errors were encountered: