class SmartSpiral(ScanPlanner): (source)
Constructor: SmartSpiral(initial_position, planner_settings)
A scan planner that spirals outward from the centre, prioritising short moves.
This planner spirals out from the centre, but prioritises short moves over rigidly sticking to minimising radius from the centre of the scan.
Each time and image is taken the four neighbouring images are added to the list of positions to image (unless they are already listed or tried). However, if a location is not imaged due no sample being detected then neibouring positions are not imaged.
The next image taken is the closes to the centre (considering the largest of vertical or horizontal distance), ties are broken by the distance from the current position.
| Method | get |
Return the next location to scan and its estimated z-position. |
| Method | mark |
Mark the location as visited. Adjust extra positions accordingly. |
| Method | moves |
Return the larger of x moves or y moves between two xy positions. |
| Method | select |
Return the xyz position of the nearby site with the lowest z position. |
| Method | _add |
Add the 4 surrounding positions to the list of remaining locations to visit. |
| Method | _initial |
Set the initial list of locations for this scan planner. |
| Method | _parse |
Parse SmartSpiral Settings dictionary. |
| Method | _re |
Sort the remaining positions based on the current location. |
| Instance Variable | _dx |
Undocumented |
| Instance Variable | _dy |
Undocumented |
| Instance Variable | _max |
Undocumented |
Inherited from ScanPlanner:
| Method | __init__ |
Set up lists for the path planning, and scan history. |
| Method | closest |
Return the xyz position of the closest site where focus was achieved. |
| Method | position |
Return True if input xy position is planned. |
| Method | position |
Return True if input xy position has been visited before. |
| Property | focused |
Property to access a copy of the focused_locations. |
| Property | imaged |
Property to access a copy of the imaged_locations. |
| Property | path |
Property to access a copy of the path_history. |
| Property | remaining |
Property to access a copy of the remaining_locations. |
| Property | scan |
Return True if there are no locations left to scan. |
| Instance Variable | _focused |
Undocumented |
| Instance Variable | _imaged |
Undocumented |
| Instance Variable | _initial |
Undocumented |
| Instance Variable | _path |
Undocumented |
| Instance Variable | _remaining |
Undocumented |
Return the next location to scan and its estimated z-position.
This overrides the default behaviour of ScanPlanner to take the lowest value of nearest neighbours as this works best for smart stack.
Note z-position may be None! This indicates that the current z position should be used.
XYZPos, imaged: bool = True, focused: bool = True):
(source)
¶
Mark the location as visited. Adjust extra positions accordingly.
- Args:
- xyz_pos: the x_y_z position imaged: true if an image was taken, false if not (due to background detect) focused: true if autofocus completed successfully
Return the xyz position of the nearby site with the lowest z position.
Lowest position is best, as starting too high causes smart stacking to autofocus and restart. Starting too low just requires extra movements in +z. Nearby is defined as within NEIGHBOUR_CUTOFF times the distance to the closest neighbour.
Returns None if there if no focused locations are present
Add the 4 surrounding positions to the list of remaining locations to visit.
This adds the surrounding positions (with 4 point connectivity) to the remaining locations list if they are not:
- too far away
- already planned
- already visited
Set the initial list of locations for this scan planner.
This is salled on initialisation.
For smart spiral this is just the first point
Parse SmartSpiral Settings dictionary.
- dx - the movement size in x
- dy - the movement size in y
- max_dist - The maximum distance to a location can be from the centre.