From d17039a7e8e8aefcb707a9e8a479b5436f412d3f Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 13 Dec 2024 12:08:18 -0500 Subject: [PATCH 01/10] update the shared data defs --- shared-data/command/schemas/7.json | 3 +- .../definitions/1/pipetteModelSpecs.json | 336 +++++++++ .../definitions/1/pipetteNameSpecs.json | 42 ++ .../general/ninety_six_channel/p200/1_0.json | 660 ++++++++++++++++++ .../general/ninety_six_channel/p200/3_0.json | 6 +- .../geometry/ninety_six_channel/p200/1_0.json | 305 ++++++++ .../ninety_six_channel/p1000/default/1_0.json | 51 ++ .../ninety_six_channel/p1000/default/3_6.json | 3 +- .../ninety_six_channel/p200/default/1_0.json | 288 ++++++++ .../ninety_six_channel/p200/default/3_0.json | 152 ++-- 10 files changed, 1769 insertions(+), 77 deletions(-) create mode 100644 shared-data/pipette/definitions/2/general/ninety_six_channel/p200/1_0.json create mode 100644 shared-data/pipette/definitions/2/geometry/ninety_six_channel/p200/1_0.json create mode 100644 shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/1_0.json diff --git a/shared-data/command/schemas/7.json b/shared-data/command/schemas/7.json index 30fe52f96bd..150abdf995f 100644 --- a/shared-data/command/schemas/7.json +++ b/shared-data/command/schemas/7.json @@ -1297,7 +1297,8 @@ "p1000_single_gen2", "p1000_single_flex", "p1000_multi_flex", - "p1000_96" + "p1000_96", + "p200_96" ], "type": "string" }, diff --git a/shared-data/pipette/definitions/1/pipetteModelSpecs.json b/shared-data/pipette/definitions/1/pipetteModelSpecs.json index 6a1eea16bd4..5549371ef61 100644 --- a/shared-data/pipette/definitions/1/pipetteModelSpecs.json +++ b/shared-data/pipette/definitions/1/pipetteModelSpecs.json @@ -10837,6 +10837,342 @@ "quirks": [], "returnTipHeight": 0.83, "idleCurrent": 0.3 + }, + "p200_96_v1": { + "name": "p200_96", + "backCompatNames": [], + "top": { + "value": 0.5, + "min": 0, + "max": 45, + "units": "mm", + "type": "float" + }, + "bottom": { + "value": 71.5, + "min": 55, + "max": 80, + "type": "float", + "units": "mm" + }, + "blowout": { + "value": 76.5, + "min": 60, + "max": 85, + "units": "mm", + "type": "float" + }, + "dropTip": { + "value": 92.5, + "min": 78, + "max": 119, + "units": "mm", + "type": "float" + }, + "pickUpCurrent": { + "value": 0.5, + "min": 0.05, + "max": 2.0, + "units": "amps", + "type": "float" + }, + "pickUpDistance": { + "value": 13, + "min": 1, + "max": 30, + "units": "mm", + "type": "float" + }, + "pickUpIncrement": { + "value": 0.0, + "min": 0.0, + "max": 10.0, + "units": "mm", + "type": "float" + }, + "pickUpPresses": { + "value": 1, + "min": 0, + "max": 10, + "units": "presses", + "type": "int" + }, + "pickUpSpeed": { + "value": 10, + "min": 1, + "max": 30, + "units": "mm/s", + "type": "float" + }, + "nozzleOffset": [-8.0, -16.0, -259.15], + "modelOffset": [0.0, 0.0, 25.14], + "ulPerMm": [ + { + "aspirate": [ + [0.6464, 0.4817, 0.0427], + [1.0889, 0.2539, 0.1591], + [1.5136, 0.1624, 0.2587], + [1.9108, 0.1042, 0.3467], + [2.2941, 0.0719, 0.4085], + [2.9978, 0.037, 0.4886], + [3.7731, 0.0378, 0.4863], + [4.7575, 0.0516, 0.4342], + [5.5024, 0.011, 0.6275], + [6.2686, 0.0114, 0.6253], + [7.005, 0.0054, 0.6625], + [8.5207, 0.0063, 0.6563], + [10.0034, 0.003, 0.6844], + [11.5075, 0.0031, 0.6833], + [13.0327, 0.0032, 0.6829], + [14.5356, 0.0018, 0.7003], + [17.5447, 0.0014, 0.7063], + [20.5576, 0.0011, 0.7126], + [23.5624, 0.0007, 0.7197], + [26.5785, 0.0007, 0.721], + [29.593, 0.0005, 0.7248], + [32.6109, 0.0004, 0.7268], + [35.6384, 0.0004, 0.727], + [38.6439, 0.0002, 0.7343], + [41.6815, 0.0004, 0.7284], + [44.6895, 0.0002, 0.7372], + [47.6926, 0.0001, 0.7393], + [51.4567, 0.0001, 0.7382] + ], + "dispense": [ + [0.6464, 0.4817, 0.0427], + [1.0889, 0.2539, 0.1591], + [1.5136, 0.1624, 0.2587], + [1.9108, 0.1042, 0.3467], + [2.2941, 0.0719, 0.4085], + [2.9978, 0.037, 0.4886], + [3.7731, 0.0378, 0.4863], + [4.7575, 0.0516, 0.4342], + [5.5024, 0.011, 0.6275], + [6.2686, 0.0114, 0.6253], + [7.005, 0.0054, 0.6625], + [8.5207, 0.0063, 0.6563], + [10.0034, 0.003, 0.6844], + [11.5075, 0.0031, 0.6833], + [13.0327, 0.0032, 0.6829], + [14.5356, 0.0018, 0.7003], + [17.5447, 0.0014, 0.7063], + [20.5576, 0.0011, 0.7126], + [23.5624, 0.0007, 0.7197], + [26.5785, 0.0007, 0.721], + [29.593, 0.0005, 0.7248], + [32.6109, 0.0004, 0.7268], + [35.6384, 0.0004, 0.727], + [38.6439, 0.0002, 0.7343], + [41.6815, 0.0004, 0.7284], + [44.6895, 0.0002, 0.7372], + [47.6926, 0.0001, 0.7393], + [51.4567, 0.0001, 0.7382] + ] + } + ], + "plungerCurrent": { + "value": 1, + "min": 0.1, + "max": 1.5, + "units": "amps", + "type": "float" + }, + "dropTipCurrent": { + "value": 1, + "min": 0.1, + "max": 1.25, + "units": "amps", + "type": "float" + }, + "dropTipSpeed": { + "value": 10, + "min": 0.001, + "max": 30, + "units": "mm/sec", + "type": "float" + }, + "tipOverlap": { + "default": 10.5, + "opentrons/opentrons_96_tiprack_50ul/1": 10.5 + }, + "tipLength": { + "value": 78.3, + "units": "mm", + "type": "float", + "min": 0, + "max": 100 + }, + "quirks": [], + "returnTipHeight": 0.83, + "idleCurrent": 0.3 + }, + "p200_96_v3.0": { + "name": "p200_96", + "backCompatNames": [], + "top": { + "value": 0.5, + "min": 0, + "max": 45, + "units": "mm", + "type": "float" + }, + "bottom": { + "value": 71.5, + "min": 55, + "max": 80, + "type": "float", + "units": "mm" + }, + "blowout": { + "value": 76.5, + "min": 60, + "max": 85, + "units": "mm", + "type": "float" + }, + "dropTip": { + "value": 92.5, + "min": 78, + "max": 119, + "units": "mm", + "type": "float" + }, + "pickUpCurrent": { + "value": 0.5, + "min": 0.05, + "max": 2.0, + "units": "amps", + "type": "float" + }, + "pickUpDistance": { + "value": 13, + "min": 1, + "max": 30, + "units": "mm", + "type": "float" + }, + "pickUpIncrement": { + "value": 0.0, + "min": 0.0, + "max": 10.0, + "units": "mm", + "type": "float" + }, + "pickUpPresses": { + "value": 1, + "min": 0, + "max": 10, + "units": "presses", + "type": "int" + }, + "pickUpSpeed": { + "value": 10, + "min": 1, + "max": 30, + "units": "mm/s", + "type": "float" + }, + "nozzleOffset": [-8.0, -16.0, -259.15], + "modelOffset": [0.0, 0.0, 25.14], + "ulPerMm": [ + { + "aspirate": [ + [0.6464, 0.4817, 0.0427], + [1.0889, 0.2539, 0.1591], + [1.5136, 0.1624, 0.2587], + [1.9108, 0.1042, 0.3467], + [2.2941, 0.0719, 0.4085], + [2.9978, 0.037, 0.4886], + [3.7731, 0.0378, 0.4863], + [4.7575, 0.0516, 0.4342], + [5.5024, 0.011, 0.6275], + [6.2686, 0.0114, 0.6253], + [7.005, 0.0054, 0.6625], + [8.5207, 0.0063, 0.6563], + [10.0034, 0.003, 0.6844], + [11.5075, 0.0031, 0.6833], + [13.0327, 0.0032, 0.6829], + [14.5356, 0.0018, 0.7003], + [17.5447, 0.0014, 0.7063], + [20.5576, 0.0011, 0.7126], + [23.5624, 0.0007, 0.7197], + [26.5785, 0.0007, 0.721], + [29.593, 0.0005, 0.7248], + [32.6109, 0.0004, 0.7268], + [35.6384, 0.0004, 0.727], + [38.6439, 0.0002, 0.7343], + [41.6815, 0.0004, 0.7284], + [44.6895, 0.0002, 0.7372], + [47.6926, 0.0001, 0.7393], + [51.4567, 0.0001, 0.7382] + ], + "dispense": [ + [0.6464, 0.4817, 0.0427], + [1.0889, 0.2539, 0.1591], + [1.5136, 0.1624, 0.2587], + [1.9108, 0.1042, 0.3467], + [2.2941, 0.0719, 0.4085], + [2.9978, 0.037, 0.4886], + [3.7731, 0.0378, 0.4863], + [4.7575, 0.0516, 0.4342], + [5.5024, 0.011, 0.6275], + [6.2686, 0.0114, 0.6253], + [7.005, 0.0054, 0.6625], + [8.5207, 0.0063, 0.6563], + [10.0034, 0.003, 0.6844], + [11.5075, 0.0031, 0.6833], + [13.0327, 0.0032, 0.6829], + [14.5356, 0.0018, 0.7003], + [17.5447, 0.0014, 0.7063], + [20.5576, 0.0011, 0.7126], + [23.5624, 0.0007, 0.7197], + [26.5785, 0.0007, 0.721], + [29.593, 0.0005, 0.7248], + [32.6109, 0.0004, 0.7268], + [35.6384, 0.0004, 0.727], + [38.6439, 0.0002, 0.7343], + [41.6815, 0.0004, 0.7284], + [44.6895, 0.0002, 0.7372], + [47.6926, 0.0001, 0.7393], + [51.4567, 0.0001, 0.7382] + ] + } + ], + "plungerCurrent": { + "value": 1, + "min": 0.1, + "max": 1.5, + "units": "amps", + "type": "float" + }, + "dropTipCurrent": { + "value": 1, + "min": 0.1, + "max": 1.25, + "units": "amps", + "type": "float" + }, + "dropTipSpeed": { + "value": 10, + "min": 0.001, + "max": 30, + "units": "mm/sec", + "type": "float" + }, + "tipOverlap": { + "default": 10.5, + "opentrons/opentrons_96_tiprack_50ul/1": 10.5 + }, + "tipLength": { + "value": 78.3, + "units": "mm", + "type": "float", + "min": 0, + "max": 100 + }, + "quirks": [], + "returnTipHeight": 0.83, + "idleCurrent": 0.3 } }, "mutableConfigs": [ diff --git a/shared-data/pipette/definitions/1/pipetteNameSpecs.json b/shared-data/pipette/definitions/1/pipetteNameSpecs.json index 7beeb92aabc..37d44414ea1 100644 --- a/shared-data/pipette/definitions/1/pipetteNameSpecs.json +++ b/shared-data/pipette/definitions/1/pipetteNameSpecs.json @@ -738,5 +738,47 @@ "opentrons/opentrons_flex_96_tiprack_50ul/1", "opentrons/opentrons_flex_96_filtertiprack_50ul/1" ] + }, + "p200_96": { + "displayName": "Flex 96-Channel 200 μL", + "displayCategory": "FLEX", + "defaultAspirateFlowRate": { + "value": 7.85, + "min": 3, + "max": 812, + "valuesByApiLevel": { + "2.0": 7.85 + } + }, + "defaultDispenseFlowRate": { + "value": 7.85, + "min": 3, + "max": 812, + "valuesByApiLevel": { + "2.0": 7.85 + } + }, + "defaultBlowOutFlowRate": { + "value": 7.85, + "min": 3, + "max": 812, + "valuesByApiLevel": { + "2.0": 7.85 + } + }, + "channels": 96, + "minVolume": 5, + "maxVolume": 200, + "smoothieConfigs": { + "stepsPerMM": 2133.33, + "homePosition": 230.15, + "travelDistance": 80 + }, + "defaultTipracks": [ + "opentrons/opentrons_flex_96_tiprack_200ul/1", + "opentrons/opentrons_flex_96_filtertiprack_200ul/1", + "opentrons/opentrons_flex_96_tiprack_50ul/1", + "opentrons/opentrons_flex_96_filtertiprack_50ul/1" + ] } } diff --git a/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/1_0.json b/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/1_0.json new file mode 100644 index 00000000000..5719bb3437c --- /dev/null +++ b/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/1_0.json @@ -0,0 +1,660 @@ +{ + "$otSharedSchema": "#/pipette/schemas/2/pipettePropertiesSchema.json", + "displayName": "Flex 96-Channel 200 μL", + "model": "p200", + "displayCategory": "FLEX", + "validNozzleMaps": { + "maps": { + "SingleA1": ["A1"], + "SingleH1": ["H1"], + "SingleA12": ["A12"], + "SingleH12": ["H12"], + "Column1": ["A1", "B1", "C1", "D1", "E1", "F1", "G1", "H1"], + "Column12": ["A12", "B12", "C12", "D12", "E12", "F12", "G12", "H12"], + "RowA": [ + "A1", + "A2", + "A3", + "A4", + "A5", + "A6", + "A7", + "A8", + "A9", + "A10", + "A11", + "A12" + ], + "RowH": [ + "H1", + "H2", + "H3", + "H4", + "H5", + "H6", + "H7", + "H8", + "H9", + "H10", + "H11", + "H12" + ], + "Full": [ + "A1", + "A2", + "A3", + "A4", + "A5", + "A6", + "A7", + "A8", + "A9", + "A10", + "A11", + "A12", + "B1", + "B2", + "B3", + "B4", + "B5", + "B6", + "B7", + "B8", + "B9", + "B10", + "B11", + "B12", + "C1", + "C2", + "C3", + "C4", + "C5", + "C6", + "C7", + "C8", + "C9", + "C10", + "C11", + "C12", + "D1", + "D2", + "D3", + "D4", + "D5", + "D6", + "D7", + "D8", + "D9", + "D10", + "D11", + "D12", + "E1", + "E2", + "E3", + "E4", + "E5", + "E6", + "E7", + "E8", + "E9", + "E10", + "E11", + "E12", + "F1", + "F2", + "F3", + "F4", + "F5", + "F6", + "F7", + "F8", + "F9", + "F10", + "F11", + "F12", + "G1", + "G2", + "G3", + "G4", + "G5", + "G6", + "G7", + "G8", + "G9", + "G10", + "G11", + "G12", + "H1", + "H2", + "H3", + "H4", + "H5", + "H6", + "H7", + "H8", + "H9", + "H10", + "H11", + "H12" + ] + } + }, + "pickUpTipConfigurations": { + "pressFit": { + "presses": 1, + "increment": 0.0, + "configurationsByNozzleMap": { + "SingleA1": { + "default": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 9.981, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + } + }, + "SingleH1": { + "default": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 9.981, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + } + }, + "SingleA12": { + "default": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 9.981, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + } + }, + "SingleH12": { + "default": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 9.981, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.981, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.981 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 10.5, + "current": 0.4, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.884, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.884, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.884 + } + } + } + }, + "Column1": { + "default": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + }, + "v3": { + "default": 9.49, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.52, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.52 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + }, + "v3": { + "default": 9.49, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.49 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16 + }, + "v3": { + "default": 9.52, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.52, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.52 + } + } + } + }, + "Column12": { + "default": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + }, + "v3": { + "default": 9.49, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.52, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.52 + } + } + }, + "t200": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + }, + "v3": { + "default": 9.49, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.49, + "opentrons/opentrons_flex_96_filtertiprack_200ul/1": 9.49 + } + } + }, + "t50": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16 + }, + "v3": { + "default": 9.52, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.52, + "opentrons/opentrons_flex_96_filtertiprack_50ul/1": 9.52 + } + } + } + }, + "RowA": { + "default": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5 + }, + "v1": { + "default": 9.379, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.379, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.6 + } + } + } + }, + "RowH": { + "default": { + "speed": 10.0, + "distance": 13.0, + "current": 0.55, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5 + }, + "v1": { + "default": 9.401, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 9.401, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.415 + } + } + } + } + } + }, + "camAction": { + "prep_move_distance": 8.25, + "prep_move_speed": 10.0, + "connectTiprackDistanceMM": 7.0, + "configurationsByNozzleMap": { + "Full": { + "default": { + "speed": 5.5, + "distance": 10.0, + "current": 1.5, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + } + } + }, + "t200": { + "speed": 5.5, + "distance": 10.0, + "current": 1.5, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_200ul/1": 9.74 + } + } + }, + "t50": { + "speed": 5.5, + "distance": 10.0, + "current": 1.5, + "tipOverlaps": { + "v0": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.5 + }, + "v1": { + "default": 10.5, + "opentrons/opentrons_flex_96_tiprack_50ul/1": 10.16 + } + } + } + } + } + } + }, + "dropTipConfigurations": { + "camAction": { + "current": 1.5, + "speed": 5.5, + "distance": 10.8, + "prep_move_distance": 19.0, + "prep_move_speed": 10.0 + } + }, + "plungerMotorConfigurations": { + "idle": 0.3, + "run": 0.8 + }, + "plungerPositionsConfigurations": { + "default": { + "top": 0.5, + "bottom": 68.5, + "blowout": 73.5, + "drop": 80 + } + }, + "availableSensors": { + "sensors": ["pressure", "capacitive", "environment"], + "pressure": { + "count": 2 + }, + "capacitive": { + "count": 2 + }, + "environment": { + "count": 1 + } + }, + "partialTipConfigurations": { + "partialTipSupported": true, + "availableConfigurations": [1, 8, 12, 16, 24, 48, 96] + }, + "backCompatNames": [], + "channels": 96, + "shaftDiameter": 2, + "shaftULperMM": 3.14159, + "backlashDistance": 3.0, + "quirks": [], + "plungerHomingConfigurations": { + "current": 0.8, + "speed": 5 + }, + "tipPresenceCheckDistanceMM": 8.0, + "endTipActionRetractDistanceMM": 2.0 +} diff --git a/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/3_0.json b/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/3_0.json index 5f3fa397dc8..5719bb3437c 100644 --- a/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/3_0.json +++ b/shared-data/pipette/definitions/2/general/ninety_six_channel/p200/3_0.json @@ -624,8 +624,8 @@ "plungerPositionsConfigurations": { "default": { "top": 0.5, - "bottom": 67.5, - "blowout": 72.5, + "bottom": 68.5, + "blowout": 73.5, "drop": 80 } }, @@ -649,7 +649,7 @@ "channels": 96, "shaftDiameter": 2, "shaftULperMM": 3.14159, - "backlashDistance": 0.3, + "backlashDistance": 3.0, "quirks": [], "plungerHomingConfigurations": { "current": 0.8, diff --git a/shared-data/pipette/definitions/2/geometry/ninety_six_channel/p200/1_0.json b/shared-data/pipette/definitions/2/geometry/ninety_six_channel/p200/1_0.json new file mode 100644 index 00000000000..437830a58c5 --- /dev/null +++ b/shared-data/pipette/definitions/2/geometry/ninety_six_channel/p200/1_0.json @@ -0,0 +1,305 @@ +{ + "$otSharedSchema": "#/pipette/schemas/2/pipetteGeometrySchema.json", + "pathTo3D": "pipette/definitions/2/geometry/ninety_six_channel/p200/placeholder.gltf", + "nozzleOffset": [-36.0, -25.5, -259.15], + "pipetteBoundingBoxOffsets": { + "backLeftCorner": [-67.0, -3.5, -259.15], + "frontRightCorner": [94.0, -113.0, -259.15] + }, + "orderedRows": [ + { + "key": "A", + "orderedNozzles": [ + "A1", + "A2", + "A3", + "A4", + "A5", + "A6", + "A7", + "A8", + "A9", + "A10", + "A11", + "A12" + ] + }, + { + "key": "B", + "orderedNozzles": [ + "B1", + "B2", + "B3", + "B4", + "B5", + "B6", + "B7", + "B8", + "B9", + "B10", + "B11", + "B12" + ] + }, + { + "key": "C", + "orderedNozzles": [ + "C1", + "C2", + "C3", + "C4", + "C5", + "C6", + "C7", + "C8", + "C9", + "C10", + "C11", + "C12" + ] + }, + { + "key": "D", + "orderedNozzles": [ + "D1", + "D2", + "D3", + "D4", + "D5", + "D6", + "D7", + "D8", + "D9", + "D10", + "D11", + "D12" + ] + }, + { + "key": "E", + "orderedNozzles": [ + "E1", + "E2", + "E3", + "E4", + "E5", + "E6", + "E7", + "E8", + "E9", + "E10", + "E11", + "E12" + ] + }, + { + "key": "F", + "orderedNozzles": [ + "F1", + "F2", + "F3", + "F4", + "F5", + "F6", + "F7", + "F8", + "F9", + "F10", + "F11", + "F12" + ] + }, + { + "key": "G", + "orderedNozzles": [ + "G1", + "G2", + "G3", + "G4", + "G5", + "G6", + "G7", + "G8", + "G9", + "G10", + "G11", + "G12" + ] + }, + { + "key": "H", + "orderedNozzles": [ + "H1", + "H2", + "H3", + "H4", + "H5", + "H6", + "H7", + "H8", + "H9", + "H10", + "H11", + "H12" + ] + } + ], + "orderedColumns": [ + { + "key": "1", + "orderedNozzles": ["A1", "B1", "C1", "D1", "E1", "F1", "G1", "H1"] + }, + { + "key": "2", + "orderedNozzles": ["A2", "B2", "C2", "D2", "E2", "F2", "G2", "H2"] + }, + { + "key": "3", + "orderedNozzles": ["A3", "B3", "C3", "D3", "E3", "F3", "G3", "H3"] + }, + { + "key": "4", + "orderedNozzles": ["A4", "B4", "C4", "D4", "E4", "F4", "G4", "H4"] + }, + { + "key": "5", + "orderedNozzles": ["A5", "B5", "C5", "D5", "E5", "F5", "G5", "H5"] + }, + { + "key": "6", + "orderedNozzles": ["A6", "B6", "C6", "D6", "E6", "F6", "G6", "H6"] + }, + { + "key": "7", + "orderedNozzles": ["A7", "B7", "C7", "D7", "E7", "F7", "G7", "H7"] + }, + { + "key": "8", + "orderedNozzles": ["A8", "B8", "C8", "D8", "E8", "F8", "G8", "H8"] + }, + { + "key": "9", + "orderedNozzles": ["A9", "B9", "C9", "D9", "E9", "F9", "G9", "H9"] + }, + { + "key": "10", + "orderedNozzles": ["A10", "B10", "C10", "D10", "E10", "F10", "G10", "H10"] + }, + { + "key": "11", + "orderedNozzles": ["A11", "B11", "C11", "D11", "E11", "F11", "G11", "H11"] + }, + { + "key": "12", + "orderedNozzles": ["A12", "B12", "C12", "D12", "E12", "F12", "G12", "H12"] + } + ], + "nozzleMap": { + "A1": [-36.0, -25.5, -259.15], + "A2": [-27.0, -25.5, -259.15], + "A3": [-18.0, -25.5, -259.15], + "A4": [-9.0, -25.5, -259.15], + "A5": [0.0, -25.5, -259.15], + "A6": [9.0, -25.5, -259.15], + "A7": [18.0, -25.5, -259.15], + "A8": [27.0, -25.5, -259.15], + "A9": [36.0, -25.5, -259.15], + "A10": [45.0, -25.5, -259.15], + "A11": [54.0, -25.5, -259.15], + "A12": [63.0, -25.5, -259.15], + "B1": [-36.0, -34.5, -259.15], + "B2": [-27.0, -34.5, -259.15], + "B3": [-18.0, -34.5, -259.15], + "B4": [-9.0, -34.5, -259.15], + "B5": [0.0, -34.5, -259.15], + "B6": [9.0, -34.5, -259.15], + "B7": [18.0, -34.5, -259.15], + "B8": [27.0, -34.5, -259.15], + "B9": [36.0, -34.5, -259.15], + "B10": [45.0, -34.5, -259.15], + "B11": [54.0, -34.5, -259.15], + "B12": [63.0, -34.5, -259.15], + "C1": [-36.0, -43.5, -259.15], + "C2": [-27.0, -43.5, -259.15], + "C3": [-18.0, -43.5, -259.15], + "C4": [-9.0, -43.5, -259.15], + "C5": [0.0, -43.5, -259.15], + "C6": [9.0, -43.5, -259.15], + "C7": [18.0, -43.5, -259.15], + "C8": [27.0, -43.5, -259.15], + "C9": [36.0, -43.5, -259.15], + "C10": [45.0, -43.5, -259.15], + "C11": [54.0, -43.5, -259.15], + "C12": [63.0, -43.5, -259.15], + "D1": [-36.0, -52.5, -259.15], + "D2": [-27.0, -52.5, -259.15], + "D3": [-18.0, -52.5, -259.15], + "D4": [-9.0, -52.5, -259.15], + "D5": [0.0, -52.5, -259.15], + "D6": [9.0, -52.5, -259.15], + "D7": [18.0, -52.5, -259.15], + "D8": [27.0, -52.5, -259.15], + "D9": [36.0, -52.5, -259.15], + "D10": [45.0, -52.5, -259.15], + "D11": [54.0, -52.5, -259.15], + "D12": [63.0, -52.5, -259.15], + "E1": [-36.0, -61.5, -259.15], + "E2": [-27.0, -61.5, -259.15], + "E3": [-18.0, -61.5, -259.15], + "E4": [-9.0, -61.5, -259.15], + "E5": [0.0, -61.5, -259.15], + "E6": [9.0, -61.5, -259.15], + "E7": [18.0, -61.5, -259.15], + "E8": [27.0, -61.5, -259.15], + "E9": [36.0, -61.5, -259.15], + "E10": [45.0, -61.5, -259.15], + "E11": [54.0, -61.5, -259.15], + "E12": [63.0, -61.5, -259.15], + "F1": [-36.0, -70.5, -259.15], + "F2": [-27.0, -70.5, -259.15], + "F3": [-18.0, -70.5, -259.15], + "F4": [-9.0, -70.5, -259.15], + "F5": [0.0, -70.5, -259.15], + "F6": [9.0, -70.5, -259.15], + "F7": [18.0, -70.5, -259.15], + "F8": [27.0, -70.5, -259.15], + "F9": [36.0, -70.5, -259.15], + "F10": [45.0, -70.5, -259.15], + "F11": [54.0, -70.5, -259.15], + "F12": [63.0, -70.5, -259.15], + "G1": [-36.0, -79.5, -259.15], + "G2": [-27.0, -79.5, -259.15], + "G3": [-18.0, -79.5, -259.15], + "G4": [-9.0, -79.5, -259.15], + "G5": [0.0, -79.5, -259.15], + "G6": [9.0, -79.5, -259.15], + "G7": [18.0, -79.5, -259.15], + "G8": [27.0, -79.5, -259.15], + "G9": [36.0, -79.5, -259.15], + "G10": [45.0, -79.5, -259.15], + "G11": [54.0, -79.5, -259.15], + "G12": [63.0, -79.5, -259.15], + "H1": [-36.0, -88.5, -259.15], + "H2": [-27.0, -88.5, -259.15], + "H3": [-18.0, -88.5, -259.15], + "H4": [-9.0, -88.5, -259.15], + "H5": [0.0, -88.5, -259.15], + "H6": [9.0, -88.5, -259.15], + "H7": [18.0, -88.5, -259.15], + "H8": [27.0, -88.5, -259.15], + "H9": [36.0, -88.5, -259.15], + "H10": [45.0, -88.5, -259.15], + "H11": [54.0, -88.5, -259.15], + "H12": [63.0, -88.5, -259.15] + }, + "lldSettings": { + "t50": { + "minHeight": 1.5, + "minVolume": 0 + }, + "t200": { + "minHeight": 1.5, + "minVolume": 0 + } + } +} diff --git a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/1_0.json b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/1_0.json index 8e17a5ac22d..e2b30fd5af1 100644 --- a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/1_0.json +++ b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/1_0.json @@ -1,6 +1,57 @@ { "$otSharedSchema": "#/pipette/schemas/2/pipetteLiquidPropertiesSchema.json", "supportedTips": { + "t20": { + "uiMaxFlowRate": 189.1, + "defaultAspirateFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultDispenseFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultBlowOutFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultFlowAcceleration": 16000.0, + "defaultTipLength": 52.0, + "defaultReturnTipHeight": 0.6, + "aspirate": { + "default": { + "1": [ + [1.933333, 2.844459, 4.750159], + [2.833333, 1.12901, 8.066694], + [3.603333, 0.254744, 10.543779], + [4.836667, 1.101839, 7.491414], + [5.755, 0.277649, 11.47775], + [6.643333, 0.14813, 12.223126], + [7.548333, 0.145635, 12.239705], + [8.475, 0.15097, 12.199433], + [13.02, 0.071736, 12.870946], + [22.318333, 0.042305, 13.254131] + ] + } + }, + "dispense": { + "default": { + "1": [ + [1.933333, 2.844459, 4.750159], + [2.833333, 1.12901, 8.066694], + [3.603333, 0.254744, 10.543779], + [4.836667, 1.101839, 7.491414], + [5.755, 0.277649, 11.47775], + [6.643333, 0.14813, 12.223126], + [7.548333, 0.145635, 12.239705], + [8.475, 0.15097, 12.199433], + [13.02, 0.071736, 12.870946], + [22.318333, 0.042305, 13.254131] + ] + } + }, + "defaultPushOutVolume": 2 + }, "t50": { "defaultAspirateFlowRate": { "default": 6, diff --git a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/3_6.json b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/3_6.json index 95f555dff89..30d8e77c32b 100644 --- a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/3_6.json +++ b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p1000/default/3_6.json @@ -235,6 +235,7 @@ "opentrons/opentrons_flex_96_tiprack_20ul/1", "opentrons/opentrons_flex_96_filtertiprack_1000ul/1", "opentrons/opentrons_flex_96_filtertiprack_200ul/1", - "opentrons/opentrons_flex_96_filtertiprack_50ul/1" + "opentrons/opentrons_flex_96_filtertiprack_50ul/1", + "opentrons/opentrons_flex_96_filtertiprack_20ul/1" ] } diff --git a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/1_0.json b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/1_0.json new file mode 100644 index 00000000000..845d7bc7e3b --- /dev/null +++ b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/1_0.json @@ -0,0 +1,288 @@ +{ + "$otSharedSchema": "#/pipette/schemas/2/pipetteLiquidPropertiesSchema.json", + "supportedTips": { + "t20": { + "uiMaxFlowRate": 189.1, + "defaultAspirateFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultDispenseFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultBlowOutFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultFlowAcceleration": 16000.0, + "defaultTipLength": 57.9, + "defaultReturnTipHeight": 0.6, + "aspirate": { + "default": { + "1": [ + [1.933333, 2.844459, 4.750159], + [2.833333, 1.12901, 8.066694], + [3.603333, 0.254744, 10.543779], + [4.836667, 1.101839, 7.491414], + [5.755, 0.277649, 11.47775], + [6.643333, 0.14813, 12.223126], + [7.548333, 0.145635, 12.239705], + [8.475, 0.15097, 12.199433], + [13.02, 0.071736, 12.870946], + [22.318333, 0.042305, 13.254131] + ] + } + }, + "dispense": { + "default": { + "1": [ + [1.933333, 2.844459, 4.750159], + [2.833333, 1.12901, 8.066694], + [3.603333, 0.254744, 10.543779], + [4.836667, 1.101839, 7.491414], + [5.755, 0.277649, 11.47775], + [6.643333, 0.14813, 12.223126], + [7.548333, 0.145635, 12.239705], + [8.475, 0.15097, 12.199433], + [13.02, 0.071736, 12.870946], + [22.318333, 0.042305, 13.254131] + ] + } + }, + "defaultPushOutVolume": 2 + }, + "t50": { + "defaultAspirateFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultDispenseFlowRate": { + "default": 6, + "valuesByApiLevel": { "2.14": 6 } + }, + "defaultBlowOutFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultFlowAcceleration": 16000.0, + "defaultTipLength": 57.9, + "defaultReturnTipHeight": 0.2, + "aspirate": { + "default": { + "1": [ + [0.4148, -1705.1015, 20.5455], + [0.4476, -80.633, 47.2788], + [0.5512, -1.5936, 11.9026], + [0.6027, -18.9998, 21.4972], + [0.6503, -15.8781, 19.6156], + [0.7733, 3.0612, 7.2993], + [0.8391, -5.2227, 13.7056], + [0.9736, 3.0706, 6.7467], + [1.16, -0.374, 10.1005], + [1.3964, 1.3004, 8.1582], + [1.5815, -0.4837, 10.6494], + [1.8306, 1.1464, 8.0714], + [2.0345, 0.0132, 10.1459], + [2.6221, 0.5374, 9.0794], + [2.9655, -1.7582, 15.0986], + [3.5124, 0.2754, 9.0681], + [4.6591, 1.406, 5.097], + [5.367, 0.394, 9.8123], + [6.0839, 0.3365, 10.1205], + [6.8312, 0.3379, 10.1121], + [7.5676, 0.2611, 10.637], + [8.2397, 0.095, 11.8939], + [8.9776, 0.2015, 11.0165], + [10.413, 0.1332, 11.6294], + [11.8539, 0.1074, 11.8979], + [13.3655, 0.1286, 11.6464], + [14.8236, 0.0758, 12.3519], + [16.3203, 0.083, 12.2457], + [17.7915, 0.0581, 12.6515], + [19.2145, 0.0273, 13.1995], + [20.6718, 0.0388, 12.9792], + [22.1333, 0.0357, 13.044], + [25.0761, 0.0332, 13.0977], + [28.0339, 0.029, 13.2035], + [30.967, 0.0201, 13.4538], + [33.8727, 0.013, 13.6737], + [36.8273, 0.0172, 13.5324], + [39.7594, 0.0121, 13.7191], + [42.6721, 0.0083, 13.8687], + [45.5964, 0.0085, 13.8618], + [48.5297, 0.0084, 13.8668], + [51.4512, 0.0064, 13.9651] + ] + } + }, + "dispense": { + "default": { + "1": [ + [0.4148, -1705.1015, 20.5455], + [0.4476, -80.633, 47.2788], + [0.5512, -1.5936, 11.9026], + [0.6027, -18.9998, 21.4972], + [0.6503, -15.8781, 19.6156], + [0.7733, 3.0612, 7.2993], + [0.8391, -5.2227, 13.7056], + [0.9736, 3.0706, 6.7467], + [1.16, -0.374, 10.1005], + [1.3964, 1.3004, 8.1582], + [1.5815, -0.4837, 10.6494], + [1.8306, 1.1464, 8.0714], + [2.0345, 0.0132, 10.1459], + [2.6221, 0.5374, 9.0794], + [2.9655, -1.7582, 15.0986], + [3.5124, 0.2754, 9.0681], + [4.6591, 1.406, 5.097], + [5.367, 0.394, 9.8123], + [6.0839, 0.3365, 10.1205], + [6.8312, 0.3379, 10.1121], + [7.5676, 0.2611, 10.637], + [8.2397, 0.095, 11.8939], + [8.9776, 0.2015, 11.0165], + [10.413, 0.1332, 11.6294], + [11.8539, 0.1074, 11.8979], + [13.3655, 0.1286, 11.6464], + [14.8236, 0.0758, 12.3519], + [16.3203, 0.083, 12.2457], + [17.7915, 0.0581, 12.6515], + [19.2145, 0.0273, 13.1995], + [20.6718, 0.0388, 12.9792], + [22.1333, 0.0357, 13.044], + [25.0761, 0.0332, 13.0977], + [28.0339, 0.029, 13.2035], + [30.967, 0.0201, 13.4538], + [33.8727, 0.013, 13.6737], + [36.8273, 0.0172, 13.5324], + [39.7594, 0.0121, 13.7191], + [42.6721, 0.0083, 13.8687], + [45.5964, 0.0085, 13.8618], + [48.5297, 0.0084, 13.8668], + [51.4512, 0.0064, 13.9651] + ] + } + }, + "defaultPushOutVolume": 7 + }, + "t200": { + "defaultAspirateFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultDispenseFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultBlowOutFlowRate": { + "default": 80, + "valuesByApiLevel": { "2.14": 80 } + }, + "defaultFlowAcceleration": 16000.0, + "defaultTipLength": 58.35, + "defaultReturnTipHeight": 0.2, + "aspirate": { + "default": { + "1": [ + [0.8314, -2.9322, 24.0741], + [0.8853, -30.0996, 48.7784], + [0.9778, -4.3627, 25.9941], + [0.975, 802.2301, -762.6744], + [1.1272, -4.6837, 24.0666], + [1.2747, -3.91, 23.1945], + [1.5656, -2.8032, 21.7836], + [1.6667, -7.2039, 28.6731], + [2.4403, -0.5147, 17.5244], + [3.0564, -1.6013, 20.1761], + [3.6444, -1.1974, 18.9418], + [4.1189, -1.7877, 21.0928], + [4.6467, -0.8591, 17.2684], + [5.2597, -0.207, 14.2379], + [5.8581, -0.2196, 14.3044], + [6.4772, -0.1025, 13.6183], + [7.8158, 0.0537, 12.6063], + [9.1664, 0.0507, 12.6302], + [10.5064, 0.0285, 12.8339], + [14.8361, 0.0818, 12.273], + [19.3933, 0.0801, 12.2991], + [23.9242, 0.0487, 12.9079], + [28.4922, 0.0379, 13.1666], + [36.145, 0.0277, 13.4572], + [43.7972, 0.0184, 13.7916], + [51.5125, 0.0154, 13.9248], + [59.2467, 0.0121, 14.0931], + [66.9428, 0.0084, 14.3151], + [74.6853, 0.0079, 14.3498], + [82.3722, 0.0052, 14.5512], + [90.1106, 0.0054, 14.5333], + [97.8369, 0.0043, 14.6288], + [105.6153, 0.0046, 14.5983], + [113.3686, 0.0036, 14.7076], + [121.1108, 0.003, 14.7785], + [136.61, 0.0026, 14.826], + [152.0708, 0.0018, 14.9298], + [167.6433, 0.0021, 14.8827], + [183.1011, 0.0012, 15.0438], + [198.5845, 0.0011, 15.0538], + [214.0264, 0.0008, 15.123] + ] + } + }, + "dispense": { + "default": { + "1": [ + [0.8314, -2.9322, 24.0741], + [0.8853, -30.0996, 48.7784], + [0.9778, -4.3627, 25.9941], + [0.975, 802.2301, -762.6744], + [1.1272, -4.6837, 24.0666], + [1.2747, -3.91, 23.1945], + [1.5656, -2.8032, 21.7836], + [1.6667, -7.2039, 28.6731], + [2.4403, -0.5147, 17.5244], + [3.0564, -1.6013, 20.1761], + [3.6444, -1.1974, 18.9418], + [4.1189, -1.7877, 21.0928], + [4.6467, -0.8591, 17.2684], + [5.2597, -0.207, 14.2379], + [5.8581, -0.2196, 14.3044], + [6.4772, -0.1025, 13.6183], + [7.8158, 0.0537, 12.6063], + [9.1664, 0.0507, 12.6302], + [10.5064, 0.0285, 12.8339], + [14.8361, 0.0818, 12.273], + [19.3933, 0.0801, 12.2991], + [23.9242, 0.0487, 12.9079], + [28.4922, 0.0379, 13.1666], + [36.145, 0.0277, 13.4572], + [43.7972, 0.0184, 13.7916], + [51.5125, 0.0154, 13.9248], + [59.2467, 0.0121, 14.0931], + [66.9428, 0.0084, 14.3151], + [74.6853, 0.0079, 14.3498], + [82.3722, 0.0052, 14.5512], + [90.1106, 0.0054, 14.5333], + [97.8369, 0.0043, 14.6288], + [105.6153, 0.0046, 14.5983], + [113.3686, 0.0036, 14.7076], + [121.1108, 0.003, 14.7785], + [136.61, 0.0026, 14.826], + [152.0708, 0.0018, 14.9298], + [167.6433, 0.0021, 14.8827], + [183.1011, 0.0012, 15.0438], + [198.5845, 0.0011, 15.0538], + [214.0264, 0.0008, 15.123] + ] + } + }, + "defaultPushOutVolume": 5 + } + }, + "maxVolume": 200, + "minVolume": 0.5, + "defaultTipracks": [ + "opentrons/opentrons_flex_96_tiprack_200ul/1", + "opentrons/opentrons_flex_96_tiprack_50ul/1" + ] +} diff --git a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/3_0.json b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/3_0.json index 6a371944682..d2814dca3c1 100644 --- a/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/3_0.json +++ b/shared-data/pipette/definitions/2/liquid/ninety_six_channel/p200/default/3_0.json @@ -12,8 +12,8 @@ "valuesByApiLevel": { "2.14": 6 } }, "defaultBlowOutFlowRate": { - "default": 80, - "valuesByApiLevel": { "2.14": 80 } + "default": 10, + "valuesByApiLevel": { "2.14": 10 } }, "defaultFlowAcceleration": 16000.0, "defaultTipLength": 52.0, @@ -21,32 +21,30 @@ "aspirate": { "default": { "1": [ - [1.933333, 2.844459, 4.750159], - [2.833333, 1.12901, 8.066694], - [3.603333, 0.254744, 10.543779], - [4.836667, 1.101839, 7.491414], - [5.755, 0.277649, 11.47775], - [6.643333, 0.14813, 12.223126], - [7.548333, 0.145635, 12.239705], - [8.475, 0.15097, 12.199433], - [13.02, 0.071736, 12.870946], - [22.318333, 0.042305, 13.254131] + [0.534, 1.2036, 1.0349], + [0.747, 0.599, 1.3577], + [1.238, 0.9829, 1.071], + [2.545, 0.2887, 1.9304], + [4.41, 0.0567, 2.5208], + [9.075, 0.0172, 2.6952], + [13.744, 0.0059, 2.7975], + [18.45, 0.0042, 2.8213], + [22.198, 0.002, 2.8607] ] } }, "dispense": { "default": { "1": [ - [1.933333, 2.844459, 4.750159], - [2.833333, 1.12901, 8.066694], - [3.603333, 0.254744, 10.543779], - [4.836667, 1.101839, 7.491414], - [5.755, 0.277649, 11.47775], - [6.643333, 0.14813, 12.223126], - [7.548333, 0.145635, 12.239705], - [8.475, 0.15097, 12.199433], - [13.02, 0.071736, 12.870946], - [22.318333, 0.042305, 13.254131] + [0.534, 1.2036, 1.0349], + [0.747, 0.599, 1.3577], + [1.238, 0.9829, 1.071], + [2.545, 0.2887, 1.9304], + [4.41, 0.0567, 2.5208], + [9.075, 0.0172, 2.6952], + [13.744, 0.0059, 2.7975], + [18.45, 0.0042, 2.8213], + [22.198, 0.002, 2.8607] ] } }, @@ -63,8 +61,8 @@ "valuesByApiLevel": { "2.14": 6 } }, "defaultBlowOutFlowRate": { - "default": 80, - "valuesByApiLevel": { "2.14": 80 } + "default": 10, + "valuesByApiLevel": { "2.14": 10 } }, "defaultFlowAcceleration": 16000.0, "defaultTipLength": 57.9, @@ -72,36 +70,44 @@ "aspirate": { "default": { "1": [ - [1.9733, 2.7039, 5.1258], - [2.88, 1.0915, 8.3077], - [3.7642, 0.5906, 9.7502], - [4.9783, 1.0072, 8.1822], - [5.9342, 0.2998, 11.7038], - [6.8708, 0.1887, 12.3626], - [7.8092, 0.1497, 12.631], - [8.7525, 0.1275, 12.804], - [13.4575, 0.0741, 13.2718], - [22.8675, 0.0296, 13.87], - [37.0442, 0.0128, 14.2551], - [55.4792, -0.0013, 14.7754] + [0.604, 1.9387, 0.7265], + [1.002, 0.5052, 1.5924], + [1.548, 0.6099, 1.4875], + [2.078, 0.3391, 1.9067], + [2.587, 0.1922, 2.212], + [3.313, -0.1475, 3.0906], + [4.418, 0.1574, 2.0807], + [5.374, 0.0397, 2.6007], + [6.27, 0.0002, 2.8129], + [7.209, 0.0181, 2.7005], + [8.141, 0.0116, 2.7476], + [9.056, 0.0036, 2.8125], + [13.787, 0.009, 2.7636], + [23.24, 0.0035, 2.8396], + [37.387, 0.0011, 2.8942], + [56.204, 0.0003, 2.9235] ] } }, "dispense": { "default": { "1": [ - [1.9733, 2.7039, 5.1258], - [2.88, 1.0915, 8.3077], - [3.7642, 0.5906, 9.7502], - [4.9783, 1.0072, 8.1822], - [5.9342, 0.2998, 11.7038], - [6.8708, 0.1887, 12.3626], - [7.8092, 0.1497, 12.631], - [8.7525, 0.1275, 12.804], - [13.4575, 0.0741, 13.2718], - [22.8675, 0.0296, 13.87], - [37.0442, 0.0128, 14.2551], - [55.4792, -0.0013, 14.7754] + [0.604, 1.9387, 0.7265], + [1.002, 0.5052, 1.5924], + [1.548, 0.6099, 1.4875], + [2.078, 0.3391, 1.9067], + [2.587, 0.1922, 2.212], + [3.313, -0.1475, 3.0906], + [4.418, 0.1574, 2.0807], + [5.374, 0.0397, 2.6007], + [6.27, 0.0002, 2.8129], + [7.209, 0.0181, 2.7005], + [8.141, 0.0116, 2.7476], + [9.056, 0.0036, 2.8125], + [13.787, 0.009, 2.7636], + [23.24, 0.0035, 2.8396], + [37.387, 0.0011, 2.8942], + [56.204, 0.0003, 2.9235] ] } }, @@ -118,8 +124,8 @@ "valuesByApiLevel": { "2.14": 80 } }, "defaultBlowOutFlowRate": { - "default": 80, - "valuesByApiLevel": { "2.14": 80 } + "default": 10, + "valuesByApiLevel": { "2.14": 10 } }, "defaultFlowAcceleration": 16000.0, "defaultTipLength": 58.35, @@ -127,34 +133,36 @@ "aspirate": { "default": { "1": [ - [1.9331, 3.4604, 3.5588], - [2.9808, 1.5307, 7.2892], - [3.9869, 0.825, 9.3926], - [4.9762, 0.5141, 10.6323], - [5.9431, 0.3232, 11.5819], - [6.9223, 0.2644, 11.9317], - [7.8877, 0.1832, 12.4935], - [8.8562, 0.1512, 12.7463], - [47.7169, 0.0281, 13.836], - [95.63, 0.0007, 15.147], - [211.1169, 0.0005, 15.1655] + [1.229, 1.4716, 0.1219], + [3.221, 0.3008, 1.5608], + [5.172, 0.0914, 2.2354], + [7.054, 0.033, 2.5375], + [8.928, 0.0185, 2.6394], + [18.272, 0.007, 2.7424], + [46.608, 0.0021, 2.8326], + [94.448, 0.0008, 2.8908], + [142.077, 0.0002, 2.9503], + [190.089, 0.0002, 2.9453], + [199.841, 0.0004, 2.9137], + [204.342, -0.0159, 6.1694] ] } }, "dispense": { "default": { "1": [ - [1.9331, 3.4604, 3.5588], - [2.9808, 1.5307, 7.2892], - [3.9869, 0.825, 9.3926], - [4.9762, 0.5141, 10.6323], - [5.9431, 0.3232, 11.5819], - [6.9223, 0.2644, 11.9317], - [7.8877, 0.1832, 12.4935], - [8.8562, 0.1512, 12.7463], - [47.7169, 0.0281, 13.836], - [95.63, 0.0007, 15.147], - [211.1169, 0.0005, 15.1655] + [1.229, 1.4716, 0.1219], + [3.221, 0.3008, 1.5608], + [5.172, 0.0914, 2.2354], + [7.054, 0.033, 2.5375], + [8.928, 0.0185, 2.6394], + [18.272, 0.007, 2.7424], + [46.608, 0.0021, 2.8326], + [94.448, 0.0008, 2.8908], + [142.077, 0.0002, 2.9503], + [190.089, 0.0002, 2.9453], + [199.841, 0.0004, 2.9137], + [204.342, -0.0159, 6.1694] ] } }, From 82370d0d393262e17db6682a0e18d335f9df5f4c Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 13 Dec 2024 12:10:25 -0500 Subject: [PATCH 02/10] fix places where the p200_96 wasn't being properly processed --- .../InstrumentMountItem/ProtocolInstrumentMountItem.tsx | 9 ++++++--- app/src/organisms/PipetteWizardFlows/BeforeBeginning.tsx | 5 ++++- app/src/organisms/PipetteWizardFlows/DetachPipette.tsx | 3 ++- .../getPipetteWizardStepsForProtocol.ts | 7 +++++-- app/src/organisms/PipetteWizardFlows/hooks.tsx | 8 ++++++-- .../python/opentrons_shared_data/pipette/load_data.py | 2 +- 6 files changed, 24 insertions(+), 10 deletions(-) diff --git a/app/src/organisms/ODD/InstrumentMountItem/ProtocolInstrumentMountItem.tsx b/app/src/organisms/ODD/InstrumentMountItem/ProtocolInstrumentMountItem.tsx index 86ae69e4107..09a144a84a2 100644 --- a/app/src/organisms/ODD/InstrumentMountItem/ProtocolInstrumentMountItem.tsx +++ b/app/src/organisms/ODD/InstrumentMountItem/ProtocolInstrumentMountItem.tsx @@ -76,8 +76,11 @@ export function ProtocolInstrumentMountItem( [] ) const [flowType, setFlowType] = useState(FLOWS.ATTACH) - const selectedPipette = - speccedName === 'p1000_96' ? NINETY_SIX_CHANNEL : SINGLE_MOUNT_PIPETTES + const is96ChannelPipette = + speccedName === 'p1000_96' || speccedName === 'p200_96' + const selectedPipette = is96ChannelPipette + ? NINETY_SIX_CHANNEL + : SINGLE_MOUNT_PIPETTES const handleCalibrate: MouseEventHandler = () => { setFlowType(FLOWS.CALIBRATE) @@ -95,7 +98,7 @@ export function ProtocolInstrumentMountItem( setShowPipetteWizardFlow(true) } } - const is96ChannelPipette = speccedName === 'p1000_96' + const isAttachedWithCal = attachedInstrument != null && attachedInstrument.ok && diff --git a/app/src/organisms/PipetteWizardFlows/BeforeBeginning.tsx b/app/src/organisms/PipetteWizardFlows/BeforeBeginning.tsx index a69e095a674..88143b83a69 100644 --- a/app/src/organisms/PipetteWizardFlows/BeforeBeginning.tsx +++ b/app/src/organisms/PipetteWizardFlows/BeforeBeginning.tsx @@ -148,7 +148,10 @@ export const BeforeBeginning = ( const displayName = pipetteDisplayName ?? requiredPipette.pipetteName bodyTranslationKey = 'remove_labware' - if (requiredPipette.pipetteName === 'p1000_96') { + if ( + requiredPipette.pipetteName === 'p1000_96' || + requiredPipette.pipetteName === 'p200_96' + ) { equipmentList = [ { ...NINETY_SIX_CHANNEL_PIPETTE, displayName }, CALIBRATION_PROBE, diff --git a/app/src/organisms/PipetteWizardFlows/DetachPipette.tsx b/app/src/organisms/PipetteWizardFlows/DetachPipette.tsx index 9d83f3d3e75..b026c40484c 100644 --- a/app/src/organisms/PipetteWizardFlows/DetachPipette.tsx +++ b/app/src/organisms/PipetteWizardFlows/DetachPipette.tsx @@ -86,7 +86,8 @@ export const DetachPipette = (props: DetachPipetteProps): JSX.Element => { } const memoizedAttachedPipettes = useMemo(() => attachedPipettes, []) const is96ChannelPipette = - memoizedAttachedPipettes[mount]?.instrumentName === 'p1000_96' + memoizedAttachedPipettes[mount]?.instrumentName === 'p1000_96' || + memoizedAttachedPipettes[mount]?.instrumentName === 'p200_96' const pipetteName = attachedPipettes[mount] != null ? attachedPipettes[mount]?.displayName diff --git a/app/src/organisms/PipetteWizardFlows/getPipetteWizardStepsForProtocol.ts b/app/src/organisms/PipetteWizardFlows/getPipetteWizardStepsForProtocol.ts index 296c428bc75..f0c40e3b408 100644 --- a/app/src/organisms/PipetteWizardFlows/getPipetteWizardStepsForProtocol.ts +++ b/app/src/organisms/PipetteWizardFlows/getPipetteWizardStepsForProtocol.ts @@ -413,8 +413,11 @@ export const getPipetteWizardStepsForProtocol = ( ): PipetteWizardStep[] | null => { const requiredPipette = pipetteInfo.find(pipette => pipette.mount === mount) const ninetySixChannelAttached = - attachedPipettes[LEFT]?.instrumentName === 'p1000_96' - const ninetySixChannelRequested = requiredPipette?.pipetteName === 'p1000_96' + attachedPipettes[LEFT]?.instrumentName === 'p1000_96' || + attachedPipettes[LEFT]?.instrumentName === 'p200_96' + const ninetySixChannelRequested = + requiredPipette?.pipetteName === 'p1000_96' || + requiredPipette?.pipetteName === 'p200_96' if (requiredPipette == null) { // return empty array if no pipette is required in the protocol diff --git a/app/src/organisms/PipetteWizardFlows/hooks.tsx b/app/src/organisms/PipetteWizardFlows/hooks.tsx index 4d07586c9de..00b7ede1dd9 100644 --- a/app/src/organisms/PipetteWizardFlows/hooks.tsx +++ b/app/src/organisms/PipetteWizardFlows/hooks.tsx @@ -90,10 +90,14 @@ export function usePipetteFlowWizardHeaderText( ) } else if ( attachedPipettes[LEFT]?.data.channels === 96 && - mountPipette?.pipetteName !== 'p1000_96' + mountPipette?.pipetteName !== 'p1000_96' && + mountPipette?.pipetteName !== 'p200_96' ) { return t('detach_96_attach_mount', { mount: capitalizedMount }) - } else if (leftPipette?.pipetteName === 'p1000_96') { + } else if ( + leftPipette?.pipetteName === 'p1000_96' || + leftPipette?.pipetteName === 'p200_96' + ) { if (isGantryEmpty) { return t('attach_96_channel') } else if ( diff --git a/shared-data/python/opentrons_shared_data/pipette/load_data.py b/shared-data/python/opentrons_shared_data/pipette/load_data.py index f495713b3d8..eed1947f531 100644 --- a/shared-data/python/opentrons_shared_data/pipette/load_data.py +++ b/shared-data/python/opentrons_shared_data/pipette/load_data.py @@ -128,7 +128,7 @@ def load_serial_lookup_table() -> Dict[str, str]: "eight_channel": "multi", "eight_channel_em": "multi_em", } - _model_shorthand = {"p1000": "p1k", "p300": "p3h"} + _model_shorthand = {"p1000": "p1k", "p300": "p3h", "p200": "p2h"} for channel_dir in _dirs_in(config_path): for model_dir in _dirs_in(channel_dir): for version_file in model_dir.iterdir(): From ecb6a380ee9577d2239a6b6b214db736b14efb8f Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 13 Dec 2024 12:13:39 -0500 Subject: [PATCH 03/10] pull in all the changes to the hardware-tesing repo that have been made --- hardware-testing/Makefile | 7 + .../hardware_testing/gravimetric/__main__.py | 28 +- .../hardware_testing/gravimetric/config.py | 66 +++- .../hardware_testing/gravimetric/execute.py | 2 +- .../gravimetric/execute_photometric.py | 1 + .../hardware_testing/gravimetric/helpers.py | 1 + .../gravimetric/increments.py | 48 ++- .../gravimetric/liquid_class/defaults.py | 281 ++++++++++++++++-- .../gravimetric/liquid_class/definition.py | 4 + .../gravimetric/liquid_class/pipetting.py | 26 +- .../hardware_testing/gravimetric/report.py | 2 + .../gravimetric/workarounds.py | 3 +- .../hardware_testing/liquid_sense/__main__.py | 25 +- .../hardware_testing/liquid_sense/execute.py | 39 ++- .../opentrons_api/helpers_ot3.py | 2 + .../gravimetric_cavity_ot3_p50_single.py | 31 ++ .../gravimetric/gravimetric_ot3_p1000_96.py | 1 + ...metric_ot3_p1000_96_20ul_tip-increment .py | 28 ++ ...imetric_ot3_p1000_96_50ul_tip-increment.py | 28 ++ .../gravimetric/gravimetric_ot3_p200_96.py | 3 +- .../gravimetric/gravimetric_ot3_p50_single.py | 1 + .../gravimetric/photometric_ot3_p200_96_sz.py | 37 +++ .../photometric/photometric_ot3_p1000_96.py | 3 +- .../photometric/photometric_ot3_p200_96.py | 3 +- .../liquid_sense_ot3_p200_96_vial.py | 41 +++ 25 files changed, 620 insertions(+), 91 deletions(-) create mode 100644 hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_cavity_ot3_p50_single.py create mode 100644 hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_20ul_tip-increment .py create mode 100644 hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_50ul_tip-increment.py create mode 100644 hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/photometric_ot3_p200_96_sz.py create mode 100644 hardware-testing/hardware_testing/protocols/liquid_sense_lpc/liquid_sense_ot3_p200_96_vial.py diff --git a/hardware-testing/Makefile b/hardware-testing/Makefile index 45b50b5a579..a3cdbe28417 100755 --- a/hardware-testing/Makefile +++ b/hardware-testing/Makefile @@ -100,6 +100,7 @@ test-photometric: $(python) -m hardware_testing.gravimetric --photometric --simulate --pipette 1000 --channels 96 --tip 50 --trials 1 $(python) -m hardware_testing.gravimetric --photometric --simulate --pipette 1000 --channels 96 --tip 200 --trials 1 $(python) -m hardware_testing.gravimetric --photometric --simulate --pipette 200 --channels 96 --tip 50 --trials 1 + $(python) -m hardware_testing.gravimetric --photometric --simulate --pipette 200 --channels 96 --tip 20 --trials 1 .PHONY: test-gravimetric-single test-gravimetric-single: @@ -123,6 +124,7 @@ test-gravimetric-multi: test-gravimetric-96: $(python) -m hardware_testing.gravimetric --simulate --pipette 1000 --channels 96 --trials 2 --no-blank $(python) -m hardware_testing.gravimetric --simulate --pipette 200 --channels 96 --trials 2 --no-blank + $(python) -m hardware_testing.gravimetric --simulate --pipette 200 --channels 96 --trials 1 --no-blank --increment --tip 20 .PHONY: test-gravimetric test-gravimetric: @@ -229,6 +231,11 @@ push-no-restart-ot3: sdist Pipfile.lock .PHONY: push-ot3 push-ot3: push-no-restart-ot3 push-plot-webpage-ot3 push-description-ot3 push-labware-ot3 +.PHONE: open-dev-app +open-dev-app: + cd .. && $(MAKE) -C app dev + + .PHONY: push-all push-all: clean wheel push-no-restart push-plot-webpage-ot3 diff --git a/hardware-testing/hardware_testing/gravimetric/__main__.py b/hardware-testing/hardware_testing/gravimetric/__main__.py index f297f0e7e3a..0c32f1f70b4 100644 --- a/hardware-testing/hardware_testing/gravimetric/__main__.py +++ b/hardware-testing/hardware_testing/gravimetric/__main__.py @@ -70,11 +70,12 @@ GRAVIMETRIC_CFG_INCREMENT = { 50: { - 1: {50: gravimetric_ot3_p50_single}, + 1: {20: gravimetric_ot3_p50_single, 50: gravimetric_ot3_p50_single}, 8: {50: gravimetric_ot3_p50_multi_50ul_tip_increment}, }, 200: { 96: { + 20: gravimetric_ot3_p200_96, 50: gravimetric_ot3_p200_96, 200: gravimetric_ot3_p200_96, }, @@ -117,6 +118,7 @@ PHOTOMETRIC_CFG = { 50: { 1: { + 20: photometric_ot3_p50_single, 50: photometric_ot3_p50_single, }, 8: { @@ -124,7 +126,11 @@ }, }, 200: { - 96: {50: photometric_ot3_p200_96, 200: photometric_ot3_p200_96}, + 96: { + 20: photometric_ot3_p200_96, + 50: photometric_ot3_p200_96, + 200: photometric_ot3_p200_96, + }, }, 1000: { 1: { @@ -137,7 +143,11 @@ 200: photometric_ot3_p1000_multi, 1000: photometric_ot3_p1000_multi, }, - 96: {50: photometric_ot3_p1000_96, 200: photometric_ot3_p1000_96}, + 96: { + 20: photometric_ot3_p1000_96, + 50: photometric_ot3_p1000_96, + 200: photometric_ot3_p1000_96, + }, }, } @@ -177,11 +187,11 @@ def _get_protocol_context(cls, args: argparse.Namespace) -> ProtocolContext: "Starting opentrons-robot-server, so we can http GET labware offsets" ) LABWARE_OFFSETS.extend(workarounds.http_get_all_labware_offsets()) - ui.print_info(f"found {len(LABWARE_OFFSETS)} offsets:") - for offset in LABWARE_OFFSETS: - ui.print_info(f"\t{offset.createdAt}:") - ui.print_info(f"\t\t{offset.definitionUri}") - ui.print_info(f"\t\t{offset.vector}") + # ui.print_info(f"found {len(LABWARE_OFFSETS)} offsets:") + # for offset in LABWARE_OFFSETS: + # ui.print_info(f"\t{offset.createdAt}:") + # ui.print_info(f"\t\t{offset.definitionUri}") + # ui.print_info(f"\t\t{offset.vector}") # gather the custom labware (for simulation) custom_defs = {} if args.simulate: @@ -572,7 +582,7 @@ def _main( parser.add_argument("--simulate", action="store_true") parser.add_argument("--pipette", type=int, choices=[50, 200, 1000], required=True) parser.add_argument("--channels", type=int, choices=[1, 8, 96], default=1) - parser.add_argument("--tip", type=int, choices=[0, 50, 200, 1000], default=0) + parser.add_argument("--tip", type=int, choices=[0, 20, 50, 200, 1000], default=0) parser.add_argument("--trials", type=int, default=0) parser.add_argument("--increment", action="store_true") parser.add_argument("--return-tip", action="store_true") diff --git a/hardware-testing/hardware_testing/gravimetric/config.py b/hardware-testing/hardware_testing/gravimetric/config.py index 968de3ecca7..ef7f989faa4 100644 --- a/hardware-testing/hardware_testing/gravimetric/config.py +++ b/hardware-testing/hardware_testing/gravimetric/config.py @@ -88,30 +88,40 @@ class PhotometricConfig(VolumetricConfig): LIQUID_PROBE_SETTINGS: Dict[int, Dict[int, Dict[int, Dict[str, int]]]] = { 50: { 1: { + 20: { + "mount_speed": 5, + "plunger_speed": 15, + "sensor_threshold_pascals": 15, + }, 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, }, 8: { 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, }, }, 200: { 96: { + 20: { + "mount_speed": 5, + "plunger_speed": 5, + "sensor_threshold_pascals": 15, + }, 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 5, "sensor_threshold_pascals": 15, }, 200: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 5, "sensor_threshold_pascals": 15, }, } @@ -120,51 +130,56 @@ class PhotometricConfig(VolumetricConfig): 1: { 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, 200: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, 1000: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, }, 8: { 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, 200: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, 1000: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 15, "sensor_threshold_pascals": 15, }, }, 96: { + 20: { + "mount_speed": 5, + "plunger_speed": 5, + "sensor_threshold_pascals": 15, + }, 50: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 5, "sensor_threshold_pascals": 15, }, 200: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 5, "sensor_threshold_pascals": 15, }, 1000: { "mount_speed": 5, - "plunger_speed": 20, + "plunger_speed": 5, "sensor_threshold_pascals": 15, }, }, @@ -194,6 +209,7 @@ def _get_liquid_probe_settings( QC_VOLUMES_G: Dict[int, Dict[int, List[Tuple[int, List[float]]]]] = { 1: { 50: [ # P50 + (20, [1.0, 20.0]), (50, [1.0, 50.0]), # T50 ], 1000: [ # P1000 @@ -214,10 +230,12 @@ def _get_liquid_probe_settings( }, 96: { 200: [ + (20, [0.5, 1.0]), # T20 (50, [1.0, 50.0]), # T50 (200, [200.0]), # T200 ], 1000: [ # P1000 + (20, [5.0]), (50, [5.0]), # T50 (200, [200.0]), # T200 (1000, [1000.0]), # T1000 @@ -279,7 +297,8 @@ def _get_liquid_probe_settings( }, 96: { 200: [ - (50, [1.0, 5.0]), # T50 + (20, [1.0, 0.5]), # T50 + (50, [50.0]), # T50 (200, [200.0]), # T200 ], 1000: [ # P1000 @@ -311,6 +330,11 @@ def _get_liquid_probe_settings( # channels: [Pipette: [tip: [Volume: (%d, Cv)]]] 1: { 50: { # P50 + 20: { + 1.0: (5.0, 4.0), + 10.0: (1.0, 0.5), + 20.0: (1, 0.4), + }, 50: { 1.0: (5.0, 4.0), 10.0: (1.0, 0.5), @@ -363,12 +387,16 @@ def _get_liquid_probe_settings( }, 96: { 200: { - 50: { # T50 + 20: { # T20 + 0.5: (2.5, 2.0), 1.0: (2.5, 2.0), 2.0: (2.5, 2.0), 3.0: (2.5, 2.0), 5.0: (2.5, 2.0), 10.0: (3.1, 1.7), + }, + 50: { # T50 + 1.0: (2.5, 2.0), 50.0: (1.5, 0.75), }, 200: { # T200 @@ -378,6 +406,14 @@ def _get_liquid_probe_settings( }, }, 1000: { # P1000 + 20: { # T20 + 1.0: (2.5, 2.0), + 2.0: (2.5, 2.0), + 3.0: (2.5, 2.0), + 5.0: (2.5, 2.0), + 10.0: (3.1, 1.7), + 20.0: (3.1, 1.7), + }, 50: { # T50 1.0: (2.5, 2.0), 2.0: (2.5, 2.0), diff --git a/hardware-testing/hardware_testing/gravimetric/execute.py b/hardware-testing/hardware_testing/gravimetric/execute.py index 44752543fd5..118eb164bcb 100644 --- a/hardware-testing/hardware_testing/gravimetric/execute.py +++ b/hardware-testing/hardware_testing/gravimetric/execute.py @@ -591,7 +591,7 @@ def run(cfg: config.GravimetricConfig, resources: TestResources) -> None: # noq assert resources.recorder is not None recorder = resources.recorder if resources.ctx.is_simulating(): - start_sim_mass = {50: 15, 200: 200, 1000: 200} + start_sim_mass = {20: 5, 50: 15, 200: 200, 1000: 200} resources.recorder.set_simulation_mass(start_sim_mass[cfg.tip_volume]) os.makedirs( f"{resources.test_report.parent}/{resources.test_report._run_id}", exist_ok=True diff --git a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py index 217109dd89d..c0c705019e2 100644 --- a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py +++ b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py @@ -46,6 +46,7 @@ "B": {"min": 10, "max": 49.99}, "C": {"min": 2, "max": 9.999}, "D": {"min": 1, "max": 1.999}, + "E": {"min": 0, "max": 0.9999}, } _MIN_START_VOLUME_UL = {1: 500, 8: 3000, 96: 30000} _MIN_END_VOLUME_UL = {1: 400, 8: 3000, 96: 10000} diff --git a/hardware-testing/hardware_testing/gravimetric/helpers.py b/hardware-testing/hardware_testing/gravimetric/helpers.py index fdeb8fa636e..5b3fcdc7a7e 100644 --- a/hardware-testing/hardware_testing/gravimetric/helpers.py +++ b/hardware-testing/hardware_testing/gravimetric/helpers.py @@ -485,6 +485,7 @@ def _load_tipracks( ) for slot in cfg.slots_tiprack ] + print(f"LOAD TIPRack{use_adapters}") for ls in tiprack_load_settings: ui.print_info(f'Loading tiprack "{ls[1]}" in slot #{ls[0]}') diff --git a/hardware-testing/hardware_testing/gravimetric/increments.py b/hardware-testing/hardware_testing/gravimetric/increments.py index 76c90a45b44..069e879438c 100644 --- a/hardware-testing/hardware_testing/gravimetric/increments.py +++ b/hardware-testing/hardware_testing/gravimetric/increments.py @@ -267,9 +267,27 @@ }, 96: { 200: { + 20: { + "default": [ + 0.800, + 1.000, + 1.300, + 1.700, + 3.000, + 5.000, + 10.000, + 15.000, + 20.000, + 24.000, + ], + }, 50: { "default": [ + 0.700, + 1.000, + 1.500, 2.000, + 2.500, 3.000, 4.000, 5.000, @@ -283,41 +301,21 @@ 40.000, 60.000, ], - "lowVolumeDefault": [ - 1.100, - 1.200, - 1.370, - 1.700, - 2.040, - 2.660, - 3.470, - 3.960, - 4.350, - 4.800, - 5.160, - 5.890, - 6.730, - 8.200, - 10.020, - 11.100, - 14.910, - 28.940, - 48.27, - ], }, 200: { "default": [ + 1.000, 2.000, - 3.000, 4.000, - 5.000, 6.000, - 7.000, 8.000, - 9.000, 10.000, + 20.000, 50.000, 100.000, + 150.000, + 200.000, + 210.000, 220.000, ], }, diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py index c7021e60585..57941c27787 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py @@ -11,6 +11,8 @@ _default_submerge_aspirate_mm = 1.5 _p50_multi_submerge_aspirate_mm = 1.5 _default_submerge_dispense_mm = 1.5 +_p200_default_submerge_aspirate_mm = 2.5 +_p200_default_submerge_dispense_mm = 3.0 _default_retract_mm = 5.0 _default_retract_discontinuity = 20 @@ -25,6 +27,38 @@ _dispense_defaults: Dict[int, Dict[int, Dict[int, Dict[int, DispenseSettings]]]] = { 1: { 50: { # P50 + 20: { # T20 + 1: DispenseSettings( # 1uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=57, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=7, + blow_out_flow_rate=57, + ), + 10: DispenseSettings( # 10uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=57, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=2, + blow_out_flow_rate=57, + ), + 20: DispenseSettings( # 20uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=57, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=2, + blow_out_flow_rate=57, + ), + }, 50: { # T50 1: DispenseSettings( # 1uL z_submerge_depth=_default_submerge_dispense_mm, @@ -34,6 +68,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=7, + blow_out_flow_rate=57, ), 10: DispenseSettings( # 10uL z_submerge_depth=_default_submerge_dispense_mm, @@ -43,6 +78,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=2, + blow_out_flow_rate=57, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -52,6 +88,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=2, + blow_out_flow_rate=57, ), }, }, @@ -65,6 +102,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=318, ), 10: DispenseSettings( # 10uL z_submerge_depth=_default_submerge_dispense_mm, @@ -74,6 +112,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=418, ), 50: DispenseSettings( # 10uL z_submerge_depth=_default_submerge_dispense_mm, @@ -83,6 +122,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=418, ), }, 200: { # T200 @@ -94,6 +134,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -103,6 +144,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), 200: DispenseSettings( # 200uL z_submerge_depth=_default_submerge_dispense_mm, @@ -112,6 +154,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), }, 1000: { # T1000 @@ -123,6 +166,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=160, ), 100: DispenseSettings( # 100uL z_submerge_depth=_default_submerge_dispense_mm, @@ -132,6 +176,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=716, ), 1000: DispenseSettings( # 1000uL z_submerge_depth=_default_submerge_dispense_mm, @@ -141,6 +186,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=716, ), }, }, @@ -156,6 +202,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=6, + blow_out_flow_rate=57, ), 10: DispenseSettings( # 5uL z_submerge_depth=_default_submerge_dispense_mm, @@ -165,6 +212,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=2, + blow_out_flow_rate=57, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -174,6 +222,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=2, + blow_out_flow_rate=57, ), }, }, @@ -187,6 +236,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=318, ), 10: DispenseSettings( # 10uL z_submerge_depth=_default_submerge_dispense_mm, @@ -196,6 +246,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=478, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -205,6 +256,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=478, ), }, 200: { # T200 @@ -216,6 +268,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -225,6 +278,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), 200: DispenseSettings( # 200uL z_submerge_depth=_default_submerge_dispense_mm, @@ -234,6 +288,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=716, ), }, 1000: { # T1000 @@ -245,6 +300,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=160, ), 100: DispenseSettings( # 100uL z_submerge_depth=_default_submerge_dispense_mm, @@ -254,6 +310,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=716, ), 1000: DispenseSettings( # 1000uL z_submerge_depth=_default_submerge_dispense_mm, @@ -263,12 +320,45 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=716, ), }, }, }, 96: { 1000: { # P1000 + 20: { # T20 + 1: DispenseSettings( # 5uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=80, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=80, + ), + 5: DispenseSettings( # 10uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=80, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=80, + ), + 20: DispenseSettings( # 50uL + z_submerge_depth=_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=80, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=80, + ), + }, 50: { # T50 5: DispenseSettings( # 5uL z_submerge_depth=_default_submerge_dispense_mm, @@ -278,6 +368,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), 10: DispenseSettings( # 10uL z_submerge_depth=_default_submerge_dispense_mm, @@ -287,6 +378,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -296,6 +388,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), }, 200: { # T200 @@ -307,6 +400,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), 50: DispenseSettings( # 50uL z_submerge_depth=_default_submerge_dispense_mm, @@ -316,6 +410,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), 200: DispenseSettings( # 200uL z_submerge_depth=_default_submerge_dispense_mm, @@ -325,6 +420,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=80, ), }, 1000: { # T1000 @@ -336,6 +432,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=80, ), 100: DispenseSettings( # 100uL z_submerge_depth=_default_submerge_dispense_mm, @@ -345,6 +442,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=80, ), 1000: DispenseSettings( # 1000uL z_submerge_depth=_default_submerge_dispense_mm, @@ -354,66 +452,105 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=20, + blow_out_flow_rate=80, ), }, }, 200: { # P200 + 20: { # T20 + 1: DispenseSettings( # 5uL + z_submerge_depth=_p200_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=10, + ), + 5: DispenseSettings( # 10uL + z_submerge_depth=_p200_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=10, + ), + 20: DispenseSettings( # 50uL + z_submerge_depth=_p200_default_submerge_dispense_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_dispense_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + blow_out_submerged=5, + blow_out_flow_rate=10, + ), + }, 50: { # T50 5: DispenseSettings( # 5uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=10, ), 10: DispenseSettings( # 10uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=10, ), 50: DispenseSettings( # 50uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=5, + blow_out_flow_rate=10, ), }, 200: { # T200 5: DispenseSettings( # 5uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, + blow_out_submerged=15, + blow_out_flow_rate=10, ), 50: DispenseSettings( # 50uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, + blow_out_submerged=15, + blow_out_flow_rate=10, ), 200: DispenseSettings( # 200uL - z_submerge_depth=_default_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, + blow_out_submerged=15, + blow_out_flow_rate=10, ), }, }, @@ -423,6 +560,38 @@ _aspirate_defaults: Dict[int, Dict[int, Dict[int, Dict[int, AspirateSettings]]]] = { 1: { 50: { # P50 + 20: { # T20 + 1: AspirateSettings( # 1uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=35, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 10: AspirateSettings( # 10uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=23.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 20: AspirateSettings( # 20uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_p50_ul_sec_sec, + plunger_flow_rate=35, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + }, 50: { # T50 1: AspirateSettings( # 1uL z_submerge_depth=_default_submerge_aspirate_mm, @@ -691,6 +860,38 @@ }, 96: { 1000: { # P1000 + 20: { # T20 + 1: AspirateSettings( # 5uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 5: AspirateSettings( # 10uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 20: AspirateSettings( # 50uL + z_submerge_depth=_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + }, 50: { # T50 5: AspirateSettings( # 5uL z_submerge_depth=_default_submerge_aspirate_mm, @@ -789,9 +990,41 @@ }, }, 200: { # P200 + 20: { # T20 + 1: AspirateSettings( # 5uL + z_submerge_depth=_p200_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 5: AspirateSettings( # 10uL + z_submerge_depth=_p200_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + 20: AspirateSettings( # 50uL + z_submerge_depth=_p200_default_submerge_aspirate_mm, + plunger_acceleration=_default_accel_96ch_ul_sec_sec, + plunger_flow_rate=6.5, # ul/sec + delay=_default_aspirate_delay_seconds, + z_retract_discontinuity=_default_retract_discontinuity, + z_retract_height=_default_retract_mm, + leading_air_gap=0, + trailing_air_gap=0.1, + ), + }, 50: { # T50 5: AspirateSettings( # 5uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, @@ -801,7 +1034,7 @@ trailing_air_gap=0.1, ), 10: AspirateSettings( # 10uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, @@ -811,7 +1044,7 @@ trailing_air_gap=0.1, ), 50: AspirateSettings( # 50uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, @@ -823,9 +1056,9 @@ }, 200: { # T200 5: AspirateSettings( # 5uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -833,9 +1066,9 @@ trailing_air_gap=2, ), 50: AspirateSettings( # 50uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -843,9 +1076,9 @@ trailing_air_gap=3.5, ), 200: AspirateSettings( # 200uL - z_submerge_depth=_default_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=80, # ul/sec + plunger_flow_rate=15, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/definition.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/definition.py index 229d16c4b1a..9f03efe759a 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/definition.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/definition.py @@ -27,6 +27,7 @@ class DispenseSettings(LiquidSettings): """Dispense Settings.""" blow_out_submerged: float # microliters + blow_out_flow_rate: float # ul/s @dataclass @@ -90,5 +91,8 @@ def _interp(lower: float, upper: float) -> float: blow_out_submerged=_interp( a.dispense.blow_out_submerged, b.dispense.blow_out_submerged ), + blow_out_flow_rate=_interp( + a.dispense.blow_out_flow_rate, b.dispense.blow_out_flow_rate + ), ), ) diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/pipetting.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/pipetting.py index 9f059559f13..81fb1180580 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/pipetting.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/pipetting.py @@ -313,7 +313,7 @@ def _dispense_on_retract() -> None: # PHASE 1: APPROACH pipette.flow_rate.aspirate = liquid_class.aspirate.plunger_flow_rate pipette.flow_rate.dispense = liquid_class.dispense.plunger_flow_rate - pipette.flow_rate.blow_out = liquid_class.dispense.plunger_flow_rate + pipette.flow_rate.blow_out = liquid_class.dispense.blow_out_flow_rate pipette.move_to(well.bottom(approach_mm).move(channel_offset)) _aspirate_on_approach() if aspirate or mix else _dispense_on_approach() @@ -388,10 +388,20 @@ def aspirate_with_liquid_class( clear_accuracy_function: bool = False, ) -> None: """Aspirate with liquid class.""" - pip_size = 50 if "50" in pipette.name else 1000 + if "50" in pipette.name: + pip_size = 50 + elif "200" in pipette.name: + pip_size = 200 + else: + pip_size = 1000 + print(f"pip_size:{pip_size}") + print(f"pipette channels :{pipette.channels}") + print(f"tip volume :{tip_volume}") + # pip_size = 50 if "50" in pipette.name else 1000 liquid_class = get_liquid_class( pip_size, pipette.channels, tip_volume, int(aspirate_volume) ) + print(f"aspirate liquid class : {(liquid_class.aspirate)}") _pipette_with_liquid_settings( ctx, pipette, @@ -426,10 +436,20 @@ def dispense_with_liquid_class( clear_accuracy_function: bool = False, ) -> None: """Dispense with liquid class.""" - pip_size = 50 if "50" in pipette.name else 1000 + if "50" in pipette.name: + pip_size = 50 + elif "200" in pipette.name: + pip_size = 200 + else: + pip_size = 1000 + print(f"pip_size:{pip_size}") + print(f"pipette channels :{pipette.channels}") + print(f"tip volume :{tip_volume}") + # pip_size = 50 if "50" in pipette.name else 1000 liquid_class = get_liquid_class( pip_size, pipette.channels, tip_volume, int(dispense_volume) ) + print(f"dispense liquid class : {(liquid_class.dispense)}") _pipette_with_liquid_settings( ctx, pipette, diff --git a/hardware-testing/hardware_testing/gravimetric/report.py b/hardware-testing/hardware_testing/gravimetric/report.py index 3a15e0b213e..94b80978e1d 100644 --- a/hardware-testing/hardware_testing/gravimetric/report.py +++ b/hardware-testing/hardware_testing/gravimetric/report.py @@ -104,6 +104,7 @@ def create_csv_test_report_photometric( lines=[ CSVLine("robot", [str]), CSVLine("pipette", [str]), + CSVLine("tips_20ul", [str]), CSVLine("tips_50ul", [str]), CSVLine("tips_200ul", [str]), CSVLine("tips_1000ul", [str]), @@ -205,6 +206,7 @@ def _field_type_not_using_typing(t: Any) -> Any: lines=[ CSVLine("robot", [str]), CSVLine("pipette", [str]), + CSVLine("tips_20ul", [str]), CSVLine("tips_50ul", [str]), CSVLine("tips_200ul", [str]), CSVLine("tips_1000ul", [str]), diff --git a/hardware-testing/hardware_testing/gravimetric/workarounds.py b/hardware-testing/hardware_testing/gravimetric/workarounds.py index 7c182ddd079..5bb00de5575 100644 --- a/hardware-testing/hardware_testing/gravimetric/workarounds.py +++ b/hardware-testing/hardware_testing/gravimetric/workarounds.py @@ -4,7 +4,6 @@ from typing import List import platform from json import loads as json_loads -from hardware_testing.data import ui from opentrons.hardware_control import SyncHardwareAPI from opentrons.protocol_api.labware import Labware from opentrons.protocol_api import InstrumentContext, ProtocolContext @@ -96,7 +95,7 @@ def _offset_applies_to_labware(_o: dict) -> bool: return False offset_uri = _o["definitionUri"] if offset_uri[0:-1] != lw_uri[0:-1]: # drop schema version number - ui.print_info(f"{_o} does not apply {offset_uri} != {lw_uri}") + # ui.print_info(f"{_o} does not apply {offset_uri} != {lw_uri}") # NOTE: we're allowing tip-rack adapters to share offsets # because it doesn't make a difference which volume # of tip it holds diff --git a/hardware-testing/hardware_testing/liquid_sense/__main__.py b/hardware-testing/hardware_testing/liquid_sense/__main__.py index 084f99eadee..6d3bf8e6031 100644 --- a/hardware-testing/hardware_testing/liquid_sense/__main__.py +++ b/hardware-testing/hardware_testing/liquid_sense/__main__.py @@ -38,6 +38,7 @@ from hardware_testing.protocols.liquid_sense_lpc import ( liquid_sense_ot3_p50_single_vial, liquid_sense_ot3_p50_multi_vial, + liquid_sense_ot3_p200_96_vial, liquid_sense_ot3_p1000_96_vial, liquid_sense_ot3_p1000_single_vial, liquid_sense_ot3_p1000_multi_vial, @@ -53,7 +54,7 @@ CREDENTIALS_PATH = "/var/lib/jupyter/notebooks/abr.json" -API_LEVEL = "2.18" +API_LEVEL = "2.21" LABWARE_OFFSETS: List[LabwareOffset] = [] @@ -75,6 +76,9 @@ 1: liquid_sense_ot3_p50_single_vial, 8: liquid_sense_ot3_p50_multi_vial, }, + 200: { + 96: liquid_sense_ot3_p200_96_vial, + }, 1000: { 1: liquid_sense_ot3_p1000_single_vial, 8: liquid_sense_ot3_p1000_multi_vial, @@ -92,6 +96,7 @@ 8: "p1000_multi_flex", 96: "p1000_96_flex", }, + 200: {96: "p200_96_flex"}, } @@ -188,8 +193,10 @@ def build_run_args(cls, args: argparse.Namespace) -> "RunArgs": if args.tip == 0: if args.pipette == 1000: tip_volumes: List[int] = [50, 200, 1000] - else: + elif args.pipette == 50: tip_volumes = [50] + else: + tip_volumes = [20, 50, 200] else: tip_volumes = [args.tip] @@ -265,22 +272,24 @@ def build_run_args(cls, args: argparse.Namespace) -> "RunArgs": parser = argparse.ArgumentParser("Pipette Testing") parser.add_argument("--simulate", action="store_true") - parser.add_argument("--pipette", type=int, choices=[50, 1000], required=True) + parser.add_argument("--pipette", type=int, choices=[50, 200, 1000], required=True) parser.add_argument("--mount", type=str, choices=["left", "right"], default="left") parser.add_argument("--channels", type=int, choices=[1, 8, 96], default=1) - parser.add_argument("--tip", type=int, choices=[0, 50, 200, 1000], default=0) + parser.add_argument("--tip", type=int, choices=[0, 20, 50, 200, 1000], default=0) parser.add_argument("--return-tip", action="store_true") - parser.add_argument("--trials", type=int, default=7) - parser.add_argument("--trials-before-jog", type=int, default=7) + parser.add_argument("--trials", type=int, default=10) + parser.add_argument("--trials-before-jog", type=int, default=10) parser.add_argument("--z-speed", type=float, default=5) parser.add_argument("--aspirate", action="store_true") - parser.add_argument("--plunger-speed", type=float, default=15) + parser.add_argument("--plunger-speed", type=float, default=5) parser.add_argument("--no-multi-pass", action="store_true") parser.add_argument("--wet", action="store_true") parser.add_argument("--starting-tip", type=str, default="A1") parser.add_argument("--test-well", type=str, default="A1") parser.add_argument("--p-solo-time", type=float, default=0) - parser.add_argument("--google-sheet-name", type=str, default="LLD-Shared-Data") + parser.add_argument( + "--google-sheet-name", type=str, default="LLD-Shared-Data-96ch-200ul" + ) parser.add_argument( "--gd-parent-folder", type=str, default="1b2V85fDPA0tNqjEhyHOGCWRZYgn8KsGf" ) diff --git a/hardware-testing/hardware_testing/liquid_sense/execute.py b/hardware-testing/hardware_testing/liquid_sense/execute.py index 001abdaa82f..76f5a9f2799 100644 --- a/hardware-testing/hardware_testing/liquid_sense/execute.py +++ b/hardware-testing/hardware_testing/liquid_sense/execute.py @@ -15,9 +15,11 @@ from hardware_testing.data import ui, get_testing_data_directory from opentrons.hardware_control.types import ( InstrumentProbeType, + PipetteSensorId, OT3Mount, Axis, top_types, + PipetteSensorResponseQueue, ) from opentrons.hardware_control.dev_types import PipetteDict @@ -420,6 +422,7 @@ def _run_trial( probes.append(InstrumentProbeType.SECONDARY) probe_target = InstrumentProbeType.BOTH data_files: Dict[InstrumentProbeType, str] = {} + data_capture: PipetteSensorResponseQueue = PipetteSensorResponseQueue() for probe in probes: data_filename = f"pressure_sensor_data-trial{trial}-tip{tip}-{probe.name}.csv" data_file = f"{data_dir}/{run_args.name}/{run_args.run_id}/{data_filename}" @@ -456,8 +459,42 @@ def _run_trial( run_args.recorder.set_sample_tag(f"trial-{trial}-{tip}ul") # TODO add in stuff for secondary probe try: - height = hw_api.liquid_probe(hw_mount, z_distance, lps, probe_target) + height = hw_api.liquid_probe( + hw_mount, z_distance, lps, probe_target, response_queue=data_capture + ) result: LLDResult = LLDResult.success + # write the data files that used to be made automatically + if not run_args.ctx.is_simulating(): + for probe in probes: + sensor_id = ( + PipetteSensorId.S0 + if probe == InstrumentProbeType.PRIMARY + else PipetteSensorId.S1 + ) + as_dict = data_capture.get_nowait() + data = [d.to_float() for d in as_dict[sensor_id]] + with open(data_files[probe], "w") as d_file: + writer = csv.writer(d_file) + writer.writerow( + [ + "time(s)", + "Pressure(pascals)", + "z_velocity(mm/s)", + "plunger_velocity(mm/s)", + "threshold(pascals)", + ] + ) + writer.writerow( + [ + "0", + "0", + f"{run_args.z_speed}", + f"{plunger_speed}", + f"{lqid_cfg['sensor_threshold_pascals']}", + ] + ) + for i in range(len(data)): + writer.writerow([f"{i*0.004}", f"{data[i]}"]) if not run_args.ctx.is_simulating(): for probe in data_files: if _test_for_blockage(data_files[probe], lps.sensor_threshold_pascals): diff --git a/hardware-testing/hardware_testing/opentrons_api/helpers_ot3.py b/hardware-testing/hardware_testing/opentrons_api/helpers_ot3.py index 0905e1cdefd..981c070db6d 100644 --- a/hardware-testing/hardware_testing/opentrons_api/helpers_ot3.py +++ b/hardware-testing/hardware_testing/opentrons_api/helpers_ot3.py @@ -1147,6 +1147,8 @@ def _ul_per_mm_of_shaft_diameter(diameter: float) -> float: pip_nominal_ul_per_mm = _ul_per_mm_of_shaft_diameter(1) elif "p1000" in pip.model.lower(): pip_nominal_ul_per_mm = _ul_per_mm_of_shaft_diameter(4.5) + elif "p200" in pip.model.lower(): + pip_nominal_ul_per_mm = _ul_per_mm_of_shaft_diameter(2) else: raise RuntimeError(f"unexpected pipette model: {pip.model}") # 10000 is an arbitrarily large volume that none of our pipettes can reach diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_cavity_ot3_p50_single.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_cavity_ot3_p50_single.py new file mode 100644 index 00000000000..8d56641eb1d --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_cavity_ot3_p50_single.py @@ -0,0 +1,31 @@ +"""Gravimetric OT3.""" +from opentrons.protocol_api import ProtocolContext +from opentrons.protocol_api._types import OffDeckType + +metadata = {"protocolName": "gravimetric-cavity-ot3-p50-single"} +requirements = {"robotType": "Flex", "apiLevel": "2.15"} + +SLOT_SCALE = 4 +SLOTS_TIPRACK = {20: [2, 3, 5, 6, 7, 8, 9, 10], 50: [2, 3, 5, 6, 7, 8, 9, 10]} +LABWARE_ON_SCALE = "radwag_pipette_calibration_vial" + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + tipracks = [ + ctx.load_labware(f"opentrons_flex_96_tiprack_{size}uL", slot) + for size, slots in SLOTS_TIPRACK.items() + for slot in slots + ] + vial = ctx.load_labware(LABWARE_ON_SCALE, SLOT_SCALE) + pipette = ctx.load_instrument("flex_1channel_50", "left") + for rack in tipracks: + pipette.pick_up_tip(rack["A1"]) + pipette.aspirate(10, vial["A1"].top()) + pipette.dispense(10, vial["A1"].top()) + pipette.drop_tip(home_after=False) + ctx.move_labware( + rack, + new_location=OffDeckType.OFF_DECK, + use_gripper=False, + ) diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96.py index 6fe882f5370..6787297b382 100644 --- a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96.py +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96.py @@ -8,6 +8,7 @@ SLOT_SCALE = 4 SLOTS_TIPRACK = { # TODO: add slot 12 when tipracks are disposable + 20: [2, 3, 5, 6, 7, 8, 9, 10, 11], 50: [2, 3, 5, 6, 7, 8, 9, 10, 11], 200: [2, 3, 5, 6, 7, 8, 9, 10, 11], 1000: [2, 3, 5, 6, 7, 8, 9, 10, 11], diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_20ul_tip-increment .py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_20ul_tip-increment .py new file mode 100644 index 00000000000..e7e2cd28337 --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_20ul_tip-increment .py @@ -0,0 +1,28 @@ +"""Photometric OT3 P1000.""" +from opentrons.protocol_api import ProtocolContext + +metadata = {"protocolName": "gravimetric-ot3-p200-96-20ul-tip"} +requirements = {"robotType": "Flex", "apiLevel": "2.15"} + +SLOT_SCALE = 4 +SLOTS_TIPRACK = { + # TODO: add slot 12 when tipracks are disposable + 20: [2, 3, 5, 6, 7, 8, 9, 10, 11], +} +LABWARE_ON_SCALE = "nest_1_reservoir_195ml" + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + tipracks = [ + ctx.load_labware(f"opentrons_flex_96_tiprack_{size}uL_adp", slot) + for size, slots in SLOTS_TIPRACK.items() + for slot in slots + ] + scale_labware = ctx.load_labware(LABWARE_ON_SCALE, SLOT_SCALE) + pipette = ctx.load_instrument("flex_96channel_200", "left") + for rack in tipracks: + pipette.pick_up_tip(rack["A1"]) + pipette.aspirate(10, scale_labware["A1"].top()) + pipette.dispense(10, scale_labware["A1"].top()) + pipette.drop_tip(home_after=False) diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_50ul_tip-increment.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_50ul_tip-increment.py new file mode 100644 index 00000000000..aaebef0f750 --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p1000_96_50ul_tip-increment.py @@ -0,0 +1,28 @@ +"""Photometric OT3 P1000.""" +from opentrons.protocol_api import ProtocolContext + +metadata = {"protocolName": "gravimetric-ot3-p200-96-50ul-tip"} +requirements = {"robotType": "Flex", "apiLevel": "2.15"} + +SLOT_SCALE = 4 +SLOTS_TIPRACK = { + # TODO: add slot 12 when tipracks are disposable + 50: [2, 3, 5, 6, 7, 8, 9, 10, 11], +} +LABWARE_ON_SCALE = "nest_1_reservoir_195ml" + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + tipracks = [ + ctx.load_labware(f"opentrons_flex_96_tiprack_{size}uL_adp", slot) + for size, slots in SLOTS_TIPRACK.items() + for slot in slots + ] + scale_labware = ctx.load_labware(LABWARE_ON_SCALE, SLOT_SCALE) + pipette = ctx.load_instrument("flex_96channel_200", "left") + for rack in tipracks: + pipette.pick_up_tip(rack["A1"]) + pipette.aspirate(10, scale_labware["A1"].top()) + pipette.dispense(10, scale_labware["A1"].top()) + pipette.drop_tip(home_after=False) diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p200_96.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p200_96.py index 726f5b72533..2847399f1c2 100644 --- a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p200_96.py +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p200_96.py @@ -3,11 +3,12 @@ from opentrons.protocol_api._types import OffDeckType metadata = {"protocolName": "gravimetric-ot3-p200-96"} -requirements = {"robotType": "Flex", "apiLevel": "2.21"} +requirements = {"robotType": "Flex", "apiLevel": "2.15"} SLOT_SCALE = 4 SLOTS_TIPRACK = { # TODO: add slot 12 when tipracks are disposable + 20: [2, 3, 5, 6, 7, 8, 9, 10, 11], 50: [2, 3, 5, 6, 7, 8, 9, 10, 11], 200: [2, 3, 5, 6, 7, 8, 9, 10, 11], } diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p50_single.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p50_single.py index 864aa5342a6..25287d0a9e0 100644 --- a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p50_single.py +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/gravimetric_ot3_p50_single.py @@ -7,6 +7,7 @@ SLOT_SCALE = 4 SLOTS_TIPRACK = { 50: [3], + 20: [6], } LABWARE_ON_SCALE = "radwag_pipette_calibration_vial" diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/photometric_ot3_p200_96_sz.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/photometric_ot3_p200_96_sz.py new file mode 100644 index 00000000000..479c132ce90 --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/gravimetric/photometric_ot3_p200_96_sz.py @@ -0,0 +1,37 @@ +"""Photometric OT3 P1000.""" +from opentrons.protocol_api import ProtocolContext + +metadata = {"protocolName": "photometric-ot3-p200-96"} +requirements = {"robotType": "Flex", "apiLevel": "2.15"} + +SLOTS_TIPRACK = { + 50: [5, 6, 8, 9, 11], + 200: [5, 6, 8, 9, 11], # NOTE: ignoring this tip-rack during run() method + 1000: [5, 6, 8, 9, 11], +} +SLOT_PLATE = 3 +SLOT_RESERVOIR = 2 + +RESERVOIR_LABWARE = "nest_1_reservoir_195ml" +PHOTOPLATE_LABWARE = "corning_96_wellplate_360ul_flat" + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + tipracks = [ + # FIXME: use official tip-racks once available + ctx.load_labware( + f"opentrons_flex_96_tiprack_{size}uL_adp", slot, namespace="custom_beta" + ) + for size, slots in SLOTS_TIPRACK.items() + for slot in slots + if size == 50 # only calibrate 50ul tips for 96ch test + ] + reservoir = ctx.load_labware(RESERVOIR_LABWARE, SLOT_RESERVOIR) + plate = ctx.load_labware(PHOTOPLATE_LABWARE, SLOT_PLATE) + pipette = ctx.load_instrument("flex_96channel_200", "left") + for rack in tipracks: + pipette.pick_up_tip(rack["A1"]) + pipette.aspirate(10, reservoir["A1"].top()) + pipette.dispense(10, plate["A1"].top()) + pipette.drop_tip(home_after=False) diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p1000_96.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p1000_96.py index 2cb4dcc1daf..822c6ba326a 100644 --- a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p1000_96.py +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p1000_96.py @@ -6,6 +6,7 @@ requirements = {"robotType": "Flex", "apiLevel": "2.15"} SLOTS_TIPRACK = { + 20: [5, 6, 8, 9, 11], 50: [5, 6, 8, 9, 11], 200: [5, 6, 8, 9, 11], } @@ -23,7 +24,7 @@ def run(ctx: ProtocolContext) -> None: pipette = ctx.load_instrument("flex_96channel_1000", "left") adapters = [ ctx.load_adapter("opentrons_flex_96_tiprack_adapter", slot) - for slot in SLOTS_TIPRACK[50] + for slot in SLOTS_TIPRACK[20] ] for tip_size in SLOTS_TIPRACK.keys(): tipracks = [ diff --git a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p200_96.py b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p200_96.py index 092c00e5878..5e999596b28 100644 --- a/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p200_96.py +++ b/hardware-testing/hardware_testing/protocols/gravimetric_lpc/photometric/photometric_ot3_p200_96.py @@ -6,6 +6,7 @@ requirements = {"robotType": "Flex", "apiLevel": "2.15"} SLOTS_TIPRACK = { + 20: [5, 6, 8, 9, 11], 50: [5, 6, 8, 9, 11], 200: [5, 6, 8, 9, 11], } @@ -23,7 +24,7 @@ def run(ctx: ProtocolContext) -> None: pipette = ctx.load_instrument("flex_96channel_200", "left") adapters = [ ctx.load_adapter("opentrons_flex_96_tiprack_adapter", slot) - for slot in SLOTS_TIPRACK[50] + for slot in SLOTS_TIPRACK[20] ] for tip_size in SLOTS_TIPRACK.keys(): tipracks = [ diff --git a/hardware-testing/hardware_testing/protocols/liquid_sense_lpc/liquid_sense_ot3_p200_96_vial.py b/hardware-testing/hardware_testing/protocols/liquid_sense_lpc/liquid_sense_ot3_p200_96_vial.py new file mode 100644 index 00000000000..4942f192700 --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/liquid_sense_lpc/liquid_sense_ot3_p200_96_vial.py @@ -0,0 +1,41 @@ +"""lld OT3 P200.""" +from opentrons.protocol_api import ProtocolContext, OFF_DECK + +metadata = {"protocolName": "liquid-sense-ot3-p200-96-vial"} +requirements = {"robotType": "Flex", "apiLevel": "2.21"} + +SLOT_SCALE = 1 +SLOT_DIAL = 9 + +SLOTS_TIPRACK = { + 20: [3], + 50: [3], + 200: [3], +} + +LABWARE_ON_SCALE = "radwag_pipette_calibration_vial" + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + trash = ctx.load_trash_bin("A3") + vial = ctx.load_labware(LABWARE_ON_SCALE, SLOT_SCALE) + dial = ctx.load_labware("dial_indicator", SLOT_DIAL) + pipette = ctx.load_instrument("flex_96channel_1000", "left") + adapters = [ + ctx.load_adapter("opentrons_flex_96_tiprack_adapter", slot) + for slot in SLOTS_TIPRACK[50] + ] + for size, slots in SLOTS_TIPRACK.items(): + tipracks = [ + adapter.load_labware(f"opentrons_flex_96_tiprack_{size}uL") + for adapter in adapters + ] + for rack in tipracks: + pipette.pick_up_tip(rack["A1"]) + pipette.aspirate(10, vial["A1"].top()) + pipette.dispense(10, vial["A1"].top()) + pipette.aspirate(10, dial["A1"].top()) + pipette.dispense(10, dial["A1"].top()) + pipette.drop_tip(trash) + ctx.move_labware(rack, OFF_DECK) From c22f24c32e2e743c697110cd59efb001d7a96788 Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 13 Dec 2024 12:13:50 -0500 Subject: [PATCH 04/10] fix the snapshot tests --- .../fixtureGeneration.test.ts.snap | 137 ++++++++++++++++++ 1 file changed, 137 insertions(+) diff --git a/step-generation/src/__tests__/__snapshots__/fixtureGeneration.test.ts.snap b/step-generation/src/__tests__/__snapshots__/fixtureGeneration.test.ts.snap index c4d02928884..991fdb2edff 100644 --- a/step-generation/src/__tests__/__snapshots__/fixtureGeneration.test.ts.snap +++ b/step-generation/src/__tests__/__snapshots__/fixtureGeneration.test.ts.snap @@ -9345,6 +9345,143 @@ exports[`snapshot tests > makeContext 1`] = ` }, }, }, + "t20": { + "aspirate": { + "default": { + "1": [ + [ + 1.933333, + 2.844459, + 4.750159, + ], + [ + 2.833333, + 1.12901, + 8.066694, + ], + [ + 3.603333, + 0.254744, + 10.543779, + ], + [ + 4.836667, + 1.101839, + 7.491414, + ], + [ + 5.755, + 0.277649, + 11.47775, + ], + [ + 6.643333, + 0.14813, + 12.223126, + ], + [ + 7.548333, + 0.145635, + 12.239705, + ], + [ + 8.475, + 0.15097, + 12.199433, + ], + [ + 13.02, + 0.071736, + 12.870946, + ], + [ + 22.318333, + 0.042305, + 13.254131, + ], + ], + }, + }, + "defaultAspirateFlowRate": { + "default": 6, + "valuesByApiLevel": { + "2.14": 6, + }, + }, + "defaultBlowOutFlowRate": { + "default": 80, + "valuesByApiLevel": { + "2.14": 80, + }, + }, + "defaultDispenseFlowRate": { + "default": 6, + "valuesByApiLevel": { + "2.14": 6, + }, + }, + "defaultFlowAcceleration": 16000, + "defaultPushOutVolume": 2, + "defaultReturnTipHeight": 0.6, + "defaultTipLength": 52, + "dispense": { + "default": { + "1": [ + [ + 1.933333, + 2.844459, + 4.750159, + ], + [ + 2.833333, + 1.12901, + 8.066694, + ], + [ + 3.603333, + 0.254744, + 10.543779, + ], + [ + 4.836667, + 1.101839, + 7.491414, + ], + [ + 5.755, + 0.277649, + 11.47775, + ], + [ + 6.643333, + 0.14813, + 12.223126, + ], + [ + 7.548333, + 0.145635, + 12.239705, + ], + [ + 8.475, + 0.15097, + 12.199433, + ], + [ + 13.02, + 0.071736, + 12.870946, + ], + [ + 22.318333, + 0.042305, + 13.254131, + ], + ], + }, + }, + "uiMaxFlowRate": 189.1, + }, "t200": { "aspirate": { "default": { From 3d02f2468900ebc4db5a92e5e7ce4bf3e645a4b7 Mon Sep 17 00:00:00 2001 From: Andiiiiiiyy Date: Tue, 17 Dec 2024 13:41:48 +0800 Subject: [PATCH 05/10] Pause for inspection --- .../hardware_testing/gravimetric/execute_photometric.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py index c0c705019e2..6be6dd6c1dc 100644 --- a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py +++ b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py @@ -192,6 +192,7 @@ def _record_measurement_and_store(m_type: MeasurementType) -> EnvironmentData: ) _record_measurement_and_store(MeasurementType.ASPIRATE) + input("请记录吸液状态,并尝试拍摄清晰的吸液后的针管照片..........") for i in range(num_dispenses): dest_name = _get_photo_plate_dest(trial.cfg, trial.trial) dest_well = trial.dest[dest_name] @@ -216,6 +217,7 @@ def _record_measurement_and_store(m_type: MeasurementType) -> EnvironmentData: touch_tip=trial.cfg.touch_tip, ) _record_measurement_and_store(MeasurementType.DISPENSE) + input("请记录排液状态,并尝试拍摄清晰的排液后的针管照片..........") trial.pipette._retract() # retract to top of gantry if (i + 1) == num_dispenses: if not trial.cfg.same_tip: From da318ca36e5e427d61d2e9fdeb77e0462196b64e Mon Sep 17 00:00:00 2001 From: Andiiiiiiyy Date: Fri, 20 Dec 2024 15:54:53 +0800 Subject: [PATCH 06/10] changing liquid setting --- .../gravimetric/liquid_class/defaults.py | 30 ++++++++++--------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py index 57941c27787..8dc9da85ee1 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py @@ -13,6 +13,8 @@ _default_submerge_dispense_mm = 1.5 _p200_default_submerge_aspirate_mm = 2.5 _p200_default_submerge_dispense_mm = 3.0 +_default_t20_submerge_aspirate_mm = 0.5 +_default_t20_submerge_dispense_mm = 1.0 _default_retract_mm = 5.0 _default_retract_discontinuity = 20 @@ -459,34 +461,34 @@ 200: { # P200 20: { # T20 1: DispenseSettings( # 5uL - z_submerge_depth=_p200_default_submerge_dispense_mm, + z_submerge_depth=_default_t20_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=1.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, - blow_out_flow_rate=10, + blow_out_submerged=7, + blow_out_flow_rate = 5, ), 5: DispenseSettings( # 10uL z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=2.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, - blow_out_flow_rate=10, + blow_out_submerged=7, + blow_out_flow_rate = 5, ), 20: DispenseSettings( # 50uL z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=5.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=5, - blow_out_flow_rate=10, + blow_out_submerged=7, + blow_out_flow_rate = 5, ), }, 50: { # T50 @@ -992,9 +994,9 @@ 200: { # P200 20: { # T20 1: AspirateSettings( # 5uL - z_submerge_depth=_p200_default_submerge_aspirate_mm, + z_submerge_depth=_default_t20_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=1.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -1004,7 +1006,7 @@ 5: AspirateSettings( # 10uL z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=2.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -1014,7 +1016,7 @@ 20: AspirateSettings( # 50uL z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=6.5, # ul/sec + plunger_flow_rate=5.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, From 9acbb5665955a4f4a91ce65d469bc90fe72293c4 Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 20 Dec 2024 10:50:32 -0500 Subject: [PATCH 07/10] format --- .../hardware_testing/gravimetric/liquid_class/defaults.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py index 8dc9da85ee1..d66092bf3bd 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py @@ -468,7 +468,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=7, - blow_out_flow_rate = 5, + blow_out_flow_rate=5, ), 5: DispenseSettings( # 10uL z_submerge_depth=_p200_default_submerge_dispense_mm, @@ -478,7 +478,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=7, - blow_out_flow_rate = 5, + blow_out_flow_rate=5, ), 20: DispenseSettings( # 50uL z_submerge_depth=_p200_default_submerge_dispense_mm, @@ -488,7 +488,7 @@ z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=7, - blow_out_flow_rate = 5, + blow_out_flow_rate=5, ), }, 50: { # T50 From 7de2e5ec9e4aa872db85d9caba52bc58db2fbce5 Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 20 Dec 2024 11:07:27 -0500 Subject: [PATCH 08/10] fix ci tests --- .../hardware_testing/gravimetric/execute_photometric.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py index 6be6dd6c1dc..a13da2785af 100644 --- a/hardware-testing/hardware_testing/gravimetric/execute_photometric.py +++ b/hardware-testing/hardware_testing/gravimetric/execute_photometric.py @@ -192,7 +192,8 @@ def _record_measurement_and_store(m_type: MeasurementType) -> EnvironmentData: ) _record_measurement_and_store(MeasurementType.ASPIRATE) - input("请记录吸液状态,并尝试拍摄清晰的吸液后的针管照片..........") + if not trial.ctx.is_simulating(): + input("请记录吸液状态,并尝试拍摄清晰的吸液后的针管照片..........") for i in range(num_dispenses): dest_name = _get_photo_plate_dest(trial.cfg, trial.trial) dest_well = trial.dest[dest_name] @@ -217,7 +218,8 @@ def _record_measurement_and_store(m_type: MeasurementType) -> EnvironmentData: touch_tip=trial.cfg.touch_tip, ) _record_measurement_and_store(MeasurementType.DISPENSE) - input("请记录排液状态,并尝试拍摄清晰的排液后的针管照片..........") + if not trial.ctx.is_simulating(): + input("请记录排液状态,并尝试拍摄清晰的排液后的针管照片..........") trial.pipette._retract() # retract to top of gantry if (i + 1) == num_dispenses: if not trial.cfg.same_tip: From c3f119f85daafebcab3e51fc4553f8e99e5be665 Mon Sep 17 00:00:00 2001 From: Ryan howard Date: Fri, 20 Dec 2024 11:18:27 -0500 Subject: [PATCH 09/10] update load calll from edge --- .../protocols/liquid_sense/lld_test_empty_wells.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_empty_wells.py b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_empty_wells.py index 3adfd8e3208..9dafa3a9803 100644 --- a/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_empty_wells.py +++ b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_empty_wells.py @@ -14,6 +14,7 @@ PipetteChannelType, PipetteModelType, PipetteVersionType, + PipetteOEMType, ) ########################################### @@ -113,6 +114,7 @@ def _setup( major=int(pip_model_list[-1][-3]), # type: ignore[arg-type] minor=int(pip_model_list[-1][-1]), # type: ignore[arg-type] ), + oem=PipetteOEMType.EM if "em" in pipette.model else PipetteOEMType.OT, ) # Writes details about test run to google sheet. tipVolume = "t" + str(TIP_SIZE) From 31b942b5664b724a8be222e37a4e7f3f4c91f0ea Mon Sep 17 00:00:00 2001 From: Ryan Howard Date: Wed, 8 Jan 2025 10:20:25 -0500 Subject: [PATCH 10/10] update flowrates from SZ testing branch --- .../gravimetric/liquid_class/defaults.py | 26 +++++++++---------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py index d66092bf3bd..e9fc477446f 100644 --- a/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py +++ b/hardware-testing/hardware_testing/gravimetric/liquid_class/defaults.py @@ -13,8 +13,6 @@ _default_submerge_dispense_mm = 1.5 _p200_default_submerge_aspirate_mm = 2.5 _p200_default_submerge_dispense_mm = 3.0 -_default_t20_submerge_aspirate_mm = 0.5 -_default_t20_submerge_dispense_mm = 1.0 _default_retract_mm = 5.0 _default_retract_discontinuity = 20 @@ -461,29 +459,29 @@ 200: { # P200 20: { # T20 1: DispenseSettings( # 5uL - z_submerge_depth=_default_t20_submerge_dispense_mm, + z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=1.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, - blow_out_submerged=7, - blow_out_flow_rate=5, + blow_out_submerged=3.5, + blow_out_flow_rate=22, ), 5: DispenseSettings( # 10uL z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=2.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, blow_out_submerged=7, blow_out_flow_rate=5, ), - 20: DispenseSettings( # 50uL + 20: DispenseSettings( # 20uL z_submerge_depth=_p200_default_submerge_dispense_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=5.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_dispense_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -994,9 +992,9 @@ 200: { # P200 20: { # T20 1: AspirateSettings( # 5uL - z_submerge_depth=_default_t20_submerge_aspirate_mm, + z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=1.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, @@ -1006,17 +1004,17 @@ 5: AspirateSettings( # 10uL z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=2.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm, leading_air_gap=0, trailing_air_gap=0.1, ), - 20: AspirateSettings( # 50uL + 20: AspirateSettings( # 20uL z_submerge_depth=_p200_default_submerge_aspirate_mm, plunger_acceleration=_default_accel_96ch_ul_sec_sec, - plunger_flow_rate=5.5, # ul/sec + plunger_flow_rate=6.5, # ul/sec delay=_default_aspirate_delay_seconds, z_retract_discontinuity=_default_retract_discontinuity, z_retract_height=_default_retract_mm,