class AutofocusThing(lt.Thing): (source)
The Thing concerned with combinations of z axis movements and the camera.
Actions here involve moving a stage in z, and using the camera to either capture images (generally, z-stacking) and measuring the sharpness of the field of view to assess focus (autofocus and testing the success of a z-stack)
| Method | capture | Capture another image and return the capture information. | 
| Method | check | Check if the sharpest image in a list of captures is central enough. | 
| Method | fast | Sweep the stage up and down, then move to the sharpest point. | 
| Method | looping | Repeatedly autofocus the stage until it looks focused. | 
| Method | reset | Return to the initial z position and run a looping autofocus. | 
| Method | run | Run a smart stack. | 
| Method | save | Save the required captures to disk. | 
| Method | z | Make a move (or a series of moves) and monitor sharpness. | 
| Method | z | Capture a series of images checking that sharpest image central. | 
| Class Variable | stack | Distance in steps between images in a z-stack. | 
| Class Variable | stack | The number of images to save in a stack. | 
| Class Variable | stack | The minimum number of images to capture in a stack. | 
CameraClient, stage: Stage, buffer_max: int) -> CaptureInfo:
    
      
      (source)
    
    
      
      
      ¶
    
  Capture another image and return the capture information.
The capture is stored by the camera Thing, and can be saved by ID.
| Parameters | |
| cam: CameraClient | Camera Dependency to be passed through from the calling action | 
| stage: Stage | Stage Dependency to be passed through from the calling action | 
| buffer int | The maximum number of images to tell the camera to keep in memory for saving once the stack is complete | 
| Returns | |
| CaptureInfo | A CaptureInfo object containing the capture information including its camera buffer_id needed for saving. | 
list[) -> tuple[:
    
      
      (source)
    
    
      
      
      ¶
    
  Check if the sharpest image in a list of captures is central enough.
| Parameters | |
| captures: list[ | a list of the capture objects to for testing if the sharpness has converged in the centre | 
| Returns | |
| tuple[ | A tuple with two values: 
 | 
SharpnessMonitorDep, dz: int = 2000, start: Literal[ = 'centre') -> SharpnessDataArrays:
    
      
      (source)
    
    
      
      
      ¶
    
  Sweep the stage up and down, then move to the sharpest point.
This method will will move down by dz/2, sweep up by dz, and then evaluate the position where the image was sharpest. We'll then move back down, and finally up to the sharpest point.
Stage, sharpness_monitor: SharpnessMonitorDep, dz=2000, start: Literal[ = 'centre'):
    
      
      (source)
    
    
      
      
      ¶
    
  Repeatedly autofocus the stage until it looks focused.
This action will run the fast_autofocus action until it settles on a point in the middle 3/5 of its range. Such logic can be helpful if the microscope is close to focus, but not quite within dz/2. It will attempt to autofocus up to 10 times.
list[, autofocus_dz: int, stage: Stage, sharpness_monitor: SharpnessMonitorDep):
    
      
      (source)
    
    
      
      
      ¶
    
  Return to the initial z position and run a looping autofocus.
stage and sharpness_monitor are Thing dependencies passed through from the calling action.
| Parameters | |
| initial list[ | The initial z positions of previous captures | 
| autofocus int | the range in steps to autofocus | 
| stage: Stage | Undocumented | 
| sharpness SharpnessMonitorDep | Undocumented | 
CameraClient, stage: Stage, sharpness_monitor: SharpnessMonitorDep, images_dir: str, autofocus_dz: int, save_resolution: tuple[) -> tuple[:
    
      
      (source)
    
    
      
      
      ¶
    
  Run a smart stack.
A smart stack captures images offset in z, testing whether the sharpest image is towards the centre of the stack.
The sharpest image, and optionally images around the sharpest, will be saved to the images_dir with their coordinates in the filename.
| Parameters | |
| cam: CameraClient | Camera Dependency supplied by LabThings dependency injection | 
| stage: Stage | Stage Dependency supplied by LabThings dependency injection | 
| sharpness SharpnessMonitorDep | Sharpness Monitor Dependency (for focus detection) supplied by LabThings dependency injection | 
| images str | the folder to save all images | 
| autofocus int | the range to autofocus over if a stack fails | 
| save tuple[ | The resolution the images should be saved at, the images will be resampled if this doesn't match the camera's capture resolution | 
| Returns | |
| tuple[ | A tuple containing: 
 | 
int, captures: list[, stack_parameters: StackParams, cam: CameraClient) -> int:
    
      
      (source)
    
    
      
      
      ¶
    
  Save the required captures to disk.
This will save the sharpest image, and optionally extra images either side of focus (see stack_parameters.images_to_save).
| Parameters | |
| sharpest int | the buffer id index of the sharpest image | 
| captures: list[ | a list of captures, including file name, image data and metadata | 
| stack StackParams | a StackParams object holding stack parameters | 
| cam: CameraClient | is a Thing dependency passed through from the calling action | 
| Returns | |
| int | Undocumented | 
SharpnessMonitorDep, dz: Sequence[, wait: float = 0) -> SharpnessDataArrays:
    
      
      (source)
    
    
      
      
      ¶
    
  Make a move (or a series of moves) and monitor sharpness.
This method will will make a series of relative moves in z, and return the sharpness (JPEG size) vs time, along with timestamps for the moves. This can be used to calibrate autofocus.
Each move is relative to the last one, i.e. we will finish at sum(dz) relative to the starting position.
If wait is specified, we will wait for that many seconds between moves.
StackParams, cam: CameraClient, stage: Stage) -> tuple[:
    
      
      (source)
    
    
      
      
      ¶
    
  Capture a series of images checking that sharpest image central.
The images are separated in z offset by stack_parameters.stack_dz, as they are captured the last stack_parameters.min_images_to_test images are checked to see if the sharpest image is central enough in the stack. If it is the stack completes.
| Parameters | |
| stack StackParams | a StackParams object holding stack parameters | 
| cam: CameraClient | Camera Dependency to be passed through from the calling action | 
| stage: Stage | Stage Dependency to be passed through from the calling action | 
| Returns | |
| tuple[ | A tuple of 
 | 
Distance in steps between images in a z-stack.
Suggested values:
- 50 for 60-100x
- 100 for 40x
- 200 for 20x
The minimum number of images to capture in a stack.
This many images are captures and tested for focus, if the focus is not central enough more images may be captured. After new images are captured the number sets the number of images used for checking if focus is central.
Defaults to 9 which balances reliability and speed/