SYSTEM AND METHOD FOR MANAGING CONTROL DATA FOR OPERATION OF BIOSYSTEMS ON CHIPS

Information

  • Patent Application
  • 20240028434
  • Publication Number
    20240028434
  • Date Filed
    July 25, 2022
    2 years ago
  • Date Published
    January 25, 2024
    11 months ago
Abstract
Methods and systems for operating biosystem on a chip are disclosed. To operate biosystem on a chip based systems, likely faults in the operation of the system may be predicted. Algorithms usable to mitigate the predicted likely faults may be identified, and ranked based on a level of impact that access to data reelecting the operation of the system may have on the utility of the algorithms. Higher ranked algorithms may be deployed for execution during operation of the system to lower latency locations while lower ranked algorithms may be deployed for execution to higher latency locations. The lower latency locations may include computing resources that are local to the biosystem on a chip, but that may be limited in quantity.
Description
FIELD

Embodiments disclosed herein relate generally to data management. More particularly, embodiments disclosed herein relate to systems and methods to manage deployment of control data.


BACKGROUND

Computing devices may provide computer-implemented services. The computer-implemented services may be used by users of the computing devices and/or devices operably connected to the computing devices. The computer-implemented services may be performed with hardware components such as processors, memory modules, storage devices, and communication devices. The operation of these components and the components of other devices may impact the performance of the computer-implemented services.





BRIEF DESCRIPTION OF THE DRAWINGS

Embodiments disclosed herein are illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.



FIG. 1A shows a block diagram illustrating a system in accordance with an embodiment.



FIG. 1B shows a block diagram illustrating a biosystem on a chip deployment in accordance with an embodiment.



FIG. 2A shows a block diagram illustrating a first data flow in accordance with an embodiment.



FIG. 2B show block diagrams illustrating a first data structure in accordance with an embodiment.



FIG. 2C shows a block diagram illustrating a second data flow in accordance with an embodiment.



FIG. 2D show block diagrams illustrating a second data structure in accordance with an embodiment.



FIG. 2E show block diagrams illustrating a third data flow in accordance with an embodiment.



FIG. 3A shows a flow diagram illustrating a method of storing and using data in accordance with an embodiment.



FIG. 3B shows a flow diagram illustrating a method of servicing information requests in accordance with an embodiment.



FIG. 3C shows a flow diagram illustrating a method of operating a biosystem on a chip deployment in accordance with an embodiment.



FIGS. 4A-4B show diagrams illustrating a system, operations performed thereby, and data structures used by the system over time in accordance with an embodiment.



FIG. 5 shows a block diagram illustrating a data processing system in accordance with an embodiment.





DETAILED DESCRIPTION

Various embodiments will be described with reference to details discussed below, and the accompanying drawings will illustrate the various embodiments. The following description and drawings are illustrative and are not to be construed as limiting. Numerous specific details are described to provide a thorough understanding of various embodiments. However, in certain instances, well-known or conventional details are not described in order to provide a concise discussion of embodiments disclosed herein.


Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in conjunction with the embodiment can be included in at least one embodiment. The appearances of the phrases “in one embodiment” and “an embodiment” in various places in the specification do not necessarily all refer to the same embodiment.


In general, embodiments disclosed herein relate to methods and systems for managing operation of systems on chips (BoC) and managing operation data for the BoCs. The operation data may include information regarding a process performed by one more BoCs. The operation data may be stored in a database that may include a low overhead for storage. The operation data may be stored in other types of structures such as containers that may also include low overhead by including little or no metadata.


To manage operation of the BoCs, predictions of faults in the operation of the BoCs may be identified. If a fault occurs, a process performed with a BoC may not successfully complete.


To reduce the likelihood of predicted faults from occurring, algorithms for controlling the operation of the BoC may be deployed. To select deployment locations for the algorithms, the sensitive of each algorithm with respect to latency of access to operation data form a BoC may be obtained. The sensitivity of each algorithm may be used to rank the algorithms with respect to one another. Higher ranked algorithms may be deployed to locations having lower levels of latency with respect to operation data during operation of the BoC. Lower ranked algorithms may be deployed at locations having higher latency with respect to operation data during operation of the BoC, but may have access to larger quantities of computing resources for implementing the algorithms.


By doing so, embodiments disclosed herein may provide a system that is able to more efficiently use limited computing resources to facilitate operation of BoC systems. For example, by deploying control algorithms in local computing resources of a BoC deployment, control algorithms having higher latency sensitive may still be used to mitigate predicted faults in the operation of the BoC deployment.


In an embodiment, a method for managing operation of a biosystem on a chip (BoC) deployment is provided. The method may include obtaining an architecture of a BoC of the BoC deployment; predicting a fault for a future operation of the BoC based on the architecture; obtaining a risk rating for a portion of control data usable to manage the predicted fault, the risk rating being based on a level of delay for hosting the portion of the control data remotely to the BoC deployment; making a determination regarding whether the risk rating exceeds a threshold; in a first instance of the determination where the risk rating exceeds the threshold: deploying a copy of the control data to local computing resources of the BoC deployment to obtain a deployed portion of the control data, and operating the BoC deployment using the deployed copy of the control data to manage any instances of the predicted fault that occur during the operation; and in a second instance of the determination where the risk rating does not exceed the threshold: operating the BoC deployment using the control data to manage the any instances of the predicted fault that occur during the operation, the control data being hosted by computing resources that are remote to the BoC deployment.


Operating the BoC deployment using the deployed copy of the control data may include executing a control algorithm specified by the deployed portion of the control data using the local computing resources to obtain an action; and implementing the action using a robotic controller of the BoC deployment.


Implementing the action may modify the operation of the BoC deployment to reduce a likelihood of a predicted fault of the any instances of the predicted fault from occurring.


Executing the control algorithm may include storing a copy of sensor data from a sensor of the BoC deployment that monitors an environmental condition within a portion of the BoC; and using the copy of the sensor data to identify the action.


Operating the BoC deployment using the deployed copy of the control data may also include executing a second control algorithm specified by a second portion of the control data using remote computing resources to obtain a second action; and implementing the second action using the BoC deployment.


The BoC deployment and the remote computing resources may be operably connected by a communication system that imparts a first level of latency for operation data from the BoC deployment to become available to the remote computing resources, the local computing resources are operably connected to other components of the BoC deployment via a low latency communication medium that imparts a second level of latency for operation data from the BoC deployment to become available to the local computing resources, and first level of latency reducing a capacity of the control data to manage the any instances of the predicted fault that occur during the operation of the BoC.


The predicted fault for the future operation of the BoC may also be based on operation data for a completed operation of the BoC deployment.


The risk rating may be based on a level of latency for hosting the portion of control data remotely during the operation of the BoC deployment.


A non-transitory media may include instructions that when executed by a processor cause the computer-implemented method to be performed.


A data processing system may include the non-transitory media and a processor, and may perform the computer-implemented method when the computer instructions are executed by the processor.


Turning to FIG. 1A, a block diagram illustrating a system in accordance with an embodiment is shown. The system shown in FIG. 1A may provide computer-implemented services that may utilize operation data one or more Biosystems on a Chip (BoC) as part of the provided computer-implemented services.


A BoC may be a physical device that performs one or more processes to emulate and/or duplicate processes that biological systems may perform. For example, biological systems may perform various types or processes through which input materials (e.g., proteins, chemicals, etc.) may be transformed into output materials. These processes may be performed, for example, at a cellular level, at a tissue level, at an organ level, and/or at other levels of biological systems.


To operate a BoC, BoC deployment 110 may include BoC 116, control system components 112, sensors 114, local computing resources 170, and/or other components. Each of these components is discussed below.


Generally, BoC 116 may be implemented with a physical structure that includes channels, chambers, and/or other fluidic components usable to channel, store, mix, and/or otherwise direct interactions between various fluids (in which various materials may be entrained). For example, BoC 116 may be implemented with a micro-fluidic device or other types of devices that may facilitate input of various fluids, direct interaction of the input fluids and/or manage the fluids as they traverse BoC 116, and output a product or other material (e.g., such as a new material generated through flow of the input material(s) through BoC 116).


To manage the fluids, direction of the fluids, conditions to which the fluids area exposed, and/or otherwise manage BoC 116, BoC deployment 110 may include control system components 112. Control system components may include any number of devices (e.g., valves, heaters, chillers, pumps, etc.) for controlling the flow of fluids through BoC 116, the environment to which the fluids are exposed in BoC 116, and/or otherwise managing processes performed with BoC 116.


To identifying the processes occurring within BoC 116, BoC deployment 110 may include any number of sensors 114. Sensors may be positioned with control systems components 112 and/or BoC 116, and may be adapted to monitor the processes being performed with BoC 116. For example, sensors 114 may include any number of flow rate sensors, temperature sensors, pressure sensors, and/or other types of sensors. Sensors 114 may be implemented using any type of hardware devices usable to measure any number and types of characteristics of the processes performed with BoC 116.


To manage the operation of BoC 116, BoC deployment may include local computing resources 170. Local computing resources 170 may reflect computing devices of BoC deployment 110 usable to control the operation of control system components 112, storage and/or use data from sensor 114, and/or perform other computer implemented functions. For example, local computing resources 170 may host application used to control all or a portion of control system components 112.


However, on contrast to the computing resources available to data management system 100, local computing resources 170 may include fewer resources. Consequently, local computing resources 170 may host some of the applications (which may implement various algorithms) used to operate the components of BoC deployment 110. Other components of BoC deployment 110 may be managed and/or operated by data management system 100, which may be remote to BoC deployment 110 thereby introducing latency between (i) when processes are performed by BoC deployment 110 (e.g., operations, data collection, etc.) and (ii) when portions of the control algorithms that use data regarding the processes are able to access the data. As will be discussed in greater detail below data management system 100 and/or other components of the system of FIG. 1A may divide algorithm and data storage duties between data management system 100 and local computing resources 170 to reduce the occurrence of undesired impacts of the latency.


While illustrated in FIG. 1A as being separate components, any of the components of BoC deployment 110 may be integrated (entirely or partially) with each other. Refer to FIG. 1B for additional details regarding BoC deployment 110.


As part of its operation, BoC deployment 110 may generate operation data. The operation data may reflect, for example, the operation of control system components 112 and sensors 114. For example, information regarding operation of a pump used to pump material into BoC 116 over time, pressures within portions of BoC 116, temperatures within the portions of BoC 116, and/or other types of information may be generated. This information may be usable, for example, to guide subsequent use of BoC deployment 110, use of other BoCs (not shown) or BoC deployments (not shown), and/or for other purposes.


For example, a downstream consumer (e.g., a researcher using an application) that may wish to implement a particular process may desire to review operation data from BoC systems to ascertain whether the process may be implemented using the BoC systems. Similarly, due to the complexity of operating BoC based systems, a downstream consumer may wish to ascertain whether a similar process has been performed in the past using a BoC. If the operation data for the previously performed processes is available, then the downstream consumer may use the operation data (rather than performing a new process with a BoC) as a substitute for a new process or to guide performance of a new process using a BoC.


In general, embodiments disclosed herein may provide methods, systems, and/or devices for (i) managing storage and use of operation data for BoC based systems and (ii) managing processes performed by BoC systems. To its functionality, the system of FIG. 1A may include data management system 100. Data management system 100 may manage storage of BoC based system operation data, facilitate comparison between different BoC systems (which may use different BoCs having different architectures), facilitate use of the stored operation data, and manage operations performed by BoC deployment 110.


To manage storage of operation data and facilitate exploration, data management system 100 may (i) store operation data for BoC systems in a database, which may be unstructured, (ii) obtain graph representations for the BoC systems, (iii) link the graph representations (or portions thereof) to portions of the database in which operation data for a corresponding BoC based system is stored, and/or (iv) facilitate comparison between different BoC based systems through generation and use of metagraphs based on the graph representations of the BoCs. By doing so, embodiments disclosed herein may provide a system capable of managing large amounts of operation data from BoC based systems in a manner that better facilitates subsequent use of the BoC based system operation data (e.g., when compared to only storing the operation data in a database).


To manage operations performed by BoC deployment 110, data management system 100 may (i) analyze the architecture of BoC 116 to identify likely failures of processes performed by BoC deployment 110, (ii) maintain a library of algorithms usable to mitigate the likely failures, (iii) rank the algorithms with respect to the impact that latency will have on their respective performances, and (iv) deploy some of the algorithms to local computing resources 170 for execution based on the ranking of the algorithms while deploying others to data management system 100 (or other remote computing resource collections not shown in FIG. 1A) for execution during subsequent operation of BoC deployment 110. By doing so, the system of FIG. 1A may efficiently marshal limited computing resources to manage processes performed by BoC deployment 110 which may include portions that are managed with latency sensitive algorithms. For example, quickly increasing levels of pressure in a portion of BoC 116 may need to be addressed within durations of time that latency makes infeasible to achieve using remotely executed algorithms.


Refer to FIGS. 2A-2E for additional details regarding the functionality of data management system 100.


When performing their functionality, one or more of data management system 100 and BoC deployment 110 may perform all, or a portion, of the methods and/or actions shown in FIGS. 3A-3B.


Any of data management system 100 and BoC deployment 110 may be implemented using a computing device (e.g., a data processing system) such as a host or a server, a personal computer (e.g., desktops, laptops, and tablets), a “thin” client, a personal digital assistant (PDA), a Web enabled appliance, a mobile phone (e.g., Smartphone), an embedded system, local controllers, an edge node, and/or any other type of data processing device or system. For additional details regarding computing devices, refer to FIG. 5.


In an embodiment, data management system 100 is implemented with multiple computing devices. For example, some of the computing devices may provide data storage services while other computing devices may provide services related to identifying similarities and/or differences of various BoC based systems.


Any of the components illustrated in FIG. 1A may be operably connected to each other (and/or components not illustrated) with a communication system (e.g., 105).


In an embodiment, communication system 105 includes one or more networks that facilitate communication between any number of components. The networks may include wired networks and/or wireless networks (e.g., and/or the Internet). The networks may operate in accordance with any number and types of communication protocols (e.g., such as the internet protocol).


These networks may introduce latency with respect to data management system 100 and BoC deployment 110. In contrast, the components of BoC deployment 110 may be operably connected via low latency connections (such as a single local network) that introduces lower levels of latency within BoC deployment 110. As used herein, latency may refer to a time delay due to transit of information via one or more mediums, such as communication system 105.


While illustrated in FIG. 1A as including a limited number of specific components, a system in accordance with an embodiment may include fewer, additional, and/or different components than those illustrated therein.


Turning to FIG. 1B, a diagram of an example instance of BoC deployment 110 in accordance with an embodiment is shown. As discussed above BoC deployment 110 may implement a process to generate one or more output materials, such as output material 160. Output material 160 may be a desired product such as, for example, a protein or another type of material.


To generate output materials, BoC deployment 110 may include BoC 116. In FIG. 1B, a top view of BoC 116 is shown. BoC 116 may include a body in which any number of chambers (e.g., 120A-120B), channels (e.g., 122A-122E), and/or other types of features (not shown) are positioned. These chambers and channels may facilitate, for example, completion of chemical reactions that may transform one or more input materials (e.g., 150A-150C) into one or more output materials (e.g., 160).


A chamber may be a cavity or other space within the body of BoC 116. For example, BoC 116 may be implemented by starting with a block of material (e.g., a sheet) and removing some of the material to form chambers. A cover or other structure may be positioned to close the top portions of the chambers. While shown in FIG. 1B as including two chambers 120A, 120B, a BoC in accordance with an embodiment may include any number of chambers without departing from embodiments disclosed herein. The chambers may be of similar and/or different shapes/sizes.


A channel may be a cavity or other space within the body of BoC 116 that connects chambers to other chambers, input or output ports, and/or other structures. For example, BoC 116 may be implemented by starting with a block of material (e.g., a sheet) and removing some of the material to form the channels. A cover or other structure may be positioned to close the top portions of the channels. While shown in FIG. 1B as including five channels 122A-122E, a BoC in accordance with an embodiment may include any number of channels without departing from embodiments disclosed herein. The channels may be of similar and/or different shapes/sizes, and may connect similar or different other portions of BoC 116.


To manage the processes performed with BoC 116, control system components 112 of BoC deployment may include any number of actuators (e.g., 130A-130D). The actuators may manage flow of materials through BoC 116. For example, the actuators may include valves, pumps, and/or other types of flow control components, which may be computerized thereby allowing for computer control of the flow of materials through BoC 116. While not shown in FIG. 1B, control system components 112 may include other types of components such as, for example, heating elements, cooling elements, and/or other types of devices that may manage flows of material and/or environmental conditions presented to the materials.


Control system components 112 may also include any number of robotic controllers (e.g., 132A). A robotic controller may be a computer controllable machine that may modify the operation of BoC 116 and/or components (e.g., such as changing out any of input materials 150A-150C). The computer controllable machine may be implemented with, for example, a mechanical arm, pinching appendages to pickup items, and/or other features. The operation of control system components 112 may be managed via algorithms performed by local computing resources 170 and/or remote computing resources.


To manage the processes performed with BoC 116, sensors 114 of BoC deployment 110 may include any number of sensors (140A-140E, others shown in FIG. 1B are not numbered for readability). These sensors may obtain data regarding the process performed with BoC 116 such as, for example, flowrates of materials, temperatures/pressures of materials at various locations in BoC 116, and/or other characteristics of the process performed with BoC 116.


The measurements from sensors 140 may be provided to remote and/or local computing resources. For example, copies of some of the sensor measurements may be provided to both remote and local computing resources 170 so that any algorithms performed by local computing resources 170 may have access to information regarding the state of BoC deployment 110 with little latency. Accordingly, the algorithms implemented by local computing resources 170 may have more current representations of the state of BoC deployment 110 than remote computing resources.


Any of sensors 114 and control system components 112 may be positioned with (e.g., integrated) or outside of BoC 116. For example, some of these components may be integrated into BoC 116 while other may be positioned outside of BoC 116.


As seen in FIG. 1B, control data for control system components 112 and sensor measurements from sensors 114 may be obtained during operation of BoC 116. This information (e.g., “operation data”) may be stored for future use in a manner that facilitates its future. As will be discussed below, a combination of graph representations and databases may be used to store the operation data and facilitate use of the operation data.


Turning to FIGS. 2A-2E, data flow and data structure diagrams in accordance with an embodiment are shown.



FIG. 2A shows a data flow diagram in accordance with an embodiment. Operation data 202 may be generated during operation of a BoC, and structure data 203 may include information regarding the architecture of the BoC that performed the process through which operation data 202 was obtained. To manage and use operation data 202 in the future, operation data 202 and structure data 203 may be used to store the various portions of operation data 202 in a manner that facilitates ease of use in the future while managing cost for storing the portions.


To do so, operation data 202 may be subjected to database processing 204 to generate database entries 206 in which portions of operation data 202 may be stored. For example, the portions may correspond to sensor measurements (e.g., over the duration of the process) and/or control data used to operate actuators and/or other components. Once generated, database entries 206 may be added to operation data database 212.


Generally, operation data database 212 may be implemented with a low computational overhead architecture such as, for example, an unstructured database. For example, the database entries 206 may simply be stored without generating significant metadata and/or other types of indexing data. By doing so, the operation may be efficiently stored, but may limit search functionality for operation data database 212.


To facilitate searching of operation data 202 and/or comparison between the BoC and other BoCs, operation data 202, structure data 203, and/or database entries 206 may be subjected to graph processing 208. Graph processing may generate a graph representation and/or updates to an existing graph representation (e.g., 210) of the structure (e.g., architecture) of the BoC. For example, graph representation 214 may include nodes corresponding to chambers and channels of the BoC, and the edges between the nodes may correspond to connections (e.g., 124) between these portions of the BoC.


Additionally, each of the nodes may be associated with pointers to the database entries 206 that include operation data associated with the corresponding component of BoC. In this manner, to identify operation data associated with a particular component of a BoC, the corresponding node (e.g., which may include a label or other association indicator) may be identified in the graph representations. The associated pointers for the identified node may identify the entries of operation data database 212 in which the operation data is stored.


Turning to FIG. 2B, a data structure diagram in accordance with an embodiment is shown. In FIG. 2B, a portion of graph representation 214A corresponding to a chamber and three channels of a BoC is shown. Node 220 may correspond to the chamber while the other nodes 222-226 may correspond to the channels. Edges 230, 232, 234 between the nodes indicate the fluidic connections between these structures of the BoC. Thus, in this example, edges 230-234 indicate that each of the channels connects to the chamber associated with node 220.


Node 220 may also include or have associated with it any number of pointers that point to operation data of operation data database 212 associated with the chamber. In this example, node 220 is associated with two pointers that point to two entry 212A-212B of operation data database 212. These entries include measurements of pressure and temperature of the fluids within the chamber during operation of the BoC.


In an embodiment, the operation data for each component is stored as part of information for a corresponding node (e.g., part of the graph representation).


While shown in FIG. 2B with a limited number of nodes, pointers, and edges, it will be understood that these data structures may include any number of these components without departing from embodiments disclosed herein.


Turning to FIG. 2C, a data flow diagram in accordance with an embodiment is shown. Once the data structures illustrated in FIG. 2B are obtained, the data structures may be used to facilitate use of BoC system data. To do so, for example, a user interested in identifying similar BoC systems may submit a similarity form 240. The similarity form may define a hypothetical architecture of BoC system, including the numbers and arrangements of chambers, channels, and/or other features of the hypothetical BoC system.


Once submitted, similarity form 240 may be subject to graph processing 242, which may also use any number of graph representations of BoC systems as input. The graph representations of the BoC systems may be stored in a repository, such as graph representation repository 246.


The graph processing 242 may generate metagraph 244. Metagraph 244 may be a graph representation of the similarities between the similarity form and the other BoCs.


Metagraph 244 may include any number of nodes corresponding to each of the BoC systems for which graph representations are available, and the similarity form. The edges of the nodes may indicate the level of similarity between the similarity form and the BoCs. For example, larger numbers of edges and/or weights of the edges between two nodes may indicate a higher level of similarity between the nodes. Thus, to identify a BoC most similar to similarity form 240, the numbers of edges and/or weights of the edges between the node of metagraph 244 corresponding to the similarity form and each other node. The other node connected to the node corresponding to the similarity form by the largest number of edges may be the most closely related, architecturally to similarity form 240.


Additionally, in an embodiment, different edges may represent the similarity of different characteristics (e.g., indicated by the weights of the corresponding edges) of two graph representations and corresponding architectures of BoCs. For example, a first edge may represent a similarity between the quantity of nodes in two graph representations, and a second edge may represent a similarity between the average number of edges between the nodes in the two graph representations. For highly dissimilar characteristics, edges may not even be added to further convey the differences in architectures of BoCs. By doing so, metagraph 244 may be filterable based on the type of similarity a user may wish to investigate. For example, in FIG. 2D, if a user wished to investigate similarity levels of numbers of nodes, all of the first edges 260 associated with other characteristics may be removed to provide a visual indication with respect to the level of similarity between the number of nodes of the similarity form and the graph representation of the first BoC. The weight of the remaining edge (e.g., thickness) may convey the level of similarity regarding that specific characteristic of the architectures of the similarity form and the first BoC.


Turning to FIG. 2D, a data structure diagram in accordance with an embodiment is shown. In FIG. 2D, an example of metagraph 244 is shown for a similarity form and two BoCs.


As seen in FIG. 2D, metagraph 244 may include three nodes 250, 252, 254. Node 250 may correspond to the similarity form, while the other nodes 252, 254 may correspond to two different BoCs having different architectures.


First edges 260 between node 250 and node 252 may indicate a level of similarity between the architecture specified by the similarity form and the first BoC. Second edges 262 between node 250 and node 254 may indicate a level of similarity between the architecture specified by the similarity form and the second BoC.


As seen in FIG. 2D, in this example, first edges 260 may include two edges and second edges 262 may include three edges. Thus, in this example, it may be concluded that second BoC is more similar to the similarity form than the first BoC.


However, while illustrated in this example with multiple edges representing similarity, as noted above, weights of the edges may be used (in conjunction with and/or alternatively to multiple edges) to represent the level of similarity and/or similarity levels with respect to certain characteristics of the architectures of multiple BoCs. For example, any two nodes may be connected with a single edge that has a weight (e.g., graphically this could be a thickness of a line representing the edge in a depiction of metagraph 244, may represent an overall similarity) and/or multiple edges that may represent the similarity of different characteristics of two BoC architectures.


The edges between the nodes may be identified through pattern matching, graph analysis, inferencing, or other means. For example, the architecture specified by the similarity form may be transformed into (or used as a basis for) a graph representation and compared to the graph representation of the architecture of the first BoC and the second BoC. Similar node and edge patterns in each graph representation may give rise to edges between the corresponding nodes of metagraph 244. The edges of metagraph 244 may be added when, for example, a graph representation of a similarity form and a graph representation of a BoC include a same node with a same edge pattern about the node. Thus, in an embodiment, the number of edges that may be present between nodes of metagraph 244 may be up to the number of nodes of the similarity form.


Turning to FIG. 2E, a data flow diagram in accordance with an embodiment is shown. In FIG. 2E, data management system 100 may be preparing to operate a BoC deployment. To do so, data management system 100 may decide where different portions of algorithms (e.g., control data of control data repository 280) used to manage the operation of the BoC deployment should be deployed.


To do so, data management system 100 may subject structure data 203 and/or operation data database 212 to fault prediction processing 272. Fault prediction processing 272 may identify which portions of a process for operating the BoC deployment are likely to fail or become susceptible to failure during operation of the BoC deployment.


For example, a trained inference model (e.g., a trained neural network) may take structure data 203 as input and identify faults that are likely to occur. An example may be a chamber connected to a narrow channel. This type of structure may present risk of fluid pressure in the channel exceeding a threshold that results in damage to the BoC deployment. The inference model may be trained using a labeled data set that associates various architectures with corresponding failures. Similarly, the corresponding failures (e.g., faults) may also be associated with various algorithms (e.g., stored in control data repository 280) that may be used to proactively and/or reactively address faults or reduce the impacts of faults on operation of a BoC deployment.


Predicted faults 274 may be obtained through performance of fault prediction processing 272. Any number of faults may be predicted. To remediate the faults, any number of algorithms from control data repository 280 may need to be performed. However, the ability of these algorithms to remediate the faults may depend on the level of latency for access to operation data and/or performance of the algorithm (which may be limited by computational resources of various host devices). Thus, if an algorithm that is latency sensitive is deployed to remote computing resources for operation or to local computing resources that include insufficient resources for performance of an algorithm, then the algorithm even if performed may not successfully prevent or remediate the impact of some or all of predicted faults 274.


To reduce the impact of latency, a portion of the algorithms stored in control data repository 280 usable to address predicted faults 274 may be subject to fault response risk processing 276. Fault response risk processing 276 may provide control data risk ratings 278 which may rank the portion of the algorithm with respect to the impact of latency on their abilities to mitigation corresponding predicted faults 274.


For example, a trained inference model (e.g., a trained neural network) may take the portion of algorithms from control data repository 280 as input and identify the level of impact that latency with respect to operation data will have on their operation. In another example, the operation of each algorithm may be simulated with varying levels of latency for accessing operation data during the simulation to identify the level of impact that latency will have on each algorithm.


Once obtained, control data risk ratings 278 may be used to perform deployment processing 282 to select a portion of the algorithms for deployment to local computing resources 170. The portion may be based on an available quantity of the local computing resources 170 and/or the computational resources required to perform the algorithms.


For example, the algorithms most sensitive to latency (as indicated by control data risk ratings 278) and that fit within the available computing resources of local computing resources 170 may be selected for and deployed to local computing resources 170. Other algorithms needed to mitigate predicted faults 274 may be deployed to other computing resources, such as those of data management system 100 or other remote computing resources (e.g., remote to the BoC deployment).


Once deployed, the algorithms may begin to manage the operation of the BoC deployment. To facilitate operation of these algorithms, the operation data which the algorithms use to make control decisions (which may include any type and quantity of operation data) may be stored locally to the algorithm execution location and/or as specified by the methods illustrated in FIGS. 3A-3B. Refer to FIGS. 4A-4B for additional details regarding operation of a BoC deployment.


As discussed above, the components of FIG. 1A may perform various methods to manage and facilitate use of BoC system operation data. FIGS. 3A-3C illustrate methods that may be performed by the components of FIG. 1A. In the diagrams discussed below and shown in FIGS. 3A-3C, any of the operations may be repeated, performed in different orders, and/or performed in parallel with or in a partially overlapping in time manner with other operations.


Turning to FIG. 3A, a flow diagram illustrating a method of storing and using BoC data in accordance with an embodiment is shown. The method may be performed by a data management system or a data processing system.


At operation 300, operation data for a BoC is obtained. The operation data may be obtained by (i) receiving it form a BoC deployment, (ii) reading it from storage, and/or (iii) receiving it from another device. The operation data may reflect operation of the BoC.


At operation 302, the operation data is stored in a database. The operation data may be stored in the database by generating and adding entries to the database. The entries may include and/or be based on the operation data such that the operation data may be retrieved from the database. The data may not include, for example, indications of how or from where the operation data was obtained. Rather, the database may be an unstructured database.


At operation 304, a graph update is generated based on the stored operation data. The graph update may be generated by (i) generating a new graph representation for the BoC if none existed previously, and (ii) generating a change log for an existing graph representation of the BoC that updates nodes corresponding to the components of the BoC associated with various portions of the operation data. For example, pointers may be added to the nodes (or may otherwise be associated with the nodes). The pointers associated with each node may facilitate retrieval of the operation data from the data that is associated with component of the BoC associated with the node.


At operation 306, a graph representation of the BoC is updated using the graph update. The graph representation may be updated by either (i) using the new graph representation as the updated graph representation of the BoC in a case in which no graph representation of the BoC previously existed and/or (ii) applying the update change log to the existing graph representation of the BoC.


At operation 308, a request for operation data for a component of the BoC is obtained. The request may be obtained by (i) receiving it from another device, (ii) receiving it from an application, and/or (iii) obtaining user input that indicates the request. The component may be, for example, a chamber, channel, and/or other portion of the BoC.


At operation 310, a node of the graph representation of the BoC is identified based on the component. For example, an identifier of the component may be used to search the graph representation to identify the node (e.g., which may be labeled with the identifier of the component).


At operation 312, a pointer associated with the identified node is used to read the operation data for the component from the database. The pointer may be used by performing a read or lookup using the information included in the pointer. For example, the pointer may specify entries of the database. The specified entries may be read from the database, and the operation may be in the read entries of the database.


The method may end following operation 312.


Using the method illustrated in FIG. 3A, embodiments disclosed herein may facilitate storage and use of operation data from BoCs.


Turning to FIG. 3B, a flow diagram illustrating a method of using stored operation data in accordance with an embodiment is shown. The method may be performed by a data management system or a data processing system.


At operation 320, an information request based on a similarity form is obtained. The information request may specify, for example, that a type of operation data for a BoC most similar to the similarity form be provided.


At operation 322, a metagraph is generated based on the similarity form and a repository of graph representations of BoC systems. The metagraph may be generated by generating a graph representation for the architecture indicated by the similarity form. The graph representation of the similarity forms and the graph representations in the repository may be used to establish nodes (e.g., one per graph representation) of the metagraph. Edges of the metagraph may be established based on similarity between the graph representation for the similarity form and the other graph representations in the repository. Thus, the node corresponding to the graph representation of the similarity form may be connected to the other nodes of the metagraph by numbers of edges corresponding to a level of similarity between the architecture specified by the similarity form and the architectures of the BoC systems.


At operation 324, one of the BoCs is identified based on edges between the nodes of the metagraph as being a closest match to the similarity form. The one of the BoCs may be identified by counter the edges between the node corresponding to the similarity form and the other nodes. The BoC associated with the other node that is connected to the node corresponding to the similarity form with the largest number of edges may be the identified one of the BoCs.


At operation 326, operation data for the identified one of the BoCs is provided to service the information request. The operation data may be provided by identified the graph representation corresponding to the BoC, identifying one or more nodes of the identified graph representation relevant to the requested operation data, identifying pointers associated with the one or more identified nodes, and reading entries of the database using the pointers. The read entries may include the operation data.


The method may end following operation 326.


Using the method illustrated in FIG. 3B, embodiments disclosed herein may facilitate identification and use of operation data for BoCs that are similar to a target BoC architecture. By doing so, the operation data for BoCs may not need to be identified to ascertain its relevance with respect to a desired BoC architecture.


Turning to FIG. 3C, a flow diagram illustrating a method of operating a BoC deployment in accordance with an embodiment is shown. The method may be performed by a data management system or a data processing system.


At operation 340, an architecture of a BoC of a BoC deployment is obtained. The architecture may be read from storage, received from another device, or may otherwise be obtained. The architecture may be specified by a data structure.


At operation 342, a fault of a future operation of the BoC is predicted based on the architecture of the BoC. For example, a trained inference model or other process may take the architecture as input and output the predicted fault.


At operation 344, a risk rating for control data usable to manage the predicted fault is obtained. The risk rating may be obtained using, for example, a trained inference model, through simulation, or through other processes. The risk rating may indicate a level of undesired impact that latency (e.g., due to communication time or computation time) will have on the control data. The control data may be, for example, an application or other data structure usable to perform an algorithm believed to be able to mitigate impacts of the predicted fault.


For example, portions of control data within a repository may be indexed based on the types of faults that they are believed to be able to remediate. A lookup based on the type of the predicted fault may be performed to identify the portion(s) of control data that may be deployed to attempt to proactively address the predicted fault.


At operation 346, a determination is made regarding whether the risk rating exceeds a threshold. The determination may be made by comparing the risk rating to the threshold (e.g., a level of impact that if exceeded indicates that the control data should be prioritized to reduce latency to which it is exposed). The threshold may be determined heuristically.


In an embodiment, at operation 342 multiple faults are predicted. In such a scenario, the threshold may be set dynamically. For example, the threshold may initially be set low and incrementally increased until the computing resources necessary to execute algorithms specified by the control data are within the capabilities of local computing resources of a BoC deployment. In other words, the highest ranked control data (e.g., with respect to negative impact from latency) that will fit within local computing resources of a BoC deployment may be determined as exceeding the dynamically set threshold.


If it is determined that the risk rating for the control data exceeds the threshold, then the method may proceed to operation 348. Otherwise, the method may proceed to operation 352.


At operation 348, the control data is deployed to local computing resources of the BoC deployment (e.g., when the risk rating is due to communication latency and not computation latency). The control data may be deployed by sending a copy of it to the local computing resources. The local control resources may then then use it to initiate execution of an algorithm that is likely to remediate the predicted fault.


At operation 350, a product is generated using the BoC deployment. When doing so, the deployed control data may manage instances of the predicted fault. For example, the deployed control day may control the operation of one or more actuators, robotic controllers, and/or other control system components 112. When doing so, local copies of sensor data and/or other data used by the algorithm implemented with the deployed control data may be used in the algorithm. Consequently, the latency for accessing the data used to perform the algorithm may be reduced when compared to remote deployments of the control data.


The method may end following operation 350.


Returning to operation 346, the method may proceed to operation 352 when the risk rating does not exceed the threshold.


At operation 352, a product is generated using the BoC deployment using a remote instance of the control data to manage instances of the predicted fault (e.g., when the risk rating is not due to communication latency). For example, the control data may be used to begin performance of the algorithm remotely to the BoC deployment thereby imparting latency in access to the data used to perform the algorithm.


The method may end following operation 352.


Using the method illustrated in FIG. 3C, embodiments disclosed herein may facilitate efficient storage of data while ensuring that control algorithms for managing BoC deployments are executed at locations where latency of data access is within tolerances of the control algorithms.


Additionally, while described in operations 352 and 348 as being deployed to one of two locations, it will be understood that there may be a range of different locations to which the control data may be deployed, and the deployment location may be selected based on risk ratings for both computational and communication latency. Thus, even when a risk rating based on communication latency is high, the control data may be deployed to remote computing resources if the computational risk rating is high and the local computing resources include insufficient computing resources to timely perform an algorithm using the control data.


Turning to FIGS. 4A-4B, diagrams illustrating a process of operating a BoC in accordance with an embodiment are shown.


Turning to FIG. 4A, consider a scenario in which complex BoC 400 will be used to perform a process for generating a desired material. To prepare to manage the process, data management system 100 may investigate the architecture of complex BoC 400 and/or may use operation data from previously performed processes to identify likely faults that will occur.


To reduce the likelihood of the predicted faults from occurring, data management system 100 may select one or more algorithms for controlling robotic controllers 132A-132B in a manner likely to mitigate the predicted failures. For example, a first algorithm for robotic controller 132A may monitor a pressure within a chamber of complex BoC 400, and change a pump rate of a material based on the pressure. A second algorithm for robotic controller 132B may monitor output material from complex BoC 400.


Local computing resources 170 of BoC deployment 110 may only be capable of hosting one of the control algorithms. Consequently, to ascertain which algorithm to use, data management system 100 may simulate operation of complex BoC 400 using each algorithm with progressively larger amounts latency to access to the pressure data and output material data monitored by sensor 140A and sensor 140B, respectively. Through this simulation, data management system 100 ascertains that the first algorithm is highly sensitive to latency while the second algorithm is insensitive to latency.


Based on this determination, data management system 100 may send control data for robotic controller 132A to local computing resources 170 for execution during operation of complex BoC 400. Additionally, the data that sensor 140A will generate is set for redundant storage in both local computing resources 170 and the database hosted by data management system 100.


Turning to FIG. 4B, when operation of complex BoC 400 begins, local computing resources 170 may begin collecting data from sensor 140A. The collected data may be used by the algorithm performed by local computing resources 170 to control robotic controller 132A to perform various actions. For example, the algorithm may indicate that the pump rate into complex BoC 400 is to be maintained inversely proportionally to the pressure indicated by sensor 140A. Consequently, as the pressure increases, actions sent to robotic controller 132A cause robotic controller 132A to reduce the pump rate of material into complex BoC 400 which reduces the pressure within the chamber thereby keeping it within structural limits.


Likewise, data management system 100 may begin to collect data from both sensors 140A, 140B. The collected data may be used by the algorithm performed by data management system 100 to decide robotic controller 132B will operate. To do so, as data is received, the algorithm may decide various actions for robotic controller 132B to perform. However, due to the remote implementation of this algorithm, the data upon which the algorithm operates may include significant latency.


However, because the algorithm for robotic controller 132B is insensitive to latency, the delay introduced by storing the data in the database maintained by data management system 100, and using graph representations to mediate data access may not impact the ability of the actions for robotic controller 132B to mitigation the corresponding predicted fault.


Thus, as illustrated in FIGS. 4A-4B, embodiments disclosed herein may provide a system that facilitate efficient storage and use of data, while facilitate successful system operation through appropriate placement of algorithms in a distributed computing environment.


Any of the components illustrated in FIGS. 1-4B may be implemented with one or more computing devices. Turning to FIG. 5, a block diagram illustrating an example of a data processing system (e.g., a computing device) in accordance with an embodiment is shown. For example, system 500 may represent any of data processing systems described above performing any of the processes or methods described above. System 500 can include many different components. These components can be implemented as integrated circuits (ICs), portions thereof, discrete electronic devices, or other modules adapted to a circuit board such as a motherboard or add-in card of the computer system, or as components otherwise incorporated within a chassis of the computer system. Note also that system 500 is intended to show a high level view of many components of the computer system. However, it is to be understood that additional components may be present in certain implementations and furthermore, different arrangement of the components shown may occur in other implementations. System 500 may represent a desktop, a laptop, a tablet, a server, a mobile phone, a media player, a personal digital assistant (PDA), a personal communicator, a gaming device, a network router or hub, a wireless access point (AP) or repeater, a set-top box, or a combination thereof. Further, while only a single machine or system is illustrated, the term “machine” or “system” shall also be taken to include any collection of machines or systems that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.


In one embodiment, system 500 includes processor 501, memory 503, and devices 505-507 via a bus or an interconnect 510. Processor 501 may represent a single processor or multiple processors with a single processor core or multiple processor cores included therein. Processor 501 may represent one or more general-purpose processors such as a microprocessor, a central processing unit (CPU), or the like. More particularly, processor 501 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or processor implementing other instruction sets, or processors implementing a combination of instruction sets. Processor 501 may also be one or more special-purpose processors such as an application specific integrated circuit (ASIC), a cellular or baseband processor, a field programmable gate array (FPGA), a digital signal processor (DSP), a network processor, a graphics processor, a network processor, a communications processor, a cryptographic processor, a co-processor, an embedded processor, or any other type of logic capable of processing instructions.


Processor 501, which may be a low power multi-core processor socket such as an ultra-low voltage processor, may act as a main processing unit and central hub for communication with the various components of the system. Such processor can be implemented as a system on chip (SoC). Processor 501 is configured to execute instructions for performing the operations discussed herein. System 500 may further include a graphics interface that communicates with optional graphics subsystem 504, which may include a display controller, a graphics processor, and/or a display device.


Processor 501 may communicate with memory 503, which in one embodiment can be implemented via multiple memory devices to provide for a given amount of system memory. Memory 503 may include one or more volatile storage (or memory) devices such as random access memory (RAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), static RAM (SRAM), or other types of storage devices. Memory 503 may store information including sequences of instructions that are executed by processor 501, or any other device. For example, executable code and/or data of a variety of operating systems, device drivers, firmware (e.g., input output basic system or BIOS), and/or applications can be loaded in memory 503 and executed by processor 501. An operating system can be any kind of operating systems, such as, for example, Windows® operating system from Microsoft®, Mac OS®/iOS® from Apple, Android® from Google®, Linux®, Unix®, or other real-time or embedded operating systems such as VxWorks.


System 500 may further include IO devices such as devices (e.g., 505, 506, 507, 508) including network interface device(s) 505, optional input device(s) 506, and other optional IO device(s) 507. Network interface device(s) 505 may include a wireless transceiver and/or a network interface card (NIC). The wireless transceiver may be a WiFi transceiver, an infrared transceiver, a Bluetooth transceiver, a WiMax transceiver, a wireless cellular telephony transceiver, a satellite transceiver (e.g., a global positioning system (GPS) transceiver), or other radio frequency (RF) transceivers, or a combination thereof. The NIC may be an Ethernet card.


Input device(s) 506 may include a mouse, a touch pad, a touch sensitive screen (which may be integrated with a display device of optional graphics subsystem 504), a pointer device such as a stylus, and/or a keyboard (e.g., physical keyboard or a virtual keyboard displayed as part of a touch sensitive screen). For example, input device(s) 506 may include a touch screen controller coupled to a touch screen. The touch screen and touch screen controller can, for example, detect contact and movement or break thereof using any of a plurality of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, and surface acoustic wave technologies, as well as other proximity sensor arrays or other elements for determining one or more points of contact with the touch screen.


IO devices 507 may include an audio device. An audio device may include a speaker and/or a microphone to facilitate voice-enabled functions, such as voice recognition, voice replication, digital recording, and/or telephony functions. Other IO devices 507 may further include universal serial bus (USB) port(s), parallel port(s), serial port(s), a printer, a network interface, a bus bridge (e.g., a PCI-PCI bridge), sensor(s) (e.g., a motion sensor such as an accelerometer, gyroscope, a magnetometer, a light sensor, compass, a proximity sensor, etc.), or a combination thereof. IO device(s) 507 may further include an image processing subsystem (e.g., a camera), which may include an optical sensor, such as a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor, utilized to facilitate camera functions, such as recording photographs and video clips. Certain sensors may be coupled to interconnect 510 via a sensor hub (not shown), while other devices such as a keyboard or thermal sensor may be controlled by an embedded controller (not shown), dependent upon the specific configuration or design of system 500.


To provide for persistent storage of information such as data, applications, one or more operating systems and so forth, a mass storage (not shown) may also couple to processor 501. In various embodiments, to enable a thinner and lighter system design as well as to improve system responsiveness, this mass storage may be implemented via a solid state device (SSD). However, in other embodiments, the mass storage may primarily be implemented using a hard disk drive (HDD) with a smaller amount of SSD storage to act as a SSD cache to enable non-volatile storage of context state and other such information during power down events so that a fast power up can occur on re-initiation of system activities. Also a flash device may be coupled to processor 501, e.g., via a serial peripheral interface (SPI). This flash device may provide for non-volatile storage of system software, including a basic input/output software (BIOS) as well as other firmware of the system.


Storage device 508 may include computer-readable storage medium 509 (also known as a machine-readable storage medium or a computer-readable medium) on which is stored one or more sets of instructions or software (e.g., processing module, unit, and/or processing module/unit/logic 528) embodying any one or more of the methodologies or functions described herein. Processing module/unit/logic 528 may represent any of the components described above. Processing module/unit/logic 528 may also reside, completely or at least partially, within memory 503 and/or within processor 501 during execution thereof by system 500, memory 503 and processor 501 also constituting machine-accessible storage media. Processing module/unit/logic 528 may further be transmitted or received over a network via network interface device(s) 505.


Computer-readable storage medium 509 may also be used to store some software functionalities described above persistently. While computer-readable storage medium 509 is shown in an exemplary embodiment to be a single medium, the term “computer-readable storage medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The terms “computer-readable storage medium” shall also be taken to include any medium that is capable of storing or encoding a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of embodiments disclosed herein. The term “computer-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, and optical and magnetic media, or any other non-transitory machine-readable medium.


Processing module/unit/logic 528, components and other features described herein can be implemented as discrete hardware components or integrated in the functionality of hardware components such as ASICS, FPGAs, DSPs or similar devices. In addition, processing module/unit/logic 528 can be implemented as firmware or functional circuitry within hardware devices. Further, processing module/unit/logic 528 can be implemented in any combination hardware devices and software components.


Note that while system 500 is illustrated with various components of a data processing system, it is not intended to represent any particular architecture or manner of interconnecting the components; as such details are not germane to embodiments disclosed herein. It will also be appreciated that network computers, handheld computers, mobile phones, servers, and/or other data processing systems which have fewer components or perhaps more components may also be used with embodiments disclosed herein.


Some portions of the preceding detailed descriptions have been presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the ways used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. The operations are those requiring physical manipulations of physical quantities.


It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the above discussion, it is appreciated that throughout the description, discussions utilizing terms such as those set forth in the claims below, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.


Embodiments disclosed herein also relate to an apparatus for performing the operations herein. Such a computer program is stored in a non-transitory computer readable medium. A non-transitory machine-readable medium includes any mechanism for storing information in a form readable by a machine (e.g., a computer). For example, a machine-readable (e.g., computer-readable) medium includes a machine (e.g., a computer) readable storage medium (e.g., read only memory (“ROM”), random access memory (“RAM”), magnetic disk storage media, optical storage media, flash memory devices).


The processes or methods depicted in the preceding figures may be performed by processing logic that comprises hardware (e.g. circuitry, dedicated logic, etc.), software (e.g., embodied on a non-transitory computer readable medium), or a combination of both. Although the processes or methods are described above in terms of some sequential operations, it should be appreciated that some of the operations described may be performed in a different order. Moreover, some operations may be performed in parallel rather than sequentially.


Embodiments disclosed herein are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of embodiments disclosed herein.


In the foregoing specification, embodiments have been described with reference to specific exemplary embodiments thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope of the embodiments disclosed herein as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.

Claims
  • 1. A method for managing operation of a biosystem on a chip (BoC) deployment, the method comprising: obtaining an architecture of a BoC of the BoC deployment;predicting a fault for a future operation of the BoC based on the architecture;obtaining a risk rating for a portion of control data usable to manage the predicted fault, the risk rating being based on a level of delay for hosting the portion of the control data remotely to the BoC deployment;making a determination regarding whether the risk rating exceeds a threshold;in a first instance of the determination where the risk rating exceeds the threshold: deploying a copy of the control data to local computing resources of the BoC deployment to obtain a deployed portion of the control data, andoperating the BoC deployment using the deployed copy of the control data to manage any instances of the predicted fault that occur during the operation; andin a second instance of the determination where the risk rating does not exceed the threshold: operating the BoC deployment using the control data to manage the any instances of the predicted fault that occur during the operation, the control data being hosted by computing resources that are remote to the BoC deployment.
  • 2. The method of claim 1, wherein operating the BoC deployment using the deployed copy of the control data comprises: executing a control algorithm specified by the deployed portion of the control data using the local computing resources to obtain an action; andimplementing the action using a robotic controller of the BoC deployment.
  • 3. The method of claim 2, wherein implementing the action modifies the operation of the BoC deployment to reduce a likelihood of a predicted fault of the any instances of the predicted fault from occurring.
  • 4. The method of claim 3, wherein executing the control algorithm comprises: storing a copy of sensor data from a sensor of the BoC deployment that monitors an environmental condition within a portion of the BoC; andusing the copy of the sensor data to identify the action.
  • 5. The method of claim 2, wherein operating the BoC deployment using the deployed copy of the control data further comprises: executing a second control algorithm specified by a second portion of the control data using remote computing resources to obtain a second action; andimplementing the second action using the BoC deployment.
  • 6. The method of claim 5, wherein the BoC deployment and the remote computing resources are operably connected by a communication system that imparts a first level of latency for operation data from the BoC deployment to become available to the remote computing resources, the local computing resources are operably connected to other components of the BoC deployment via a low latency communication medium that imparts a second level of latency for operation data from the BoC deployment to become available to the local computing resources, and first level of latency reducing a capacity of the control data to manage the any instances of the predicted fault that occur during the operation of the BoC.
  • 7. The method of claim 1, wherein the predicted fault for the future operation of the BoC is further based on operation data for a completed operation of the BoC deployment.
  • 8. The method of claim 1, wherein the risk rating is based on a level of latency for hosting the portion of control data remotely during the operation of the BoC deployment.
  • 9. A non-transitory machine-readable medium having instructions stored therein, which when executed by a processor, cause the processor to perform operations for managing operation of a biosystem on a chip (BoC) deployment, the operations comprising: obtaining an architecture of a BoC of the BoC deployment;predicting a fault for a future operation of the BoC based on the architecture;obtaining a risk rating for a portion of control data usable to manage the predicted fault, the risk rating being based on a level of delay for hosting the portion of the control data remotely to the BoC deployment;making a determination regarding whether the risk rating exceeds a threshold;in a first instance of the determination where the risk rating exceeds the threshold: deploying a copy of the control data to local computing resources of the BoC deployment to obtain a deployed portion of the control data, andoperating the BoC deployment using the deployed copy of the control data to manage any instances of the predicted fault that occur during the operation; andin a second instance of the determination where the risk rating does not exceed the threshold: operating the BoC deployment using the control data to manage the any instances of the predicted fault that occur during the operation, the control data being hosted by computing resources that are remote to the BoC deployment.
  • 10. The non-transitory machine-readable medium of claim 9, wherein operating the BoC deployment using the deployed copy of the control data comprises: executing a control algorithm specified by the deployed portion of the control data using the local computing resources to obtain an action; andimplementing the action using a robotic controller of the BoC deployment.
  • 11. The non-transitory machine-readable medium of claim 10, wherein implementing the action modifies the operation of the BoC deployment to reduce a likelihood of a predicted fault of the any instances of the predicted fault from occurring.
  • 12. The non-transitory machine-readable medium of claim 11, wherein executing the control algorithm comprises: storing a copy of sensor data from a sensor of the BoC deployment that monitors an environmental condition within a portion of the BoC; andusing the copy of the sensor data to identify the action.
  • 13. The non-transitory machine-readable medium of claim 10, wherein operating the BoC deployment using the deployed copy of the control data further comprises: executing a second control algorithm specified by a second portion of the control data using remote computing resources to obtain a second action; andimplementing the second action using the BoC deployment.
  • 14. The non-transitory machine-readable medium of claim 13, wherein the BoC deployment and the remote computing resources are operably connected by a communication system that imparts a first level of latency for operation data from the BoC deployment to become available to the remote computing resources, the local computing resources are operably connected to other components of the BoC deployment via a low latency communication medium that imparts a second level of latency for operation data from the BoC deployment to become available to the local computing resources, and first level of latency reducing a capacity of the control data to manage the any instances of the predicted fault that occur during the operation of the BoC.
  • 15. A data processing system, comprising: a processor; anda memory coupled to the processor to store instructions, which when executed by the processor, cause the processor to perform operations for managing operation of a biosystem on a chip (BoC) deployment, the operations comprising: obtaining an architecture of a BoC of the BoC deployment;predicting a fault for a future operation of the BoC based on the architecture;obtaining a risk rating for a portion of control data usable to manage the predicted fault, the risk rating being based on a level of delay for hosting the portion of the control data remotely to the BoC deployment;making a determination regarding whether the risk rating exceeds a threshold;in a first instance of the determination where the risk rating exceeds the threshold: deploying a copy of the control data to local computing resources of the BoC deployment to obtain a deployed portion of the control data, andoperating the BoC deployment using the deployed copy of the control data to manage any instances of the predicted fault that occur during the operation; andin a second instance of the determination where the risk rating does not exceed the threshold: operating the BoC deployment using the control data to manage the any instances of the predicted fault that occur during the operation, the control data being hosted by computing resources that are remote to the BoC deployment.
  • 16. The data processing system of claim 15, wherein operating the BoC deployment using the deployed copy of the control data comprises: executing a control algorithm specified by the deployed portion of the control data using the local computing resources to obtain an action; andimplementing the action using a robotic controller of the BoC deployment.
  • 17. The data processing system of claim 16, wherein implementing the action modifies the operation of the BoC deployment to reduce a likelihood of a predicted fault of the any instances of the predicted fault from occurring.
  • 18. The data processing system of claim 17, wherein executing the control algorithm comprises: storing a copy of sensor data from a sensor of the BoC deployment that monitors an environmental condition within a portion of the BoC; andusing the copy of the sensor data to identify the action.
  • 19. The data processing system of claim 16, wherein operating the BoC deployment using the deployed copy of the control data further comprises: executing a second control algorithm specified by a second portion of the control data using the remote computing resources to obtain a second action; andimplementing the second action using the BoC deployment.
  • 20. The data processing system of claim 15, wherein the BoC deployment and the remote computing resources are operably connected by a communication system that imparts a first level of latency for operation data from the BoC deployment to become available to the remote computing resources, the local computing resources are operably connected to other components of the BoC deployment via a low latency communication medium that imparts a second level of latency for operation data from the BoC deployment to become available to the local computing resources, and first level of latency reducing a capacity of the control data to manage the any instances of the predicted fault that occur during the operation of the BoC.