-
Notifications
You must be signed in to change notification settings - Fork 28
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
campaign.recollate() produces an error; is there a more elegant solution for delayed collation (or recollation) than the hack used below? #369
Comments
What is the use case here? |
I first encountered the problem when analysing a crash somebody was experiencing, which was related to the first element of the vector (for every sample) being identical, and thus having a variance of zero. The ultimate fix was to prevent the divide by zero destroying the calculation of the remaining good quantities, but as a temporary fix I tried to edit the output CSV files and then tried to force a recollate -- resulting in the pasted error message. I now have a use case where running the cases takes significant time and user intervention so I essentially have a split workflow:
I might also choose to analyse a different subset of the output data from SOLPS, producing a new output CSV file in step 2, and then needing to redo step 3. The most suggestive option in the campaign description seemed to be the .recollate() method, which no longer works. I have found a work-around but it is not clean. |
Is it not possible to do 2. as part of an EasyVVUQ workflow? |
In principle, yes. In practise, no. While parts could be automated with a script do all of 1, 2 & 3, the decision whether to continue runs is still made manually. It is also useful to re-use the existing runs, just changing the QOIs which involves running a very small analysis code that transforms the large amount of data output from SOLPS into a different output.csv file. |
In the particular case it takes about 1 weeks to run the SOLPS cases. In other cases it might take months -- which would require that the EasuVVUQ driver needs to be hanging around for that length of time (which cannot be guaranteed given the systems people wanting to install security patches periodically) |
The basic idea would be as follows - create an actions chain that does the first part and a separate one that does the third part. Set the first part as active_app, run execute. Then set the third part as active_app and run execute again. The first chain will do the set-up. The second chain decoding, etc. In between do your thing. There might be some finer details I am missing but I've tested this in the past and it works. Best if you try and show me a partial solution along those lines then we can figure out what else needs to be done. Even if it takes months you can always resume from the database. All the actions chains are stored in the database as well (as serialized objects). |
I tried that:
and I then tried a second block (new program)
but was not able to get this to work ... |
well it needs to work, so we need to figure out why that is and how to prevent it |
What exactly doesn't work? Looking at the code again I see that I've added changes precisely for this case (for example the run status will only be set to collated after the Decode action is executed). |
My recollection is that it wasn't clear how to tell the system that the actions had to be replaced with a new set of actions ... |
Simplest way is to use the "replace_actions" method of the Campaign. It is by itself hacky but simple. Line 270 in efa9795
|
I would have sworn that I tried that and it didn't work -- but I have just tried it again and it worked! Thanks! |
Using campaign.recollate() produces the error
'Campaign' object has no attribute 'collate'
as shown in
Indeed collate now seems to be part of actions/action_statuses.py,
Is there any clean way of recollating (or collating at a later stage)?
I am currently using the hack
which works but is, as I said above, a hack.
Is there a more elegant solution?
The text was updated successfully, but these errors were encountered: