AUTOMATED SCHEDULER FOR LABORATORY EQUIPMENT

Information

  • Patent Application
  • 20180080949
  • Publication Number
    20180080949
  • Date Filed
    September 14, 2017
    7 years ago
  • Date Published
    March 22, 2018
    6 years ago
Abstract
A method is presented. The method includes receiving at least one order, generating one or more optimization problem instances using one or more resource descriptions of automated laboratory equipment, one or more protocol descriptions of the automated laboratory equipment, an objective function and the at least one order. The method further includes providing the one or more optimization problem instances as input to a constraint optimization solver and processing the one or more optimization problem instances by the constraint optimization solver to generate the schedule of operations to carry out the at least one order on the automated laboratory equipment.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims priority to EP 16189852.3, filed Sep. 21, 2016, which is hereby incorporated by reference.


BACKGROUND

The present disclosure relates to methods and systems for providing a schedule of operations for automated laboratory equipment.


In today's laboratory environments, automated laboratory equipment for performing various tasks can be deployed. The automated laboratory equipment can receive samples and orders. The orders can describe which protocol(s) to carry out on each sample. It can happen that multiple samples can be processed in parallel, e.g., to increase throughput or reduce a time-to-result. For carrying out the protocols, numerous resources can be required, such as instrument resources (e.g., transport systems for sample holders and reaction vessels, robotic arms with pipettes to transfer and dose sample and/or reagent liquids, fluid mixers, incubator positions, photodetector positions, and the like) and consumable resources (e.g., reagents, disposable fluid carriers such as tubes, reaction vessels, multi-well plates or other fluid carriers for sample fluids and reagents, disposable pipette tips and many more). The sequence of using the resources to process an order is called a process. Since multiple processes, each addressing a protocol, can run fully or partially in parallel and share some of the resources, a pattern of resource activities of the laboratory equipment can be fairly complex. This complexity can even be increased by demanding timing-windows, for instance for chemical reactions in analyzers, and by rules defined to avoid, e.g., carry over or requested order priorities. As a consequence, the development and operation of a schedule of operations for automated laboratory equipment can be very challenging.


SUMMARY

According to the present disclosure, a method for providing a schedule of operations for automated laboratory equipment is presented. The method can comprise receiving at least one order. Each order can require the execution of one or more protocols on the automated laboratory equipment. The method can also comprise generating one or more optimization problem instances using one or more resource descriptions of the automated laboratory equipment, one or more protocol descriptions of the automated laboratory equipment, an objective function and the at least one order. The one or more resource descriptions can describe the resources present in the automated laboratory equipment and capabilities and constraints of the resources. Each protocol description can describe a protocol the automated laboratory equipment can carry out. Each protocol description can include a definition of one or more protocol steps to be carried out by the automated laboratory equipment. Each protocol description can include one or more constraints to be observed when carrying out the protocol steps on the laboratory equipment. The objective function can define an optimization goal for a schedule of operations for the automated laboratory equipment. The method can also comprise providing the one or more optimization problem instances as input to a constraint optimization solver and processing the one or more optimization problem instances by the constraint optimization solver to generate the schedule of operations to carry out the at least one order on the automated laboratory equipment.


In accordance with one embodiment of the present disclosure, a laboratory network is presented. The laboratory network can comprise automated laboratory equipment and a computer system configured to carry out the above method to generate the schedule of operations for the automated laboratory equipment.


Other features of the embodiments of the present disclosure will be apparent in light of the description of the disclosure embodied herein.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

The following detailed description of specific embodiments of the present disclosure can be best understood when read in conjunction with the following drawings, where like structure is indicated with like reference numerals and in which:



FIG. 1 illustrates a schematic diagram of the structure of a scheduler according to an embodiment of the present disclosure.



FIG. 2 schematically illustrates a schedule of operations of automated laboratory equipment according to an embodiment of the present disclosure.



FIG. 3 schematically illustrates a dynamic adaptation of a schedule of operations of automated laboratory equipment according to an embodiment of the present disclosure.



FIG. 4 illustrates an example modelling of a protocol according to an embodiment of the present disclosure.



FIG. 5 illustrates a part of the generation process of an optimization problem instance according to an embodiment of the present disclosure.



FIGS. 6A-C illustrate example schedules of operations obtained when changing the objective function according to an embodiment of the present disclosure.



FIG. 7 schematically illustrates of an example automated laboratory device according to an embodiment of the present disclosure.





DETAILED DESCRIPTION

In the following detailed description of the embodiments, reference is made to the accompanying drawings that form a part hereof, and in which are shown by way of illustration, and not by way of limitation, specific embodiments in which the disclosure may be practiced. It is to be understood that other embodiments may be utilized and that logical, mechanical and electrical changes may be made without departing from the spirit and scope of the present disclosure.


A method for providing a schedule of operations for automated laboratory equipment includes receiving at least one order is presented. Each order can require the execution of one or more protocols on the automated laboratory equipment. The method can comprise generating one or more optimization problem instances using one or more resource descriptions of the automated laboratory equipment, one or more protocol descriptions of the automated laboratory equipment, an objective function and the at least one order. The one or more resource descriptions can describe the resources present in the automated laboratory equipment and capabilities and constraints of the resources. Each protocol description can describe a protocol the automated laboratory equipment can carry out. Each protocol description can include a definition of one or more protocol steps to be carried out by the automated laboratory equipment and each protocol description can include one or more constraints to be observed when carrying out the protocol steps on the laboratory equipment. The objective function can define an optimization goal for a schedule of operations for the automated laboratory equipment. The method can further comprise providing the one or more optimization problem instances as input to a constraint optimization solver and processing the one or more optimization problem instances by the constraint optimization solver to generate the schedule of operations to carry out the at least one order on the automated laboratory equipment.


A laboratory network includes automated laboratory equipment and a computer system configured to carry out above method is also presented. Particular embodiments of the subject-matter can be implemented so as to realize one or more of the following advantages.


Firstly, the techniques of the present disclosure can allow for a fast and flexible generation of a schedule of operations for automated laboratory equipment in some examples. For example, by using an optimization problem instance which can model the automated laboratory equipment and a (potentially generic) constraint optimization solver, the schedule can be generated without or with little prior knowledge regarding a structure of the schedule to be generated (i.e., the solution of the scheduling problem).


In some prior art schedulers, pre-defined templates of operations are used (e.g., templates which define at which times a particular operation can be carried out). The protocols are defined such that they can be fitted into the pre-defined templates. During run-time (e.g., upon arrival of one or more orders), the scheduler fits the respective protocol required for the orders into the pre-defined templates. The quality of the schedules of these schedulers can depend strongly on the pre-defined templates. Moreover, it might not be straightforward to modify the scheduler, e.g., to include new protocols, to operate on a different automated laboratory equipment, or to change parameters of the automated laboratory equipment (e.g., a pipetting time or an incubation duration). This process might require involvement of an experienced user who has deep knowledge about the respective automated laboratory equipment or substantial trial-and-error work to prepare new templates.


The technique of the present disclosure can ameliorate or even overcome these problems in some examples. The resource and protocol descriptions can be amended and adapted to different laboratory equipment, a changed design of the automated laboratory equipment or changed protocols in a relatively straightforward manner. It may not be required to provide information regarding potential solutions in the scheduling process. In addition, the constraint optimization solver can be re-run after one of the above described changes have occurred without requiring (substantial) modifications to the solver.


For instance, a first run (or plurality of runs) of the solver may generate a schedule which can be optimized to yield a high throughput. At a later point in time, a high priority order may arrive in the laboratory. In this situation, a re-run of the constraint optimization solver can be triggered to adapt the schedule to the new situation. An updated schedule can process the high priority sample as quickly as possible.


As in this example, the technique of the present disclosure can allow for adaptation to a multitude of other situations in some examples. The underlying structure of the optimization problem instance generation process may remain (substantially) unchanged. Furthermore, a designer can change or complement the resource descriptions, the protocol descriptions and the objective function without considering a structure of the solutions of the optimization process.


In the same manner, a plurality of devices or a laboratory environment containing multiple automated devices can be considered. This may not be the case when using pre-defined templates for the scheduling process as in some prior art schedulers. Further examples of how the flexibility of the techniques of the present disclosure can allow for an improved operation of laboratory equipment will be discussed below.


Secondly, the techniques of the present disclosure can be used to generate schedules which can make automated laboratory equipment run faster, achieve a higher throughput, or run more resource efficiently (or a combination of two or more of these) in some examples.


Thirdly, the techniques of the present disclosure can be employed to simulate scheduling operations of automated laboratory equipment. In this manner, the technique of the present disclosure can be helpful in the development automated laboratory equipment. For example, a placement and layout of components of an automated device can be selected or changed based on the findings of a simulation with the techniques of the present disclosure. In the same manner, protocols, workflows or templates of operations of automated laboratory equipment can be developed by using the techniques of the present disclosure. Moreover, the design of automated laboratory equipment and protocols and workflows can be tested by using the simulations according to the present disclosure.


The term ‘automated laboratory equipment’ as used herein can refer to any kind of automated or semi-automated technical device for use in laboratory work, e.g., in the clinical, chemical, biological, immunology or pharmaceutical area or the like. Such a laboratory device may comprise components to perform fluid transfer and dosing, fluid homogenization (mixing), temperature control, and measurements of chemical or physical parameters. For example, the devices can include fluid dispensing components (e.g., a pipettor or a valve), a stirrer, a tempering device, a shaker, or an agitator.


In other examples, automated laboratory equipment can include an analysis system or a work-cell of an analysis system or analyzer. For example, automated laboratory equipment can be an analyzer for analyzing a mechanical, optical, chemical or biological property of a sample. ‘Automated laboratory equipment’ not necessarily is located in a dedicated laboratory. Rather, the term also includes stand-alone laboratory equipment for carrying out analytic procedures, e.g., in the clinical, chemical, biological, immunology or pharmaceutical area. For example, a benchtop device in point-of-care settings such as physician clinics or pharmacies or a device for home-use can also be automated laboratory equipment according to the present disclosure.


‘Automated laboratory equipment’ as used herein can comprise a control unit or controller operatively which can be coupled to one or more analytical, pre- and post-analytical work cells. The control unit can be operable to control the work cells. In addition, the control unit may be operable to evaluate and/or process gathered analysis data, to control the loading, storing and/or unloading of samples to and/or from any one of the analyzers, to initialize an analysis or hardware or software operations of the analysis system used for preparing the samples, sample tubes or reagents for said analysis and the like. In one example, automated laboratory equipment can be a transportation system configured to transport sample in a laboratory environment.


The term ‘analyzer’/‘analytical work cell’ as used herein can encompass any apparatus or apparatus component that can measure physical or chemical characteristics of a sample. In some examples, the device can be configured to induce a reaction of a biological sample with a reagent for obtaining a measurement value.


An analyzer can be operable to determine via various chemical, biological, physical, optical or other technical procedures a parameter value of the sample or a component thereof. An analyzer may be operable to measure the parameter of the sample or of at least one analyte and return the obtained measurement value. The list of possible analysis results returned by the analyzer comprises, without limitation, concentrations of the analyte in the sample, a digital (yes or no) result indicating the existence of the analyte in the sample (corresponding to a concentration above the detection level), optical parameters, images, cell or particle counts, DNA or RNA sequences, data obtained from mass spectroscopy of proteins or metabolites and physical, mechanical, optical, electrical or chemical parameters of various types. An analytical work cell may comprise units assisting with the pipetting, dosing, and mixing of samples and/or reagents. The analyzer may comprise a reagent holding unit for holding reagents to perform the assays. Reagents may be arranged for example in the form of containers or cassettes containing individual reagents or group of reagents, placed in appropriate receptacles or positions within a storage compartment or conveyor. It may comprise a consumable feeding unit. The analyzer may comprise a process and detection system whose workflow is optimized for certain types of analysis. Examples of such analyzer can be clinical chemistry analyzers, coagulation chemistry analyzers, immunochemistry analyzers, urine analyzers, nucleic acid analyzers, used to detect the result of chemical or biological reactions or to monitor the progress of chemical or biological reactions.


The term ‘workflow’ as used herein can encompass any task that can comprise a number of steps, such as for maintenance or operation of the system or one of its system components.


The term ‘step of a workflow’ or ‘task of a workflow’ as used herein can encompass any activity belonging to a workflow. The activity can be of an elementary or complex nature and is typically performed at or by a single automated laboratory equipment. A ‘workflow’ may include all processing steps taking place in the automated laboratory equipment, or only a subset of the tasks (e.g., those that are relevant for scheduling in some situations).


The term ‘communication network’ as used herein can encompass any type of wireless network, such as a WIFI, GSM, UMTS or other wireless digital network or a cable based network, such as Ethernet or the like. In particular, the communication network can implement the Internet protocol (IP). For example, the communication network can comprise a combination of cable-based and wireless networks.


A ‘control unit’ or ‘controller’ can control the automated or semi-automated system in a way that the necessary steps for the processing protocols can be conducted by the automated system. That can mean the control unit may, for example, instruct the automated system to conduct certain pipetting steps to mix the liquid biological sample with reagents, or the control unit can control the automated system to incubate the sample mixtures for a certain time or the like. The control unit may receive information from a data management unit regarding which steps need to be performed with a certain sample. In some embodiments, the control unit may be integral with the data management unit or may be embodied by a common hardware. The control unit may, for instance, be embodied as a programmable logic controller running a computer-readable program provided with instructions to perform operations in accordance with a process operation plan. The control unit may be set up to control, for example, any one or more of the following operations: loading and/or wasting and/or washing of cuvettes and/or pipette tips, moving and/or opening of sample tubes and reagent cassettes, pipetting of samples and/or reagents, mixing of samples and/or reagents, washing pipetting needles or tips, washing mixing paddles, controlling of a light source, e.g. selection of the wavelength, or the like. In particular, the control unit may include a scheduler, for executing a sequence of steps within a predefined cycle time. The control unit may further determine the order of samples to be processed according to the assay type, urgency, and the like.


The term ‘sample’ can refer to material(s) that may potentially contain an analyte of interest. The sample can be derived from a biological source, such as a physiological fluid, including blood, saliva, ocular lens fluid, cerebrospinal fluid, sweat, urine, stool, semen, milk, ascites fluid, mucous, synovial fluid, peritoneal fluid, amniotic fluid, tissue, cells, or the like. The biological sample can be pretreated prior to use, such as preparing plasma or serum from blood. Methods of treatment can involve centrifugation, filtration, distillation, dilution, concentration and/or separation of sample components including analytes of interest, inactivation of interfering components, and the addition of reagents. A sample may be used directly as obtained from the source or used following a pretreatment to modify the character of the sample. In some embodiments, an initially solid or semi-solid biological material can be rendered liquid by dissolving or suspending it with a suitable liquid medium. In some examples, the sample can be suspected to contain a certain antigen or nucleic acid.


The term ‘order’ can include any request for automated laboratory equipment to automatically or semi-automatically carry out a particular task. For example, an order can be a request that one or more assays are to be performed on one or more biological samples.


First, an overview over the structure of the scheduler will be given in connection with FIG. 1. Subsequently, different aspects of the use of the techniques of the present disclosure will be discussed in connection with FIG. 2 and FIG. 3. Next, in connection with FIG. 4 to FIG. 6, additional details of the structure of the scheduler of the present disclosure will be presented. Last, an example automated laboratory device and its modelling will be discussed in more detail in connection with FIG. 7.



FIG. 1 illustrates a schematic diagram of the structure of a scheduler according to the present disclosure including a model of automated laboratory equipment 1. The model can include one or more resource descriptions 4 and one or more protocol descriptions 3. The scheduler can further include an objective function 6 and a constraint optimization solver 2 (also referred to as constraint optimization solver module herein). The constraint optimization solver 2 or constraint optimization solver module can be part of an optimization module, as shown in FIG. 1. Moreover, the scheduler can further receive an order list 7 including at least one order as part of the schedule generation process.


The mathematical model 1 including the resource descriptions 4 and the protocol descriptions 3, as well as the order list 7 and the objective function 6 can be used to generate one or more optimization problem instances. The one or more optimization problem instances can be provided to the constraint optimization solver 2 which can generate a schedule of operations 8 for the one or more optimization problem instances.


The different components of the scheduler can have the following functions: The order list 7 can include at least one order (e.g., a plurality of orders) to be carried out by the automated laboratory equipment. Each order can involve the execution of one or more protocols. For example, an order list can define a plurality of assays to be carried out by an automated analyzer on a sample or a batch of samples.


Each protocol description 3 can describe a protocol the automated laboratory equipment can carry out. The protocol description 3 can include a definition of one or more protocol steps to be carried out by the automated laboratory equipment and one or more constraints to be observed when carrying out the protocol steps on the automated laboratory equipment.


For example, a protocol may be a particular assay involving multiple steps of adding reagents to a sample, homogenizing the mixture, transporting the mixture, incubating the mixture and performing optical measurements on the mixture.


The constraints can, e.g., define orders of the steps and minimum and maximum durations of the steps and of the times between two steps. The protocol descriptions 3 can describe the protocol the automated laboratory equipment can carry out independently of how the orders are scheduled in the schedule. In other words, the definition of the protocol descriptions 3 may not require information regarding the (potential) solution of a schedule generated by the solver.


Each resource description 4 can describe one or more resources present in the automated laboratory equipment and capabilities and constraints of the one or more resources. For instance, a resource description 4 can describe a dispensing device (e.g., a pipettor). A constraint of this dispensing device may be that it is only capable of addressing a certain subset of fluids, e.g., only sample (certain) reagents, and/or a subset of volume ranges (e.g., only 50 to 100 μl or only 110 to 200 μl).


In some examples, the resource descriptions 4 can be specific to a particular automated laboratory equipment. The resource descriptions 4 can be independent of how the orders can be scheduled in the schedule. In other words, the definition of the resource descriptions 4 may not require information regarding the (potential) solution of a schedule generated by the solver.


The objective function 6 can define an optimization goal to be fulfilled by a schedule of operations for automated laboratory equipment.


In some examples, the techniques of the present disclosure can also include obtaining one or more special rules and exceptions 5 (also short-handed as ‘exceptions’ herein) which can define how the automated laboratory equipment can handle one or more particular situations. The special rules and exceptions 5 can also be defined as part of the resource descriptions 4 in some examples. For instance, the one or more particular situations can include a situation in which a substance associated (e.g., the sample or a reagent) with a first order can be carried over to a process of another order. In one example, a particular process may be extremely sensitive to contamination with a particular reagent.


In other examples, the one or more particular situations can include a situation in which a resource can be in a certain state after having carried out a particular task that can affect the processing of other subsequent tasks. For example, a particular sensor may not be in a state to carry out a second type of measurements directly after having carried out a first type of measurement.


Further details regarding the components shown in FIG. 1 and their implementation will be discussed below.


After having received the one or more optimization problem instances generated using the elements discussed above, the constraint optimization solver 2 can process the one or more optimization problem instances to generate the schedule of operations 8 to carry out the plurality of orders on the automated laboratory equipment. As depicted in FIG. 1, the constraint optimization solver 2 can be a generic constraint optimization solver module.


For example, the constraint optimization solver module can use one or a combination of packages, containing optimization algorithms and heuristic methods. Examples of solver packages are the Cplex CP Optimizer (by IBM), the Cplex Optimizer (by IBM), the Gurobi Optimizer (by Gurobi), ECLiPSe and CBC. Examples of optimization algorithms and heuristic methods can be branch and bound, branch and price and exhaustive search algorithms, local search, constructive algorithms, evolutionary algorithms, ant colony optimization and machine learning-based algorithms.


In other words, the constraint optimization solver module 2 can include no information regarding the particular automated laboratory equipment modeled. In addition, the constraint optimization solver module 2 may not receive any templates relating to solutions or part of solutions for the schedule of operations.


In other examples, the model 1 can include one or more constraints to force the constraint optimization solver to search for solutions with repetitive patterns. In this case, the exact times at which resource activities take place may not be prescribed, this can be optimized by the solver, but what can be defined is that the schedules can fit a repetitive pattern. As a result, a pattern can be computed during design-time. This pattern can be fix uploaded without the need for run-time resource constraint solving. At run-time, the ordered protocols can be fit on the repetitive pattern (e.g., by the automated analyzer). Fitting the ordered protocols on the repetitive pattern can be a (simplified) optimization problem. In some examples, a generic optimizer module can be used. In other examples, dedicated software routines can be written that fit the orders onto the repetitive pattern.


The schedule of operations 8 can be further processed in multiple ways. In one example, the automated laboratory equipment can receive the schedule of operations 8 and carry out the operations according to the schedule. For instance, this can happen automatically after the schedule has been generated, or upon user input (e.g., after an operator has released the schedule). In some examples, the automated laboratory equipment can carry out the operations exactly according to the schedule of operations 8. However, in other situations, the schedule of operations 8 can be further processed by the automated laboratory equipment. For example, the automated laboratory equipment may not necessarily exactly follow the schedule of operations 8 but change the schedule of operations 8 (by purpose or accidentally). For instance, the automated laboratory equipment can be configured to follow the defined schedule only roughly time-wise, leaving some space for deviations.


In addition or alternatively, the schedule of operations 8 can be processed into a diagrammatic representation which can be output on a user interface for inspection by a user. For example, the schedule of operations 8 can be represented as a Gantt chart as shown in FIG. 2 or in FIG. 3.


After having shortly introduced the components of the scheduler of the present disclosure, different techniques of using the techniques of the present disclosure will be discussed in connection with FIG. 2 and FIG. 3.


In general, the techniques of the present disclosure can be used to simulate a behavior of automated laboratory equipment as well as generating a schedule for actual automated laboratory equipment. The latter case can include that the generation of the schedule can be performed during design-time or configuration-time of the automated laboratory equipment (e.g., before a processing of samples has started) or during run-time of the automated laboratory equipment.


In one example, the schedule of operations can be generated during development- or design-time of instrument software of the automated laboratory equipment. In other examples, the schedule of operations can be generated during development- or design-time of schedules of operations of the automated laboratory equipment. For example, a schedule generated during development- or design-time can be applied on automated laboratory equipment as a pre-defined schedule to be used during run-time of the automated laboratory equipment.


As can be seen in FIG. 2, the schedule 8 determined by the constraint optimization solver can allocate the resources 9 of automated laboratory equipment to particular tasks at particular times. In FIG. 2, the example automated laboratory equipment can include eight different resources. The steps belonging to different orders are illustrated by bars with different hatchings. For instance, resource #1 is scheduled to carry out tasks belonging to four different orders. In one example, resource #8 can be an incubator. At a predetermined point in time, the incubator can be scheduled to perform an incubation operation 10 on a sample to be processed as part of a particular order. As can be seen in FIG. 2, the schedule can define and order and timing of the operations of the resources 9 of the automated laboratory equipment.


As discussed above, the methods of the present disclosure can include displaying the schedule 8 to a user (e.g., on a graphical user interface). In order to do so, the techniques of the present disclosure can include transforming the information in the schedule into a graphic representation (e.g., a Gantt chart as shown in FIG. 2 or FIG. 3 or a 3D animation). However, the schedule can be represented in different other forms defining a sequence of the operations.


In some examples the schedule may be only transmitted to a controller of the automated laboratory equipment or a simulated version of it to allow for controlling the operation according to the schedule. In these examples, no graphic representation of the information of the schedule may be generated. The schedule can merely include the information regarding the sequence of the operations to carry out the plurality of orders on the automated laboratory equipment in a machine-readable format. For example, the schedule can be a table or list defining a series of operations of the resources of automated laboratory equipment.


In some examples, the techniques of the present disclosure can involve leaving gaps in the schedule for particular resources. This can facilitate filling in new order after arrival in an existing schedule.


After having discussed the structure of the schedule, several examples of the application of the techniques of the present disclosure will be presented subsequently.


As can be seen in FIG. 3, the techniques of the present disclosure can include running the constraint optimization solver multiple times to update the schedule. For example, after a plurality of orders have been received (e.g., a predefined number of orders—this technique is also called batch processing herein) or a certain time interval has elasped, the constraint optimization solver can be run a first time and generate a schedule of operations 8A for automated laboratory equipment.


The automated laboratory equipment can start to process the orders according to the schedule. Then, at a later point in time, one or multiple additional orders can be received. In response to receiving the additional orders, the constraint optimization solver can be run a second time and generate an updated schedule of operations 8B for the automated laboratory equipment. As can be seen in FIG. 3, in some examples, the updated schedule can not only add the operations of the newly received orders but can also re-schedule operations of some of the orders that have been scheduled earlier but whose process has not been started yet. In this manner, the techniques of the present disclosure can allow for scheduling both batch-wise order reception and continuously received orders.


During subsequent operation of the automated laboratory equipment, further orders may arrive. The schedule can be updated by re-running of the constraint optimization solver in response to one or more of these further orders. In one example, the schedule can be continuously updated by re-running the constraint optimization solver in response to the receipt of each order. In other examples, the constraint optimization solver can only be re-run after a predetermined number of orders (e.g., between 1 and 5000 or between 6 and 2000 orders) have been received.


In one example of batch processing, the constraint optimization solver can run a first optimization run after which a subset or none of the computed schedule or the complete schedule can be fixed. The remaining subset of the schedule can be released. Then all, a part of, or none of the corresponding orders of the released part of the schedule can be included in a next optimization run, whereby the fixed subset resulting from the first optimization run can be taken into the next optimization run as resource non-availability.


A number of orders that are fixed or released again for the next batch as well as the batch-size can be constant or variable for each batch run. In some situations, e.g., due to a very early trigger, all of the orders can be newly scheduled (for instance in case of an error or when an extremely urgent order arrives before the scheduled processes have started).


Not all of the orders from the portion of the schedule that is not fixed need to be taken in for a new schedule. For instance, when a new set of high-priority orders may arrive and the solver may be re-run with a limited number of orders (e.g., ten orders) only. In this case, the new high-priority orders may be included first, and the set can be filled up with old orders.


In the example of FIG. 3, the second run (or any further run) of the constraint optimization solver can be triggered by a receipt of one or more new orders. In addition or alternatively, other events can trigger the re-running of the constraint optimization solver to generate an updated schedule. In one example, the constraint optimization solver can be re-run after a predetermined time has elapsed.


In other examples, a re-run can be triggered by detection of one or more external or internal conditions of the automated laboratory equipment. For instance, the operator or system may switch resources off or on, or resources can be exchanged during servicing, changing or exchanging the system. In these cases, the constraint optimization solver can be re-run to generate a new schedule with reduced, added or changed resources. In other examples, if an error occurs (e.g., a break-down of a particular resource of the automated laboratory equipment), this may automatically be signaled to the scheduler and a new schedule can be generated in response. In other examples, an internal condition can be that one or more components of the automated laboratory equipment do not work properly.


An external condition can include a workload or status of other automated laboratory equipment or the laboratory environment the automated laboratory equipment is located in (e.g., a number of lab personnel present at a predetermined time).


In response to these trigger conditions, the resource descriptions (or other parts of the model) and/or the objective functions can be changed. For instance, a resource description of automated laboratory equipment can be changed to account for a resource (e.g., a pipette head) which has broken down. Moreover, an objective function can be changed and an initial objective of “maximize” throughput may be changed for “save as many orders as possible”.


In some cases, e.g., if an error has occurred, not all orders may be successfully processed. In this case, some orders may be sacrificed (terminated) to free resources to process other, possibly more important orders.


In still other examples, the constraint optimization solver can be re-run after the objective function has been changed. This may happen upon user input or in response to a detection of a particular state of the automated laboratory equipment or the laboratory environment.


This list of examples shows that the techniques of the present disclosure can allow for a flexible adaptation of automated laboratory equipment to different situations. This may improve different aspects of the operation of the automated laboratory equipment (e.g., throughput, time to result, walk away time and resource consumption). In general, the triggering of re-runs can happen automatically (i.e., without involvement of an operator of the automated laboratory equipment).


In the previous sections, examples of a run-time execution of the techniques of the present disclosure have been discussed. In other examples, the generation of the schedule can take place during design- or configuration-time of the automated laboratory equipment. In still other examples, the generation of the schedule of operations can take place in a simulation of the automated laboratory equipment. This case will be discussed subsequently.


As already explained above, the techniques of the present disclosure can include using models including resource descriptions of the automated laboratory equipment and protocols which can be independent of the (expected or desired) schedule of operations. In this manner, a user can modify the characteristics of the model (e.g., the resource descriptions and the protocol descriptions) and run the constraint optimization solver to simulate the behavior of automated laboratory equipment. Thus, new protocols for the automated equipment or laboratory workflows can be developed and tested for newly designed instruments as well as for existing instruments (e.g., after an instrument update with additional or changed protocols).


In addition or alternatively, new and/or modified automated laboratory equipment can be simulated. For instance, a user may add a component (e.g., an additional pipettor) to a model of existing automated laboratory equipment. Using the modified model as input for the constraint optimization solver, the behavior of the laboratory equipment can be studied.


In still other examples, characteristics of existing laboratory equipment can be studied by simulation. For instance, performance bottle-necks of existing laboratory equipment can be identified in schedules generated by the techniques of the present disclosure. In addition or alternatively, resource consumption (e.g., reagents or other consumable items) of an existing laboratory equipment can be estimated based on the schedules generated by the techniques of the present disclosure.


In the previous sections, a number of use cases according to the present disclosure have been presented. Subsequently, aspects of the model will be discussed in connection with FIG. 4 to FIG. 7.


These sections also include code examples for the sake of illustration. The code is written in a form to be processed by the IBM ILOG CPLEX Optimizer. The IBM ILOG CPLEX Optimizer can solve integer programming problems, large linear programming problems using either primal or dual variants of the simplex method or the barrier interior point method, convex and non-convex quadratic programming problems, and convex quadratically constrained problems (solved via second-order cone programming, or SOCP). However, the techniques of the present disclosure are not limited to this particular (generic) constraint optimization solver. Rather, the model and the objective function can also be implemented to be processed by other (generic) constraint optimization solvers (as listed above).


The protocol descriptions will be discussed first. FIG. 4 depicts an example protocol description according to the present disclosure. The protocol described by the protocol description can relate to any assay or other test on a sample the automated laboratory equipment can carry out. In other examples, the protocol can relate to a preparation or manipulation of a sample. In still other examples, a protocol can relate to a cleaning, testing or maintenance operation of the automated laboratory equipment.


As can be seen in FIG. 4, the protocol description can include a description of a plurality of protocol steps 31A-31D included in the protocol and one or more constraints 32A-32G to be observed when carrying out the protocol steps on the automated laboratory equipment.


The protocol steps 31A-31D can include any operation the automated laboratory equipment can perform. These operations can include transport of samples, reagents or consumable items (e.g., reaction vessels or instrument tips), manipulation of samples or reagents (e.g., sampling of a predetermined quantity of a reagent or sample), homogenization of fluid mixtures, incubating of fluids, measurement of a parameter of the sample, cleaning operations of reaction vessels or instrument components and disposal operations of non-renewable resources (e.g., fluids and consumables).


One example of a protocol step is given in FIG. 5. Step #231E involves pipetting 10 μl of reagent A into a reaction vessel. In other examples, the description of the protocol steps can include other and/or further information (e.g., the duration of one or more protocol steps or an optionality flag indicating that a particular protocol step can be skipped).


A protocol step 31A-31D can combine multiple operations of the automated laboratory equipment. For example, step #1 may include adding a predetermined quantity of a sample and a reagent in a reaction vessel.


The constraints 32A-32G included in the protocol descriptions can include one or more of a definition of the sequence of protocol steps 32E-32G, a definition of the minimum and/or maximum duration of a protocol step 32C, 32D or a definition of the minimum and/or maximum time between two subsequent protocol steps 31A-31D. These subsequent protocol steps can be but not necessarily have to place directly after each other. For instance, in the example of FIG. 5 step #2 must start at most one minute after step #1 has been completed.


A code example of a protocol description for a prothrombin time assay is given in the left hand column of Table 1 below. The right hand column includes an explanation of various features of the protocol description. As can be seen, the protocol description can include a protocol identifier (i.e., “PT” in the example). Moreover, the protocol description can define a sequence of the steps and various constraints to be observed.










TABLE 1







<<“PT”, “AspireS”>, 18, 0>,
Protocol “PT” requires a step named “AspireS”


<<“PT”, “DummyDispS”>, 9, 0>,
with execution time 1.8 s (all times are expressed as


<<“PT”, “WashNeedle”>, 40, 0>
multiples of 100 ms). This step is obligatory


<<“PT”, “SpecialWash”>, 100, 1>,
(optionality flag set to zero). The “SpecialWash”



step is optional, marked by an optionality flag



which is set to “1”.


<“PT”, “AspireS”,
Protocol “PT” does not require a minimum delay


“DummyDispS”, −1, 1200>,
between the end of step “AspireS” and before


<“PT”, “DispenseS”,
starting the step “DummyDispS” (value “−1”). The


“CuvPrepDispSR”, 2562, 2582>,
maximum allowed waiting time between the steps


<“PT”, “CuvLoad”,
is 120 s.


“CuvToIncubator”, −1, −1>
The allowed time delay between the steps



“DispenseS” and “CuvPrepDispSR” is at least



256.2 s and at most 258.2 s.



Step “CuvLoad” has to be scheduled before



“CuvToIncubator” but there are no required times



for the minimal nor maximum delay the two steps



(indicated by “−1”).









The resource descriptions will be discussed next. In general, the resource descriptions describe the resources present in the automated laboratory equipment and capabilities and constraints of these resources.


Resources of laboratory equipment can include, e.g., one or more of samplers and dispensers of samples and reagents (e.g., pipettors), grippers or other movers for manipulation of vessels, incubators, measurement units, cleaning stations and feeding devices for consumable items (e.g., reaction vessels, sample vessels or parts of the instrument).


An example for resource descriptions is shown in FIG. 5. For the sake of illustration, four resource descriptions 41-44 are shown. On the one hand, the example laboratory equipment can include three pipettes. For each of these pipettes, the resource description 41-43 can define a range of volumes the respective pipettes can handle, an accuracy of the pipette, and a set of reagents the pipettes can address. In the same manner, a resource description of reagent A defines a constraint: A special wash step is required in case if another predefined reagent has been used a predetermined number of runs prior to the reagent A.


In addition, in some examples, the resource descriptions can define one or more of states in which the resource can be, processes that cause a transition from one state (level) to the next, eventually a transition time required to transition between states of the resource, requirements of states of the resource to carry out a predetermined protocol step, and incompatibilities between different states of the resource.


In one example, the resource description can include different components. For instance, the resource description can include a resource definition component which can define the capacity of the respective resource, a component describing how the resource can be occupied and released by predetermined protocol steps, a resource state component which can define a dynamic behavior of the respective resource and a component defining rules to be obeyed in certain situations.


In one example, the resource definition component can define a resource identifier and a capacity of the resource. For instance, the number of resources of a certain type available in the instrument can be defined. Resources may be separately defined (e.g., the pipettes in FIG. 5) as having a capacity of one, or as a joint set of resources in one unit (e.g., an incubator with a capacity of multiple cuvette positions). As shown in FIG. 5, the resource definition component can specify additional characteristics of the respective resource. A code example for a resource definition component is shown in Table 2 below:










TABLE 2







<″NeedleSample″, 1>,
The automated laboratory equipment


<″NeedleReagent″, 1>,
includes one needle unit for the samples


<″PhotometerPos″, 12>,
(“NeedleSample”) and a second needle unit


<″IncubatorPos″, 20>,
for reagents (“NeedleReagent”).



Furthermore, there are twelve positions for



cuvettes in a photometer unit and twenty



positions in an incubator.









The component describing how the resource can be occupied and released by predetermined protocol steps can define one or more of respective resources required for a particular protocol step, actions necessary to release a resource after it has been used in a particular protocol step and a constraint regarding a maximum number of resources that can be used. A code example for this component is shown in Table 3 below:










TABLE 3







<″NeedleSample″,
Protocol step “AspireS” occupies


″AspireS″, >1,
one sample needle. There might be



multiple needles of the type



“Sample”.


<″PhotometerPos″,
One photometer position is used to


″CuvMoveIncub″, 1>,
place a cuvette in the photometer.


<″NeedleSample″,
Protocol step “WashNeedle”


″WashNeedle″, 1>,
releases one sample needle. Until a



wash has been carried out the



needle cannot be used because it is



contaminated.


<″PhotometerPos″,
Protocol step “CuvMoveTrash”


″CuvMoveTrash″, 1>,
releases one photometer position as



the cuvette is taken out of the



photometer and disposed.


photometerResourceUse[resCurr]
Definition of the maximum allowed


<= resCurr.nCapacity;
resource use: the current resource



use shall be less or equal to the



capacity.









The resource state component can define one or more of states the respective resource can be in, a required transition time between different states, a required state for a particular protocol step and information regarding incompatibility between different states. A code example for this component is shown in Table 4 below:










TABLE 4







<″TransferArm″,
The resource “TransferArm” has two possible


″ReagentCassette″>,
spatial positions: the first position being


<″TransferArm″,
above reagent cassettes, the second position


″Incubator″>,
being above the incubators.


<″TransferArm″,
The resource “TransferArm” needs 1.1 s for


″ReagentCassette″,
moving from the position “ReagentCassette”


″Incubator″, 11>,
to the position “Incubator”.


<″AspireReagent″,
In order to carry out the protocol step


″TransferArm″,
“AspireReagent”, the resource “TransferArm”


″ReagentCassette″>'
needs to be in the position “ReagentCassette”.


<<″TransferArm_1″,
The resource “TransferArm_1” and cannot


″ReagentCassette_a1″>,
be in state “ReagentCassette a1” if, at the


<″TransferArm_2″,
same time, resource “TransferArm_2” is in


″ReagentCassette_a2″>>
state “ReagentCassette_a2”. The reverse



direction is also considered.









Last, the component defining rules to be obeyed in certain situations can define different exceptions to be applied in particular situations. For instance, this component can define rules to avoid carry over (e.g., contamination of a sample or a reagent with another sample, reagent or assay) during the operation of the automated laboratory equipment.


In one example, carry-over can be avoided by implementing one or more of: Adding one or more special cleaning steps to the schedule (e.g. with special cleaning agents) between two steps between which carry-over might occur, changing a processing order of two or more tasks between which carry-over might occur (sensitive task before contaminating task) and carrying out a predetermined number of steps (e.g. normal rinsing rather than special cleaning steps) between two tasks that cause carry-over. A code example for this component is shown in Table 5 below:










TABLE 5







<″CarryOver_R1″, 100>,
There is a carry-over type called



“CarryOver_R1”. Its maximum (ceiling)



level is 100 units (the contamination of



the resource is measured in these units).


<<″CAUSE″,
Protocol step “AspireR1_CarryOver”


″AspireR1_CarryOver″>,
from protocol “CAUSE” increases the


<″CarryOver_R1″, 10>>,
level of “CarryOver_R1” by ten units



(until ceiling value of 100 is reached).


<<″Sensitive″,
Protocol step “SpecialWash_R1” from


″SpecialWash_R1″>,
protocol “Sensitive” resets the level of


<″CarryOver_R1″, 0>>,
“CarryOver_R1” to zero.


<<″PT″, ″WashNeedle″>,
Protocol step “WashNeedle” from


<″CarryOver_R1″, −1>>,
protocol “PT” reduces the level of



“CarryOver_R1” by at most one unit.


<<″Sensitive″, ″AspireR1″>,
Protocol step “AspireR1” from protocol


<″CarryOver_R1″, 0>>,
“Sensitive” requires the level of



“CarryOver_R1” to be at most zero in



order to be executed.









After having discussed different aspects of the resource descriptions of the model, the following sections will treat the order list and the objective function in more detail. The order list can include information regarding at least one order (e.g., a plurality of orders) to be carried out by the automated laboratory equipment, each order involving the execution of one or more protocols. For instance, each order can specify an assay to be performed on one sample or a batch of samples. In other examples, each order can specify a plurality of assays to be performed on one sample or a batch of samples.


In one example, the order list can include for each order one or more of a sample identifier to identify a sample or a batch of samples (e.g., a barcode attached to a sample container), a protocol identifier identifying one or more protocols to be applied to the sample or batch of samples and an entry time indicating a time at which the order entered the system.


In addition or alternatively, the order list can include for each order an expiration time indicating a time or duration until which the sample or batch of samples must be processed. Alternatively or in addition, the order list can include for each order a priority indicator indicating a priority value of a sample or batch of samples. The latter two pieces of information can form constraints for the solver and can be used to prioritize certain samples or batches of samples. A code example for an order list including three orders is shown in Table 6 below:










TABLE 6







<<1, ″PT″ >, 0, 72000>,
First, at time = 0 s two orders for sample


<<1, ″APTT″ >, 0, 7200>,
with ID = 1 entered on which a PT


<<2, ″PT″ >, 350, 18000>
(prothrombin time) and APTT (activated



partial thromboplastin time) test shall be



carried out. Both tests shall be finished



latest 72000 * 100 ms = 2 hours after



entry time of the sample. Next a sample



arrived at time = 35 s with ID = 2, for



which a PT test needs to be carried out



finishing not earlier than 30 minutes after



the entry time.









In the subsequent sections, the objective function will be discussed in more detail. In general, the objective function can define an optimization goal for a schedule of operations for the automated laboratory equipment.


An objective function can define an objective and the quality of a generated schedule can be judged according to the degree it reaches the objective. The objective function can quantify the objective so that in some cases minima or maxima of the objective function can be found by the constraint optimization solver. A certain schedule may not be an absolute maximum or minimum of the objective function but nevertheless be a useful result. In addition, the constraint optimization solver can perform multiple runs to improve the found solution.


The objective function can be adjusted to fulfill different optimization goals. The optimization goals can include minimizing one or more of a total time or duration to process one or a plurality of orders (e.g., of a batch of orders or multiple batches of orders), maximizing a throughput of automated laboratory equipment, minimizing a resource consumption (e.g., reagents, cleaning agents, or other consumable items, energy or renewable resources (instrument resources)) of the automated laboratory equipment, distributing the workload evenly over different components of the automated laboratory equipment or different automated laboratory equipment and minimizing a number of (high-priority) orders lost in case of an error occurring in the automated laboratory equipment.


In this manner, the schedule can be flexibly adapted to different optimization goals (as also discussed above). Examples of schedules generated by using different objective functions are shown in FIG. 6A to FIG. 6C. In all examples, a batch of three or for orders 71-74 can be scheduled. The total durations of the processes per order are shown. In the first example of FIG. 6A may provide the best long term throughput even though the throughput of the schedule of FIG. 6B is higher in the short run. The schedule of FIG. 6C may yield to lowest processing time for each order, even though the short term throughput is lower.


In one example, the objective function can include a weighted sum of two or more factors, wherein each factor can quantify an optimization goal. For instance, a weighted function can include a first term quantifying a total throughput of the automated laboratory equipment and a second term quantifying resource consumption. In this example, the first term can be weighted with a larger weight factor to ensure that throughput is optimized in the first place. The second term can be weighted with a lower, negative weight factor to ensure that very high resource consumption is avoided. The overall objective function can be maximized by the constraint optimization solver to generate the schedule. A code example for an objective function is shown in Table 7 below:










TABLE 7







minimize
One part of the objective function contain a


weightedMakeSpan +
term expressing the weighted penalty for


weightedFairnessPenalty
the total execution time (called make span),



as well as a fairness penalty term



considering the total execution time of the



single orders. The direction of optimization



is a minimization.









As part of the process of generating the schedule, the resource descriptions and protocols descriptions of the model can be linked. This may happen automatically or by user intervention. As described in the preceding sections, different parts of the model and the order list can include identifiers of different steps the automated laboratory equipment can perform (e.g., a “WashNeedle” step occurring above). In some examples, these identifiers can be used to link the respective parts of the model as part of the schedule generation process.



FIG. 5 exemplifies such linking process. A protocol description 3A can define three steps. One of these steps (step #2) 31E involves pipetting a quantity of a reagent with a predefined accuracy. Now, it can be found in the resource description of the model that only one of the three pipettes 41 is capable of performing the required pipetting step and there is only one instance of the necessary reagent. Therefore, the step of the protocol can be linked to the resources automatically in the course of the schedule generation or by a user. In other examples, more than one resource may be applicable to carry out the protocol step. In this case, the solver can find which of the group of applicable resources is most suitable to maximize or minimize the objective function.


In the preceding sections, the elements which are used in the schedule generation process according to the present disclosure have been discussed. In the following sections, in connection with FIG. 7, an example automated laboratory device for which a schedule can be generated will be discussed.


As can be seen in FIG. 7, the example automated laboratory equipment can be an automated analyzer 101. The automated analyzer can include a reagent repository 102 including a plurality of reagents 104 (e.g., packed in standard test-specific cassettes with a plurality of reservoirs) and a sample repository 103 including a plurality of samples 105 (in, e.g., sample collection tubes). The automated analyzer 101 can further include a set of multiple pipettes 106 (e.g., three pipettes) which can be moved in all three spatial directions. Moreover, the automated analyzer 101 can include multiple incubator positions 109 and multiple measurement channels 110. The incubation and measurement operations can take place in disposable reaction vessels (called “cuvettes”) which can be supplied through a cuvette supply 111 and disposed in a cuvette waste 113. The manipulation of the cuvettes can be effected by two grippers 112, 114, one of the grippers 112 having also a mixer function via shaking the cuvette. Last, the automated analyzer 101 can include one or two wash stations 107, 108 configured to wash the pipettes 106.


A batch of sample tubes with related orders arriving at the automated analyzer can each include providing a cuvette at an measurement position 110 for measuring the cuvette quality and/or blank-measurement (a first step of the protocols), pipetting a quantity of a sample 105 into the cuvette (a second step of the protocols) and adding a predetermined reagent 104 (a third step of the protocols) after which the mixture can be homogenized by the mixer-gripper Then, the cuvette can be placed in the incubator 109 to incubate the sample/reagent mixture for a predetermined period of time (a fourth step of the protocols). Next, the cuvettes can be transferred to pipette start reagent and to place it into a measurement position 110 (a fifth step of the protocols) where a measurement can take place (a sixth and seventh steps of the protocols). Last, the cuvette can be disposed (a final step of the protocols). As can be seen, already the relatively simple protocol described herein can require scheduling the operations of a plurality of resources of the automated analyzer. This can be done by using the techniques according to the present disclosure.


Even though a particular automated analyzer is shown in FIG. 7, the techniques of the present disclosure are not limited in any way to this particular analyzer. Rather, the aspects of the elements discussed above (e.g., the model, the order list and the objective function as well as the application examples) can also be used for other automated laboratory equipment (e.g., the automated laboratory equipment discussed in the summary section).


In addition, the techniques of the present disclosure are not limited to a single automated laboratory device. Rather, a schedule for a plurality automated devices can also be generated in a similar way as described herein for a single automated laboratory device. For example, in this case, the model can include resource descriptions for the resources of each of the plurality of automated laboratory devices.


In still other examples, a schedule for a laboratory environment including automated laboratory equipment can also be generated in a similar way as described herein for a single automated laboratory device. For example, in this case the model can include resource descriptions for the resources of the laboratory environment and protocol descriptions describing workflows in the laboratory environment.


In the following sections, several aspects of the hardware generating the schedules according to the present invention will be discussed. In general, the operations for generating the schedule can be carried out on each suitable computer system (e.g., including a single or multiple computers) or on a plurality of computer systems linked by a communication network.


In one example, the computer system can be integrated in the automated laboratory equipment (e.g., as part of a controller of an automated laboratory device). In this example, the schedule can be generated locally at the automated laboratory equipment.


In other examples, the computer system can be arranged remotely from the automated laboratory equipment for which a schedule is generated. For example, the computer system can be part of a laboratory environment and networked to the automated analyzer through a laboratory network.


In still other examples, the computer system can be remote from the laboratory environment. For instance, the constraint optimization solver can be running on a computer system which can be connected to the automated laboratory equipment or the laboratory environment including the automated laboratory equipment for which a schedule can be generated through the internet.


In addition or alternatively, the constraint optimization solver can be running on a distributed computer system (e.g., a cloud-based computer system).


If the generation of a schedule for automated laboratory equipment is simulated, there can be no need for the automated laboratory equipment to be actually networked with the computer system doing the simulation. In fact, as discussed above, the techniques of the present disclosure can be used in the design phase of automated laboratory equipment so this equipment may not exist.


In the preceding detailed description multiple examples of methods and systems for providing a schedule of operations for automated laboratory equipment of the present disclosure have been discussed. However, the methods and systems for providing a schedule of operations for automated laboratory equipment of the present disclosure can also be configured as set out in the following:


A method for providing a schedule of operations for automated laboratory equipment is presented. The method can comprise receiving at least one order. Each order can require the execution of one or more protocols on the automated laboratory equipment. The method can further comprise generating one or more optimization problem instances using one or more resource descriptions of the automated laboratory equipment, one or more protocol descriptions of the automated laboratory equipment, an objective function and the at least one order. The one or more resource descriptions can describe the resources present in the automated laboratory equipment and capabilities and constraints of the resources. Each protocol description can describe a protocol the automated laboratory equipment can carry out. Each protocol description can include a definition of one or more protocol steps to be carried out by the automated laboratory equipment. Each protocol description can include one or more constraints to be observed when carrying out the protocol steps on the laboratory equipment. The objective function can define an optimization goal for a schedule of operations for the automated laboratory equipment. The method can further comprise providing the one or more optimization problem instances as input to a constraint optimization solver and processing the one or more optimization problem instances by the constraint optimization solver to generate the schedule of operations to carry out the at least one order on the automated laboratory equipment.


The processing of the one or more optimization problem instances by the constraint optimization solver can take place during run-time of the automated laboratory equipment. The processing of the one or more optimization problem instances by the constraint optimization solver can take place during run-time of the at automated laboratory equipment in response to a triggering event.


The triggering event can be one of: an arrival of one or more new orders, a change in the resources of the automated laboratory equipment, a user input, a modification of an order forecast, a lapse of a predetermined period of time, an error, an exceptional situation, or a combination of two or more of these events. The triggering event can be the arrival of an order having a high priority.


The user input can be a user-defined change of operation, e.g., a turning off certain resources, a user-defined prioritization of orders, a user-defined assignment or interdiction of using certain resources for certain protocols or orders, an application for user-defined protocols or protocol or resource parameter changes by a user.


The processing of the one or more optimization problem instances by the constraint optimization solver can be repeated automatically in response to the occurrence of a respective triggering event.


The method can further comprise re-running the constraint optimization solver during run-time of the automated laboratory equipment to generate an updated schedule of operations.


The method can further comprise collecting a batch of multiple orders for the automated laboratory equipment and processing the optimization problem instance by the constraint optimization solver to generate a schedule of operations for the batch of multiple orders at the same time.


A number of orders in the batch can be between about 1 and about 5000. In another embodiment, the number of orders in the batch can be between about 6 and about 2000.


The processing of the one or more optimization problem instances by the constraint optimization solver can take place during development- or design-time of instrument software of the automated laboratory equipment. The processing of the one or more optimization problem instances by the constraint optimization solver can take place during development- or design-time of schedules of operations of the automated laboratory equipment.


The method can further comprise applying the schedule generated during development or design time on the automated laboratory equipment as a pre-defined schedule to be used during run-time of the automated laboratory equipment.


The method can be carried out to simulate a behavior of the automated laboratory equipment. The at least on order can be at least one hypothetical order for the automated laboratory equipment and the schedule of operations can be a schedule for the at least one hypothetical order.


The method can be carried out to predict one or more of a required time for at least one order, an expected time of arrival of results and a lab performance including error situations.


The method can further comprise changing the one or more resource descriptions, the one or more protocol descriptions and/or the objective function automatically by the automated laboratory equipment during operation.


The automatic change can happen in response to detecting that resources are not available, an error modus or state change of the automated laboratory equipment.


Continuously arriving orders can be scheduled by sequential batch-wise optimizations.


The method can comprise running a first optimization run. A subset, or none, of the computed schedule or the complete schedule can be fixed and the remaining subset of the schedule can be released and all, a part of, or none of the corresponding orders of the released part of the schedule can be included in a next optimization run, whereby the fixed subset resulting from the first optimization run can be taken into the next optimization run as resource non-availability. A number of orders that are fixed or released again for the next batch as well as the batch-size may be constant or vary for each batch run.


The method can further comprise providing the schedule of operations to a controller of the automated laboratory equipment and instructing, by the controller, the automated laboratory equipment to carry out the operations according to the schedule. The providing and the instructing steps can take place automatically.


The method can further comprise providing the schedule for display on a graphical user interface.


The optimization goal can be one of the list of optimizing a throughput of the automated laboratory equipment, processing one or more particular order as fast possible, using as little of a predetermined resource as possible, balancing of workload of two or more resources, or a combination of these goals.


The objective function can include a weighted or prioritized combination of different optimization goals.


The automated laboratory equipment can include a plurality of automated laboratory devices. The orders can be orders to be carried out by a plurality of automated laboratory devices. The constraint optimization solver can processes the one or more optimization problem instances to generate schedule operations for the plurality of automated laboratory devices. The plurality of automated laboratory devices can include two or more automated laboratory devices of the same type.


The automated laboratory equipment can be part of a laboratory environment. The orders can be orders to be carried out in the laboratory environment. The generic constraint optimization solver can process the one or more optimization problem instances and generate a schedule of workflows in the laboratory environment.


The automated laboratory equipment can include an automated analyzer for samples. The automated analyzer for samples can be an in-vitro analyzer. The in-vitro analyzer can be one of a clinical chemistry analyzer, an immune-chemistry analyzer, an analyzer for ion selective analysis, a hematology analyzer, a coagulation analyzer, a nucleic acid analyzer, a sequencer, a blood gas analyzer, a mass spectrometer, a cytometer, or a combination of two or more of these analyzers.


The automated laboratory equipment can include one or more of a transportation system configured to transport non-renewable resources such as samples, reagents, reaction vessels, multi-well plates, pipetting tips, slides, consumables, waste or renewable resources such as sensor or analysis modules or modules that can process non-renewable resources in a laboratory environment.


The automated laboratory equipment can include one or more pre-analysis systems, e.g., aliquoting systems, tube capping and de-capping systems, tube or well-plate sealers and de-sealers, sample sorting systems or sample re-formatting systems.


The automated laboratory equipment can include one or more sample post-analysis systems, e.g., sample/specimen archiving systems, systems for preparing samples/specimens for storage, waste handling systems, or cleaning systems.


Generating one or more optimization problem instances can include using a model of automated laboratory equipment which can be specified by the one or more resource descriptions of the automated laboratory equipment and the one or more protocol descriptions of the automated laboratory equipment.


The resource descriptions can define which protocol steps can be carried out by a particular resource or a group of resources of the automated laboratory equipment. The resource descriptions can include descriptions groups of resources with specific characteristics. The protocol descriptions can define one of more characteristics of the resources which can be requested by a protocol step.


The resource descriptions can define one or more of: states in which the resource can be, a transition time required to transition between states of the resource, requirements of states of the resource to carry out a predetermined protocol step, and incompatibilities between different states of the resource.


The orders define one or more of: a sample ID of a particular sample, a protocol identifier identifying an assay to be performed on a sample, an entry time of the order and an expiration time of the order.


The protocol descriptions include one or more of: protocol identifiers, durations of the tasks in the protocol, sequences of the tasks in the protocol, timing windows for durations of tasks and timing windows for times between two tasks.


Generating one or more optimization problem can further comprise using a definition of one or more exceptions which can define how the automated laboratory equipment should handle one or more particular situations.


The one or more particular situations can include a situation in which a substance associated with a first order can be carried over to a process of another order. The one or more particular situations can include a situation in which a resource can be in state after having carried out a particular which can affect the processing of other subsequent tasks.


The one or more exceptions define one or more of: that one or more cleaning or other resource-conditioning steps can be added to the schedule, that a processing order of two or more tasks can be changed and that a predetermined number of tasks can be carried out between two tasks which can be sensitive to carry-over.


The method can include leaving gaps in the schedule which can be filled later upon arrival of new orders.


Generating one or more optimization problem instances can include using a forecast of expected orders.


The constraint optimization solver can be a generic constraint optimization solver.


The protocol descriptions can be defined independently of potential solutions for the schedule of operations.


The resource descriptions can be defined independently of potential solutions for the schedule of operations.


A starting schedule solution for the constraint optimization solver either pre-defined pattern, an optimal schedule for routine tests defined at design time, or patterns of schedule solutions that have been previously calculated can be used.


The method can further comprise defining one or more constraints to force the constraint optimization solver to search for solutions with repetitive patterns. Processing the one or more optimization problem instances can include forcing the schedule to fit a repetitive pattern.


The method can further comprise uploading the repetitive pattern to the automated analyzer and using the repetitive pattern at run-time to automatically fit the ordered protocols on the repetitive pattern.


A laboratory network is presented. The laboratory network can include automated laboratory equipment and a computer system configured to carry out the above methods to generate the schedule of operations for the automated laboratory equipment.


The computer system can be a part of the automated laboratory equipment. The computer system can be remote from the automated laboratory equipment.


The steps of the above methods can be at least partially carried out on a remote computer device or by a cloud-based application.


The laboratory network can include a plurality automated laboratory instruments. The schedule of operations can include orders for the plurality of automated laboratory instruments.


The automated laboratory instrument can include an automated analyzer for samples. The automated analyzer for samples can be an in-vitro analyzer. The in-vitro analyzer can be one of a clinical chemistry analyzer, an immune-chemistry analyzer, an analyzer for ion selective analysis, a hematology analyzer, a coagulation analyzer, a nucleic acid analyzer, a sequencer, a blood gas analyzer, a mass spectrometer, a cytometer, or a combination of two or more of these analyzers.


The automated laboratory instrument can include a controller configured to carry out the operations according to the schedule.


A computer-readable medium including instructions thereon is presented, which when executed by a computer system make the computer system carrying out the steps according to any of the above methods.


Further disclosed and proposed is a computer program including computer-executable instructions for performing the method according to the present disclosure in one or more of the embodiments enclosed herein when the program is executed on a computer or computer network. Specifically, the computer program may be stored on a computer-readable data carrier. Thus, specifically, one, more than one or even all of method steps as disclosed herein may be performed by using a computer or a computer network, preferably by using a computer program.


Further disclosed and proposed is a computer program product having program code, in order to perform the method according to the present disclosure in one or more of the embodiments enclosed herein when the program is executed on a computer or computer network. Specifically, the program code may be stored on a computer-readable data carrier.


Further disclosed and proposed is a data carrier having a data structure stored thereon, which, after loading into a computer or computer network, such as into a working memory or main memory of the computer or computer network, may execute the method according to one or more of the embodiments disclosed herein.


Further disclosed and proposed is a computer program product with program code stored on a machine-readable carrier, in order to perform the method according to one or more of the embodiments disclosed herein, when the program is executed on a computer or computer network. As used herein, a computer program product refers to the program as a tradable product. The product may generally exist in an arbitrary format, such as in a paper format, or on a computer-readable data carrier. Specifically, the computer program product may be distributed over a data network.


Further disclosed and proposed is a modulated data signal which contains instructions readable by a computer system or computer network, for performing the method according to one or more of the embodiments disclosed herein.


Referring to the computer-implemented aspects of the present disclosure, one or more of the method steps or even all of the method steps of the method according to one or more of the embodiments disclosed herein may be performed by using a computer or computer network. Thus, generally, any of the method steps including provision and/or manipulation of data may be performed by using a computer or computer network. Generally, these method steps may include any of the method steps, typically except for method steps requiring manual work, such as providing the samples and/or certain aspects of performing measurements.


Further disclosed and proposed is a computer or computer network comprising at least one processor, wherein the processor is adapted to perform the method according to one of the embodiments described in this description.


Further disclosed and proposed is a computer loadable data structure that is adapted to perform the method according to one of the embodiments described in this description while the data structure is being executed on a computer.


Further disclosed and proposed is a storage medium, wherein a data structure is stored on the storage medium and wherein the data structure is adapted to perform the method according to one of the embodiments described in this description after having been loaded into a main and/or working storage of a computer or of a computer network.


It is noted that terms like “preferably,” “commonly,” and “typically” are not utilized herein to limit the scope of the claimed embodiments or to imply that certain features are critical, essential, or even important to the structure or function of the claimed embodiments. Rather, these terms are merely intended to highlight alternative or additional features that may or may not be utilized in a particular embodiment of the present disclosure.


Having described the present disclosure in detail and by reference to specific embodiments thereof, it will be apparent that modifications and variations are possible without departing from the scope of the disclosure defined in the appended claims. More specifically, although some aspects of the present disclosure are identified herein as preferred or particularly advantageous, it is contemplated that the present disclosure is not necessarily limited to these preferred aspects of the disclosure.

Claims
  • 1. A method for providing a schedule of operations for automated laboratory equipment, the method comprising: receiving at least one order, wherein each order requires the execution of one or more protocols on the automated laboratory equipment;generating one or more optimization problem instances using one or more resource descriptions of the automated laboratory equipment, one or more protocol descriptions of the automated laboratory equipment, an objective function and the at least one order, wherein the one or more resource descriptions describe the resources present in the automated laboratory equipment and capabilities and constraints of the resources, wherein each protocol description describes a protocol the automated laboratory equipment can carry out, wherein each protocol description includes a definition of one or more protocol steps to be carried out by the automated laboratory equipment, wherein each protocol description includes one or more constraints to be observed when carrying out the protocol steps on the laboratory equipment, wherein the objective function defines an optimization goal for a schedule of operations for the automated laboratory equipment;providing the one or more optimization problem instances as input to a constraint optimization solver; andprocessing the one or more optimization problem instances by the constraint optimization solver to generate the schedule of operations to carry out the at least one order on the automated laboratory equipment.
  • 2. The method of claim 1, wherein the processing of the one or more optimization problem instances by the constraint optimization solver takes place during run-time of the automated laboratory equipment.
  • 3. The method of claim 2, wherein the processing of the one or more optimization problem instances by the constraint optimization solver takes place during run-time of the automated laboratory equipment in response to a triggering event, wherein the triggering event is one of an arrival of one or more new orders, a change in the resources of the automated laboratory equipment, a user input, a modification of an order forecast, a lapse of a predetermined period of time, an error, an exceptional situation, or a combination of two or more of these events.
  • 4. The method of claim 1, wherein the processing of the one or more optimization problem instances by the constraint optimization solver is repeated automatically in response to the occurrence of a respective triggering event.
  • 5. The method of claim 1, further comprising, collecting a batch of multiple orders for the automated laboratory equipment; andprocessing the optimization problem instance by the constraint optimization solver to generate a schedule of operations (for the batch of multiple orders at the same time.
  • 6. The method of claim 1, wherein the processing step takes place during development- or design-time of instrument software of the automated laboratory equipment, or wherein the processing step takes place during development- or design-time of schedules of operations of the automated laboratory equipment.
  • 7. The method of claim 1, wherein the method is carried out to simulate a behavior of the automated laboratory equipment, wherein the at least one order is at least one hypothetical order for the automated laboratory equipment and the schedule of operations is a schedule for the at least one hypothetical order.
  • 8. The method of claim 1, further comprising, changing the one or more resource descriptions, the one or more protocol descriptions and/or the objective function automatically by the automated laboratory equipment during operation, wherein the automatic change happens in response to detecting that resources are not available, an error modus, a user input or state change of the automated laboratory equipment.
  • 9. The method of claim 1, further comprising, providing the schedule of operations to a controller of the automated laboratory equipment; andinstructing, by the controller, the automated laboratory equipment to carry out the operations according to the schedule.
  • 10. The method of claim 1, wherein the optimization goal is one of the list of optimizing a throughput of the automated laboratory equipment, processing one or more particular orders as fast possible, using as little of a predetermined resource as possible, balancing of workload of two or more resources, or a combination of these goals.
  • 11. The method of claim 1, wherein the automated laboratory equipment includes a plurality of automated laboratory devices, wherein the orders are orders to be carried out by a plurality of automated laboratory devices and wherein the constraint optimization solver processes the one or more optimization problem instances to generate a schedule of operations for the plurality of automated laboratory devices.
  • 12. The method of claim 1, wherein the automated laboratory equipment is part of a laboratory environment, wherein the orders are orders to be carried out in the laboratory environment and wherein the generic constraint optimization solver processes the one or more optimization problem instances to generate a schedule of workflows in the laboratory environment.
  • 13. The method of claim 1, wherein the protocol descriptions are defined independently of potential solutions for the schedule of operations and wherein the resource descriptions are defined independently of potential solutions for the schedule of operations.
  • 14. A laboratory network, the laboratory network comprising: automated laboratory equipment; anda computer system configured to carry out the method of claim 1 to generate the schedule of operations for the automated laboratory equipment.
  • 15. A computer-readable medium including instructions thereon, which when executed by a computer system make the computer system carry out the method of claim 1.
Priority Claims (1)
Number Date Country Kind
16189852.3 Sep 2016 EP regional