Skip to content

Latest commit

 

History

History
192 lines (179 loc) · 18.8 KB

CHANGELOG.md

File metadata and controls

192 lines (179 loc) · 18.8 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog.

Unreleased

Changed

  • The offset attribute of Pickup, Drop, Aspirate, and Dispense dataclasses are now always wrt the center of its resource.
  • The offset parameter is no longer optional in Pickup, Drop, Aspirate, and Dispense dataclasses. With LiquidHandler it defaults to Coordinate(0, 0, 0).
  • When providing offsets to LH, individual items in the offsets list are no longer optional. They must be provided as Coordinate objects. The offsets list itself is still optional and defaults to [Coordinate(0, 0, 0)]*len(use_channels).
  • To aspirate from a single resource with multiple channels, you must now provide that single resource in a list when calling LiquidHandler.aspirate and LiquidHandler.dispense.
  • The non-firmware level commands of STAR now take parameters in PLR-native units (mm, uL, mg, etc.) instead of the mixture of PLR-native and firmware-native units (0.1mm, 0.1uL, etc.) that were previously used. The affected commands are pick_up_tips, drop_tips, aspirate, dispense, pick_up_tips96, drop_tips96, aspirate96, dispense96, iswap_pick_up_resource, iswap_move_picked_up_resource, iswap_release_picked_up_resource, core_pick_up_resource, core_move_picked_up_resource, core_release_picked_up_resource, move_resource, and core_check_resource_exists_at_location_center (#191).
  • Also for Vantage, the units of the parameters are now in PLR-native units instead of the mixture of PLR-native and firmware-native units (0.1mm, 0.01uL, 0.1uL, etc.) that were previously used. The affected commands are pick_up_tips, drop_tips, aspirate, dispense, pick_up_tips96, drop_tips96, aspirate96, dispense96, pick_up_resource, and release_picked_up_resource.
  • Fixed well z position: now it actually refers to the distance between the bottom of the well (including the material) and the bottom of the plate. Before, it sometimes mistakenly referred to what is now material_z_thickness (#183).
  • A resource's origin (lfb) is not changed on rotation, it is always fixed locally (#195). Before, we updated the location after 90, 180, and 270 degree rotations.
  • Resource.rotate and Resource.rotated now support all planes and all angles (before it was limited to 90 degree rotations around the z axis) (#195)
  • Resource children will not be relocated when the parent resource is rotated (#195)
  • Resource.rotation attribute is now a Rotation object (#195)
  • Parameters to higher-level STAR commands may be ints or floats, and will be converted to int when passed to the firmware-level commands.
  • ItemizedResource now supports arbitrary patterns, not just full grids (#201):
    • Parameter items of ItemizedResource.__init__ is deprecated in favor of ordered_items.
    • Rename parameter identifier of ItemizedResource.get_items to identifiers.
    • Attributes ItemizedResource.num_items_x and ItemizedResource.num_items_y are now computed, and raise an error when the grid is not rectangular/full.
    • ItemizedResource now serializes "ordering", and not "num_items_x" and "num_items_y".
  • Merge height_functions.py and volume_functions.py into height_volume_functions.py (#200)
  • Type checking for lh.pick_up_tips, lh.drop_tips, lh.aspirate, and lh.dispense and 96-channel versions.
  • ChatterBoxBackend outputs are now pretty (#208)
  • liquid_height now defaults to 0 instead of 1 (#205)
  • material_z_thickness of a Container is used in computing its bottom (#205)
  • Default pickup_distance_from_top in LiquidHandler.{move_plate,move_lid} were lowered by 3.33 (#205)
  • PlateCarrierSite can now take ResourceStack as a child, as long as the children are Plates (#226)
  • Resource.get_size_{x,y,z} now return the size of the resource in local space, not absolute space (#235)
  • Resource.center now returns the center of the resource in local space, not absolute space (#235)
  • Rename ChatterBoxBackend to LiquidHandlerChatterboxBackend (#242)
  • Move LiquidHandlerChatterboxBackend from liquid_handling.backends.chatterbox_backend to liquid_handling.backends.chatterbox (#242)
  • Changed pedestal_size_z=-5 to pedestal_size_z=-4.74 for PLT_CAR_L5AC_A00 (#255)
  • rename homogenization_ parameters in STAR to mix_ (#261)
  • Lids no longer get special treatment when assigned to a ResourceStack. Assign them to a plate directly (#267)
  • Machine no longer inherits from Resource (#281)
  • ResourceHolderMixin is renamed to ResourceHolder and now inherits from Resource (#281)
  • You can now place resources on 'rail' 0 on Hamilton decks (left support doesn't touch rail)
  • rename STAR.move_iswap_{x,y,z}_direction to STAR.move_iswap_{x,y,z}_relative. Change units to mm. Infer direction. (#295)
  • STAR.request_iswap_position returns loc in mm (#296)
  • STAR.{position_max_free_y_for_n,request_y_pos_channel_n,request_z_pos_channel_n} are 0-indexed and return in mm (#260)
  • Rename STAR.probe_z_height_using_channel to STAR.clld_probe_z_height_using_channel and use 0-based indexing for channels (#260)
  • ResourceCarrierSite -> ResourceHolder, PlateCarrierSite -> PlateHolder (#280)
  • Carrier.sites is now a dictionary (#280)
  • create_carrier_sites->create_resources (site_size_{x,y}->resource_size_{x,y}) (#280)
  • MFXCarrier takes modules as direct children, instead of having CarrierSites as intermediaries (#280)
  • Config.log_dir is now optional and defaults to None (#302)
  • Definition of Cor_6_wellplate_16800ul_Fb to match the manufacturer spec (#311)
  • Trash now inherits from Container (#318)
  • Renamed parameters of LiquidHandler.move_{resource,plate,lid} (#328)
    • resource_offset -> pickup_offset
    • get_direction -> pickup_direction
    • put_direction -> drop_direction
  • location parameter of assign_child_resource is not optional (#336)
  • Resource.get_absolute_location raises NoLocationError instead of AssertionError when absolute location is not defined (#338)
  • no_trash and no_teaching_rack were renamed to with_trash and with_teaching_rack to avoid double negatives (#347)

Added

  • Cor_96_wellplate_360ul_Fb plate (catalog number 3603)
  • Add attribute material_z_thickness: Optional[float] to Containers (#183).
  • Coordinate.vector() to return a 3-item list of floats.
  • Rotation class to represent a rotation in 3D space (#195)
  • Resource.get_absolute_rotation() to get the absolute rotation of a resource (#195)
  • pedestal_size_z to PLT_CAR_L5MD and PLT_CAR_L5MD_A00 (#198).
  • create_ordered_items_2d, similar to create_equally_spaced_2d, but a dictionary keyed by the item's position identifier in the grid (#201)
  • CellTreat_96_DWP_350ul_Ub and CellTreat_6_DWP_16300ul_Fb (#200)
  • Opentrons_96_adapter_Vb to integrate Opentrons Aluminum 96-well plate adapter (part of the "Aluminum Block Set") and README.md for Opentrons resource folder
  • Serialization of functions. Serialize compute_volume_from_height and compute_height_from_volume functions in Containers (#215)
  • Eppendorf_96_wellplate_250ul_Vb (#215)
  • Thermo_TS_96_wellplate_1200ul_Rb (#215)
  • Thermo_AB_96_wellplate_300ul_Vb_EnduraPlate (#215)
  • adapter_hole_size_z and plate_z_offset parameters to PlateAdapter (#215)
  • wide_high_volume_tip_with_filter and HTF_WIDE (#222)
  • Serialize code cells and closures (#220)
  • Container.get_anchor() now supports "cavity_bottom" as an argument for z (#205)
  • pylabrobot.resources.utils.query for basic querying (https://github.com/PyLabRobot/pylabrobot/commit/4a07f6a32a9a33d0370eb9c29015567c98aea002)
  • HamiltonLiquidHandler.allow_firmware_planning to allow STAR/Vantage to plan complex liquid handling operations automatically (may break hardware agnosticity unexpectedly) (#224)
  • size_z and nesting_z_height for Cor_96_wellplate_360ul_Fb_Lid (#226)
  • NestedTipRack (#228)
  • HTF_ULTRAWIDE, ultrawide_high_volume_tip_with_filter (#229)
  • get_absolute_size_x, get_absolute_size_y, get_absolute_size_z for Resource (#235)
  • Cytation5Backend for plate reading on BioTek Cytation 5 (#238)
  • More chatterboxes (#242)
    • FanChatterboxBackend
    • PlateReaderChatterboxBackend
    • PowderDispenserChatterboxBackend
    • PumpChatterboxBackend
    • PumpArrayChatterboxBackend
    • ScaleChatterboxBackend
    • ShakerChatterboxBackend
    • TemperatureControllerChatterboxBackend
  • Add fluorescence reading to Cytation 5 (#244)
  • Add F.linear_tip_spot_generator and F.randomized_tip_spot_generator for looping over tip spots, with caching (#256)
  • Add skip_autoload, skip_iswap, and skip_core96_head flags to STAR.setup (#263)
  • Add skip_autoload, skip_iswap, and skip_core96_head flags to Vantage.setup (#263)
  • Resource.get_highest_known_point (#284)
  • BioRad_384_DWP_50uL_Vb (https://github.com/PyLabRobot/pylabrobot/commit/251c3c274040cdac73cd3baf3a1e9c94c2f368c3)
  • Support for portrait mode iSWAP (#291)
  • STAR.{rotate_iswap_wrist,rotate_iswap_rotation_drive} (#298)
  • STAR.request_pip_channel_version
  • STAR.ztouch_probe_z_height_using_channel for getting z-height by probing without cLLD (#260)
  • nest_8_troughplate_22000uL_Vb and nest_12_troughplate_15000uL_Vb (#312)
  • Cor_12_wellplate_6900ul_Fb, Cor_24_wellplate_3470ul_Fb and Cor_48_wellplate_1620ul_Fb (#311)
  • ignore_collision parameter to HamiltonDeck.assign_child_resource (#317)
  • AGenBio_1_troughplate_100000uL_Fl (#319)
  • MFX_DWP_module_flat (#320)
  • STAR.position_channels_in_y_direction (#324)
  • {Well,TipSpot}.get_identifier (#327)
  • LiquidHandler{Backend}.{pick_up_resource,move_picked_up_resource,drop_resource} (#328)
    • Resource management (#343)
  • Access2 loader for vspin (#308)
  • CentrifugeChatterboxBackend and LoaderChatterboxBackend (#335)
  • Add support for TF cytomat C6000, C2C_50, C2C_425, C2C_450_SHAKE, C5C (#332)
  • Add resource_size_z parameter to create_homogeneous_resources and create_resources` (#341)
  • More backend kwargs for iswap movements on STAR: (#343)
    • STAR.pick_up_resource:
      • iswap_grip_strength: int = 4
      • minimum_traverse_height_at_beginning_of_a_command: Optional[float] = None
      • z_position_at_the_command_end: Optional[float] = None
      • plate_width_tolerance: float = 2.0
      • hotel_open_gripper_position: Optional[float] = None
      • hotel_depth=160.0
      • hotel_clearance_height=7.5
      • high_speed=False
      • plate_width: Optional[float] = None
      • use_unsafe_hotel: bool = False
      • iswap_collision_control_level: int = 0
      • iswap_fold_up_sequence_at_the_end_of_process: bool = True
    • STAR.drop_resource
      • minimum_traverse_height_at_beginning_of_a_command: Optional[float] = None
      • z_position_at_the_command_end: Optional[float] = None
      • hotel_open_gripper_position: Optional[float] = None
      • hotel_depth=160.0
      • hotel_clearance_height=7.5
      • hotel_high_speed=False
      • use_unsafe_hotel: bool = False
      • iswap_collision_control_level: int = 0
  • with_trash96 on HamiltonSTARDeck so there is more fine grained control (#347)
  • add STAR.{get_channels_z_positions, position_channels_in_z_direction} (#356)
  • STAR.step_off_foil (#357)
  • make_space param to position_channels_in_y_direction (#369)

Deprecated

  • All VENUS-imported Corning-Costar plates, because they don't have unique and usable identifiers, and are probably wrong.
  • Passing single values to LiquidHandler pick_up_tips, drop_tips, aspirate, and dispense methods. These methods now require a list of values.
  • utils.positions: string_to_position, string_to_index, string_to_indices, string_to_pattern.
  • ThermoScientific_96_DWP_1200ul_Rd in favor of Thermo_TS_96_wellplate_1200ul_Rb (#215)
  • Azenta4titudeFrameStar_96_wellplate_skirted in favor of Azenta4titudeFrameStar_96_wellplate_200ul_Vb (#205)
  • Cos_96_DWP_2mL_Vb in favor of Cos_96_wellplate_2mL_Vb (https://github.com/PyLabRobot/pylabrobot/pull/205/)
  • Resource definitions with _L and _P, it is easy enough to use the stem and .rotated(z=90) for _P (#288)
  • Cor_6_wellplate_Fl (#311)
  • AGenBio_1_wellplate_Fl -> AGenBio_1_troughplate_190000uL_Fl, AGenBio_4_wellplate_Vb -> AGenBio_4_troughplate_75000_Vb (#319)

Fixed

  • Don't apply an offset to rectangle drawing in the Visualizer.
  • Fix Opentrons resource loading (well locations are now lfb instead of ccc)
  • Fix Opentrons backend resource definitions: Opentrons takes well locations as ccc instead of lfb
  • Fix ThermoScientific_96_DWP_1200ul_Rd to ThermoScientific_96_wellplate_1200ul_Rd (#183).
  • libusb_package is now an optional dependency.
  • Plates with a skirt are now correctly lowered when placed on plate carriers with a pedestal (#205)
  • minimum_height in STAR and Vantage now correctly refer to a Containers bottom instead of being a function of liquid height (#205)
  • aspirate96 and dispense96 type check
  • fix angles computed by grip directions (#234)
  • picking up rotated resources in STAR (#233)
  • picking up rotated resources in Vantage (#268)
  • assigning rotated resources to PlateReader now have the correct location (#233)
  • use local sizes in computing anchor (#233)
  • don't raise a blow out air volume error when requesting 0, or when volume tracking is disabled (#262)
  • fix get_child_location for resources rotated by 180 degrees (#269)
  • volume tracking on channel 1-n (#273)
  • correct trash location on Vantage (#285)
  • Resource.get_absolute_location includes anchor even if parent is None
  • unassign from parent if resource is re-assigned (#333)

Removed

  • HamiltonDeck.load_from_lay_file
  • hamilton_parse module and the VENUS labware database parser.
  • PLT_CAR_L4_SHAKER was removed in favor of MFX_CAR_L5_base (#188).
  • items, num_items_x and num_items_y attributes of ItemizedResource (#231)
  • report is no longer a parameter of PlateReader.read_absorbance (default is now OD) (#238)