There are three different ways to get quasi real time information about data taking. They offer different pros and cons and the final choice about which method works best for a given experiments is left to the users.
The approaches are:
AMI can display the raw/calibrated detector data in real time and it can calculate and display some simple quantities without writing any code. Analyses are configured through a GUI with just a few mouse clicks. A guide to using AMI can be found here.
Pros: excellent real time capabilities (< 1s); very simple to use for simple analysis.
Cons: it can be tricky/impossible to save&load complicated analyses, need fast X-connection to setup as it is GUI driven.
The LCLS data acquisition system can allocate processes, called shared memory servers, which receive the detector data through the network, build these contributions into events, and then hand over these events to one or more clients running on the same monitoring machine. The clients can be written in any language that can access shared memory. The most common frameworks adopted in LCLS as shared memory clients are CASS, OnDA and psana.
Pros: excellent real time capabilities (< 1s); ability to run the same code online and offline.
Cons: if not using pre-existing software, requires very large time investment from both LCLS and the user. competes with AMI resources (monitoring nodes, data stream); requires setting up the shared memory servers on the DAQ side.
This method of analysis reads the detector data from a fast storage layer called fast feedback (FFB), dedicated to the running experiment, and runs a prepared analysis. Any framework which can read XTC files can be adopted to run as a fast feedback application. The most common framework used with this method is psana.
Pros: trivial to setup; independent of the DAQ; ability to run the same code online and offline.
Cons: not quite real time (~<1 minutes after the run has ended using the LCLS supported framework).