Interface CrystFEL with Karabo and allow automatic parameter tunning with rcrystfel
- Added
CrystFELRunner
to serve as an interface between Karabo and CrystFEL, and allow for automatic parameter optimization using rcrystfel. - Added
PickyBoi
, which selects a set of trains to be sent forth for further processing. - Added
PpuKernel
-
CrystFELRunner
receives all command line options in a single vector of strings (crystfelArgs.misc
). -
CrystFELRunner
cleanly frees all resources after stopping CrystFEL. - If an end-of-stream message is sent (ie: by
PickyBoi
), CrystFEL is automatically stopped. -
CrystFELRunner
collects results of CrystFEL and shows them as properties (more may be added later). -
CrystFELRunner
generates temporary geometry files based on its contents if the slotbuildGeometry
is called with a list of strings. -
PickyBoi
now has a propertybreakStreamAfterEnd
, which sends an end-of-stream message to all clients, alertingCrystFELRunner
s to stop CrystFEL automatically.
Other (by @hammerd, and about which I have no clue) -- this should be checked by @hammerd to avoid disaster:
-
BaseArbiterKernel
,ShmemTrainMatcher
,DetectorAssembler
andFrameSelectionArbiter
have also been changed, relative tomaster
. - Many changes in the correction classes.
Merge request reports
Activity
requested review from @hammerd
added 2 commits
I was just thinking to suggest that someone review PickyBoi first. Then we merge that into
master
* (maybe after cherry-picking tweaks to it from this branch) and can focus on theCrystfelRunner
which is the main contribution here.*Or
PickyBoi
goes into a different package entirely because it's useful outside ofcalng
. I think Philipp suggested that may be relevant. It's also not entirely obvious whether theCrystfelRunner
needs to be part of corecalng
(I just make devices in the package I'm editing anyway)...Yes, after posting I realized there's no need to have this in
calng
package. It's not required in almost all installations, and where it's usedcalng
proper is actually not needed. In Karabo, large device packages are also somewhat discouraged.I suggested the same for the
PickyBoi
given its much more general use, like the train matcher.Sure thing, now CrystFEL integration and PickyBoi are their own repositories. I've just moved the current version of each from this branch as their respective initial commits. I would suggest opening a "cleanup" MR on each to stage reviews before tagging for production.
Having moved them out, this branch now mostly contains a few fixes here and there. Can either point to
master
or the train picker MR (which is now just adding the arbiter kernel). Can also close and apply the small fixes separately; will definitely squash either way.Edited by David Hammer
mentioned in merge request !47 (closed)
mentioned in commit 8e1508ca
mentioned in commit 3944f163