The single command which matters is ramp nread=N visit=V. Before that is sent you will have the readTime keyword value, which is how long a single read takes. That will be between 5.57 and 11.14 seconds, depending on how we end up configuring reference pixel interleaving ("IRP").
For the purpose of SPS/ICC sequencing it is worth keeping in mind that during a ramp the detector continuously reads out from top to bottom, then immediately continues at the top. That said, we always start a ramp with a reset frame, which takes the same readTime as a real read: the start of your requested ramp will be delayed by one readTime. [ We might want to add more resets under some circumstances, but don't worry about that yet. ]
Part of the puzzle will be whether we can reliably synchronize the read edges with any interesting SPS changes: shutter transitions, lamp transitions, ccd transitions. At worst we will lose a read at the start and a read at the end, because they overlap with shutter or lamp changes. [I have some more detailed notes on this which I will try to recover and merge with these comments. ]
I am nearly certain that we will want to continue taking reads while the ccd are reading out, for two reasons. One is that we will not need to get the relative timings exactly right. And we will be able to get our first measurement of persistence from the exposure.
I still need to understand how to figure out when the first read will start. That may not matter: if we started the ramp along with the ccd wipe (I think we will want to) we can synchronize the shutter/lamp start events after the ramp has started. At which point I think we will know when the first read started. [But remember the reset frame time. ]
Given those various points I suggest that the starting design should be to send the ramp command along with the ccd wipe command (or earlier if possible), and that nread be set to the expected time between the end of the reset frame and the end of the ccd readout. [We need to generate a ccdReadTime keyword, hmm.]
The main keywords are:
- readTime=seconds. The time a single read will take; this should be good to microseconds. This keyword will come when the DAQ is initialized or reconfigured: before you would send any ramp command. A ramp is a completely synchronous sequence of these per-read times.
- read0Start=timestamp. This is the timestamp for when the first read started. I do not yet know how good I can get this, but am guessing to better than 0.1s. Given read0Start and readTime, you can reliably calculate all later transition times. I hope to generate a decent guess for this shortly after the ramp command has been started, but have not yet tried.
- spsFileIds=camName,dateDir,visit,smNum,armNum – same as for ccdActor. When this arrives the visit has been entirely finished and all files flushed and closed. (the camName field is there just for humans, etc.)
- hxRead=visit,readN,ofN – a running report of completed reads. This is generated after any file writes for that read have been flushed.
We will need handle the shutter close, etc. times differently from the CCDs for the purpose of EXPTIME, etc.. There is no clean wipe/read split like for the ccd. I think a shutterClosed keyword similar to the new lampX keywords will have to do.
The single command which matters is ramp nread=N visit=V. Before that is sent you will have the readTime keyword value, which is how long a single read takes. That will be between 5.57 and 11.14 seconds, depending on how we end up configuring reference pixel interleaving ("IRP").
For the purpose of SPS/ICC sequencing it is worth keeping in mind that during a ramp the detector continuously reads out from top to bottom, then immediately continues at the top. That said, we always start a ramp with a reset frame, which takes the same readTime as a real read: the start of your requested ramp will be delayed by one readTime. [ We might want to add more resets under some circumstances, but don't worry about that yet. ]
Part of the puzzle will be whether we can reliably synchronize the read edges with any interesting SPS changes: shutter transitions, lamp transitions, ccd transitions. At worst we will lose a read at the start and a read at the end, because they overlap with shutter or lamp changes. [I have some more detailed notes on this which I will try to recover and merge with these comments. ]
I am nearly certain that we will want to continue taking reads while the ccd are reading out, for two reasons. One is that we will not need to get the relative timings exactly right. And we will be able to get our first measurement of persistence from the exposure.
I still need to understand how to figure out when the first read will start. That may not matter: if we started the ramp along with the ccd wipe (I think we will want to) we can synchronize the shutter/lamp start events after the ramp has started. At which point I think we will know when the first read started. [But remember the reset frame time. ]
Given those various points I suggest that the starting design should be to send the ramp command along with the ccd wipe command (or earlier if possible), and that nread be set to the expected time between the end of the reset frame and the end of the ccd readout. [We need to generate a ccdReadTime keyword, hmm.]
The main keywords are:
We will need handle the shutter close, etc. times differently from the CCDs for the purpose of EXPTIME, etc.. There is no clean wipe/read split like for the ccd. I think a shutterClosed keyword similar to the new lampX keywords will have to do.