-
Notifications
You must be signed in to change notification settings - Fork 4
Calc height function
Height adjustment
Due to the unavailability of liquid detection on the tip's edge, height position from which the pipette must aspirate has to be fed as a parameter. Going directly to the bottom of each well is not a good mean of procedure, as it could touch the bottom of the well and not aspirate correctly the needed amount of reactive volume, neither sinking the tip to the bottom edge which would induce the flooding of the pipette itself and prompt its malfunction. Furthermore, each reactive container can have different shapes and sizes, which makes the task of calculating the aspiration height non trivial.
For this reason, the shape of the container and the unusable volume are fed as parameters within this function in order to calculate the exact height of the reactive surface in the well and then the height at which the surface will remain after the aspiration, which in turn would be the depth at which the tip should be submerged as shown in Fig. XX. Indeed, wetting of the tip is minimized, reducing the risk of droplet formation.
As a further iteration, when one container is not enough for all the samples and multiple containers are used to hold all the needed volume. For this reason, the robot must know when should it change from one container to the following one. To achieve this container swap, the containers’ addresses [Reactive.reagent_reservoir] are stored within the reactive class and a column counter [Reactive.col] controls which container should it aspirate volume from, giving the robot the knowledge of the remaining volume in each of the wells [Reactive.vol_well] and allowing an easy swap between containers.
The function is called as follows:
[pickup_height, change_col] = calc_height(reagent, cross_section_area, aspirate_volume, min_height = 0.5)
It returns the pickup_height in mm and the variable change_col that indicates whether the system needs change the column of the reagent location because it's empty. The change_col variable is useful if you want to perform an action when this happens. For example mixing the new origin of reagent location before start pipetting from it.
The function accepts the following parameters:
**Parameters**
reagent (obj): A reagent object that contains the relevant information about that liquid, including its location.
cross_section_area (int): The cross section area of a container. Usually defined once at the beginning of the code.
aspirate_volume (int): Amount in µl that we want to aspirate from the origin location.
min_height (float): This is the minimum height in mm that the function will return. If it calculates a height lower than this value it will return this value. This is done to avoid collisions with the bottom of a container. Default is 0.5.
Example
# Calculate pickup_height based on remaining volume and shape of container
[pickup_height, change_col] = calc_height(reagent = Beads,
cross_section_area = multi_well_rack_area,
aspirate_volume = 150,
min_height=1)
if change_col == True: # If we switch column because there is not enough volume left in current reservoir column we mix new column
custom_mix(m300, Beads, Beads.reagent_reservoir[Beads.col],
vol=180, rounds=10, blow_out=True, mix_height=0,
x_offset = x_offset)
# We move the liquid, notice that we used the calculated pickup_height
move_vol_multichannel(m300, reagent=Beads, source=Beads.reagent_reservoir[Beads.col],
dest=work_destinations_cols[i], vol=150,
air_gap_vol=air_gap_vol, x_offset=x_offset,
pickup_height=pickup_height, disp_height = -2,
rinse=rinse, blow_out = True, touch_tip=False)