Buildings are an integral part of our everyday lives. The process of planning, designing and constructing these buildings has evolved over several thousands of years. Today, especially for modern facilities that are places from which to deliver complex services (like healthcare facilities), the steps followed to physically realize such buildings are very complicated and require a high degree of skilled labor that spans several different disciplines.
This complexity poses a huge challenge in terms of time, money, and other resources expended in order to build a viable facility that can be used to deliver the intended services in an efficient and profitable way. Several industries and services have met similar complexity challenges by changing their work flow and adapting it to better exploit fast growing and inexpensive computational resources. This has resulted in an increased productivity in those industries.
However, the emergence of technological and computational capabilities has found limited adoption in the well-established processes of building design and construction. As a result, there has been little gain in overall productivity, which is desperately needed today to meet the growing demand in complexity. For example, it has been found that while all other non-farming industries have doubled their productivity from 1964 to 2004, the building industry brethren have actually fallen behind.
While a plethora of reasons exist as to why construction productivity has not kept up with other areas, it is possible that conventional methods used in the building design and construction industry are not amenable to applying technology in general and computational technology in particular. Almost all other industries have gained in productivity due to the smart adaptation of computing technology, but, for reasons not immediately apparent, the construction industry has not seen any similar gains.
Buildings come in all different shapes and sizes and the complexity of buildings varies depending on their use. For example, from many different perspectives, a healthcare building such as a hospital is much more complex than an empty warehouse building. The complexity of a building becomes apparent when one tries to mathematically describe, model, simulate, optimize, and verify a building design such as the design of a hospital. In particular, the mathematical description, modeling, simulation, optimization, and verification are each a complex combination of three-dimensional (3D) space and temporal operations. Characteristics of the 3D space include, for example, specifics of the building shell and core, the size and layout and function of the rooms, and routing of the building infrastructure. Characteristics of the temporal operations include, for example, the services provided within the building, load on the building (e.g., volume of patients), and dynamic environmental conditions (e.g., internal/external temperature, light, energy cost, etc).
Additionally, a fundamental challenge in complex building design involves accounting for functional and operation requirements. That is, the task of designing a building is often also a task of identifying how the building will be used.
In a healthcare facility, there are many complex functions being performed simultaneously. For example, such functions include administration, admitting, diagnostic, imaging, acute care, observation, rehabilitation, surgery, laboratory, emergency, pharmacy, neonatal, delivery, information technology, sanitation, facilities, cafeteria, kitchen, etc. Each of the functions involves temporal operations that are performed within a particular physical three-dimensional space (spatial pattern) within the healthcare facility. In conventional building design processes, the three-dimensional spaces that are used to support the functions are selected by humans in a manual process from design templates that have been developed over time and have been effective in supporting a particular function.
Because healthcare facilities can provide many complex functions, the task of determining a building design that can facilitate a multitude of complex functions can quickly become a very complex problem. Traditional manual building design techniques typically evaluate only a very small number of the total possible designs.
In an embodiment, a discrete event simulator is disclosed. In an embodiment, the discrete event simulator includes a model having at least one activity instance, wherein the at least one activity instance has an activity type that defines a participating entity type list and a duration of time over which the activity instance will be performed, at least one activity queue, wherein the at least one activity queue is configured to hold the at least one activity instance in an order, and at least one entity, wherein the at least one entity is associated with at least one behavior and is configured to join at least one activity instance, and a configuration, wherein the configuration further defines the at least one entity, wherein the at least one entity is configured to perform the at least one associated behavior when, upon joining the at least one activity instance, an entity for each type in the participating entity type list of the activity instance has joined the activity instance.
In another embodiment, the discrete event simulator is configured to execute the model using the configuration.
In another embodiment, the discrete event simulator is further configured to synchronize the at least one behavior associated with the at least one entity with the behaviors of other entities that have joined the same activity instance without the use of a scheduler.
In another embodiment, the configuration further defines the at least one entity by overriding the at least one behavior associated with the at least one entity.
In another embodiment, the at least one activity instance is configured such that the at least one entity can join the activity instance by adding the at least one entity to the participating entity type list of the activity instance.
In another embodiment, the at least one entity is configured to simultaneously join multiple activity instances.
In another embodiment, the discrete event simulator is further configured to create a new activity instance of an activity type when the activity queue corresponding to the activity type of the activity instance that the at least one entity is configured to join contains no activity instances.
In an embodiment, a method for simulating discrete events is disclosed. In the embodiment, the method involves creating at least one activity instance, wherein the at least one activity instance has an activity type that defines a participating entity type list and a duration of time over which the activity instance will be performed, generating at least one entity, wherein the at least one entity is associated with at least one behavior and is configured to join at least one activity instance, and executing a model including the at least one activity instance and the at least one entity using a configuration, wherein the model executes by generating at least one activity queue, wherein the at least one activity queue is configured to hold the at least one activity instance, adding the at least one activity instance to the activity queue, and upon joining of an entity of each type in the participating entity type list of the at least one activity instance, triggering the performance of the at least one behavior associated with each entity that has joined the at least one activity instance.
In another embodiment, triggering the performance of the at least one behavior associated with each entity that has joined the at least one activity instance comprises synchronously triggering the performance of the at least one behavior associated with each entity that has joined the at least one activity instance without the use of a scheduler.
In another embodiment, executing the model using the configuration comprises overriding the at least one behavior associated with the at least one entity.
In another embodiment, the at least one entity can simultaneously join multiple activity instances.
In another embodiment, the at least one activity instance is created when the at least one entity attempts to join an activity instance and the activity queue is empty.
In another embodiment, if a plurality of activity instances are generated, then the activity queue is configured to hold the activity instances in an order.
Other aspects and advantages of embodiments of the present invention will become apparent from the following detailed description taken in conjunction with the accompanying drawings.
Throughout the description, similar reference numbers may be used to identify similar elements.
It will be readily understood that the components of the embodiments as generally described herein and illustrated in the appended figures could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of various embodiments, as represented in the figures, is not intended to limit the scope of the present disclosure, but is merely representative of various embodiments. While the various aspects of the embodiments are presented in drawings, the drawings are not necessarily drawn to scale unless specifically indicated.
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by this detailed description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Reference throughout this specification to features, advantages, or similar language does not imply that all of the features and advantages that may be realized with the present invention should be or are in any single embodiment of the invention. Rather, language referring to the features and advantages is understood to mean that a specific feature, advantage, or characteristic described in connection with an embodiment is included in at least one embodiment of the present invention. Thus, discussions of the features and advantages, and similar language, throughout this specification may, but do not necessarily, refer to the same embodiment.
Furthermore, the described features, advantages, and characteristics of the invention may be combined in any suitable manner in one or more embodiments. One skilled in the relevant art will recognize, in light of the description herein, that the invention can be practiced without one or more of the specific features or advantages of a particular embodiment. In other instances, additional features and advantages may be recognized in certain embodiments that may not be present in all embodiments of the invention.
Reference throughout this specification to “one embodiment,” “an embodiment,” or similar language means that a particular feature, structure, or characteristic described in connection with the indicated embodiment is included in at least one embodiment of the present invention. Thus, the phrases “in one embodiment,” “in an embodiment,” and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment.
Reference throughout this specification to particular types of buildings are intended as exemplary language. Thus, references to specific components or elements of a building type may also refer more generally to a similar component or element of another building type.
As described with reference to
Alternatively, a computer-implemented system can be more suited to managing large amounts of data. Thus, customer needs would less likely to be neglected or forgotten during the process of developing a building plan layout. However, the computer-implemented system would be unable to utilize the subjective knowledge of an architect or a building planner when making decisions. Therefore, the computer-implemented system may make use of a different approach to developing a building plan layout.
For example,
“Functions: x-ray, surgery, recovery, emergency, oncology, laboratory, . . . .
Patient Load: 50-150 patients
Building Cost Maximum: 300,000,000
Operating Budget: 95,000,000
Future growth: true
Maximum Height: 5 stories
Optimization Goal: Satisfy Quality of Service at Lowest Cost”
At block 306, a simulator simulates operation of the building and a space program is generated based on performance results.
At block 308, a space program with the most optimal results, as defined by the building owner's preferences, is output to, for example, a user or to a building realization platform (“BRP”) as described in U.S. Pat. No. 9,607,110, entitled “SYSTEM AND METHOD FOR REALIZING A BUILDING SYSTEM.”
At block 310, a department placer tool would place departments within a building plan layout. In an embodiment, a department placer tool can be implemented in software and uses adjacency tables to evaluate a cost algorithm to place departments throughout a building shell. The department placer tool is described in further detail in U.S. Pat. No. 9,721,046, entitled “SYSTEM AND METHOD FOR REALIZING A BUILDING SYSTEM THAT INVOLVES COMPUTER BASED MATCHING OF FORM TO FUNCTION.”
At block 312, a room placer tool would place rooms or spaces within the departments. In an embodiment, the room placer tool can be implemented in software using a constraint solver to place rooms within a building plan layout. The room placer tool is described in further detail in U.S. patent application Ser. No. 15/395,162, METHOD AND SYSTEM FOR AUTOMATICALLY GENERATING AN INTERIOR TESTFIT FOR A BUILDING.
At block 314, a content placer tool would place content within the rooms or spaces. In an embodiment, the content placer tool can be implemented in software using a constraint solver to place objects or contents within rooms throughout a building plan layout. The content placer tool is described in further detail in U.S. Pat. Pub. No. 2017/0061039, entitled COMPUTER-IMPLEMENTED SYSTEM AND METHOD FOR PLACING OBJECTS IN A ROOM.
In an embodiment, the departments, room or spaces, and content would be dictated by the space program. Furthermore, the department placer tool, room placer tool, and content placer tool may each be configured to select an optimal placement as defined according to the building owner's preferences. Finally, at block 316, a building plan layout can be output. In an embodiment, the building plan layout can be output as computer code, as a text file, or as a graphical file. Accordingly, because each step may be configured based on the preferences of the building owner, the output building plan layout may also be the optimal building plan layout given the building owner's needs.
In accordance with an embodiment of the invention, the approach described with reference to
In an embodiment, the input collector is configured to receive information such as a set of resource rules that define resources to be placed within a building plan, a set of behavioral rules, and other attributes in order to generate a model (e.g., operational schedules, resource distribution, etc.). In an embodiment, the resource rules, behavioral rules, and a default set of other attributes can be received as a base library file.
In an embodiment, resource rules can be created by using a human-readable data serialization language, such as .yaml, to define resource characteristics regarding properties of individual resources. For example, resource rules can define the dimensions of a particular resource, the cost of a particular resource, the number of possible concurrent users of the resource, or the number of instances of a given resource to be included in a model. Resource rules can also define inter-resource relations and can be used to filter simulation results as described below.
Behavioral rules can also be created by using a human-readable data serialization language to describe states of a state-machine for a given resource as well as for other entities in the model. In an embodiment, a state-machine is program or a class defining a set number of conditions or states and transitions between those conditions or states. State-machines can be implemented using, for example, one or more arrays.
In an embodiment, the modeler 404 is configured to consume the resource rules, the behavioral rules (e.g., yaml files), and other attributes to create an executable model. In an embodiment, the other attributes can also be created by using a human-readable data serialization language to define an activity. For example, an x-ray procedure activity may be defined as:
wherein the entities field indicates the entities involved in the activity, the durationDistribution field indicates a rate at which the activity is performed in a model, the waitAreas field indicates what wait behavior is performed by which entities, and the actionOnStart field indicates procedural code to be executed upon the start of the activity.
In an embodiment, the modeler 404 can be configured to generate Java class files aggregated as a Java Archive (JAR) package. The modeler can be implemented similar to a compiler used with programming languages. The resource rules, behavioral rules, and other attributes can be fed into a parser and translated into Java class files by a model generator using various libraries to produce the executable model. In an embodiment, the various libraries may include a discrete event simulations library (e.g., DESMO-J), a domain simulation library, or a class library.
In an embodiment, once the modeler 404 has generated the model, the model can be stored within the model database. In an embodiment, a single mode is created and stored at a time, but, in other embodiments, additional models can be generated and stored concurrently. Additional models can be generated by changing the resource rules, behavioral rules, and/or other attributes before re-generating the model.
In an embodiment, the simulator can be configured to select a model from the model database, to receive a configuration from the configuration database, and to execute the model using the received configuration.
In an embodiment, a configuration can include arguments that can be passed to a model when the model is executed by the simulator. A configuration can include a care plan (e.g., hospital patient demand or customer demand), permutations (e.g., how many instances of each resource to include), or additional override information that can override Java classes in the model. For example, if a base library file is received as input, then a configuration can include additional override information that defines additional resources not included in the base library file.
In regards to a care plan, the configuration can include a care plan that defines a number and type of patients to be serviced during the simulation. In an embodiment, the patients can be generated by generators using healthcare data drawn from reports on the health needs of the community in which the hospital is to be built.
In regards to permutations, the resource distribution received by the input collector can be overridden by a configuration. In an embodiment, permutations are generated by a permuter (not shown) configured to generate permutations given a set of resources and associated resource level ranges to be included in the simulation. The set of resources can be determined based on customer needs.
In an embodiment, the simulator 410 can be configured to execute a model and to reference attributes of the configuration in order to simulate the interaction of entities within the model given a set of behavioral rules. The simulator can be a software application executing in a computer system that utilizes computer system resources. In an embodiment, the interaction of entities given a set of behavioral rules is simulated by synchronously transitioning the entities through their associated behaviors as described below with reference to
In an embodiment, the simulator 410 can be configured to generate performance metrics for the set of resources and to store the generated performance metrics in the metrics database 412. In an embodiment, each entry in the metrics database includes the generated performance metrics and the set of resources used in the simulation to generate those performance metrics. Performance metrics may include, for example, the rate at which behaviors can be performed using the resources in the model (e.g., throughput), the amount of time spent active versus waiting for each resource, or the variation in the amount of time similar profiles complete similar behaviors.
Once a number of simulations have been run and a number of entries have been stored in the metrics database 412, the metrics database can be accessed by the building plan layout generator 450 to generate a building plan layout. In an embodiment, a building plan layout generator includes a metric selector, a space program generator, a department placer, a room placer, and a content placer.
In an embodiment, a metric selector 452 is configured to filter entries in the metrics database 412 using resource rules. For example, if a resource rule requires that all beds be placed in pairs, then the metric selector can filter all entries from the metrics database where the set of resources includes an odd number of beds (e.g., an entry which would violate the resource rule requiring all beds to be placed in pairs).
Once the metric selector 452 has filtered the entries in the metrics database 412 using the resource rules, a single entry can be selected and the set of resources associated with an entry can be passed to the space program generator 456.
In an embodiment, the space program generator 456 can be configured to receive the set of resources and to generate a space program. In an embodiment, a space program is a list that indicates department blocks to include in a building plan layout. Additionally, the space program can include the number of rooms to be included in each department block, the type of each room included, and dimensions (e.g., fixed or range) for each room included. For example, if a building plan layout for a hospital is being generated, then the space program may contain the number of rooms allocated to beds, the number of rooms allocated to surgery, the number of rooms allocated for patient waiting, etc.
In an embodiment, the department placer 458 receives the generated space program and places departments in a building plan layout to generate a department plan. In an embodiment, a department placer tool can be implemented in software and uses adjacency tables to evaluate a cost algorithm to place departments throughout a building shell. The department placer tool can also be configured to use travel frequencies in the selected metrics to determine costs for department placements. For example, if the model generates metrics that indicate a high number of travels between two departments, the department placer tool can use those metrics to determine that the two departments should be placed in close proximity.
In an embodiment, the room placer 460 receives the department plan and the space program and places the rooms in the space program within the various departments of the department plan to generate a room plan. In an embodiment, the room placer tool can be implemented in software using a constraint solver to place rooms within a building plan layout.
In an embodiment, the content placer 462 places resources from the simulation records in the rooms of the room plan to generate a building plan layout. In an embodiment, a building plan layout can be repeated for each floor of a building or two or more building plan layouts can be generated and stacked until the stacked building plan layouts satisfy the received set of customer needs.
At block 504, the software would collect various inputs. For example, inputs may include resource rules, behavioral rules, or other attributes used to generate a model (e.g., operational schedules, resource distribution, etc.) as described above.
At block 506, resources that can be included in the building plan layout are defined from the resource rules. For example, an x-ray machine resource can be defined using a resource rule for an x-ray machine.
At block 508, behaviors, as defined by behavioral rules, are assigned to the resources defined at block 506. In an embodiment, behaviors are assigned based on the type of the resource. For example, a behavior for a patient receiving an x-ray can be assigned to an x-ray type patient. Accordingly, during simulation, the assigned behavior can be performed, as described with reference to
In an embodiment, behaviors can be state-machines implemented in software with actions, transitions, and transition conditions for performing a specific function. For example,
In an embodiment, resource behaviors can also be implemented as state-machines with actions, transitions, and transition conditions for performing a specific function, but with more limited states. For example,
In other embodiments, additional states can be added to the state-machines to enable schedules (e.g. an “offline” state).
Returning to
At block 512, before the simulation is run, the simulator receives a configuration, as described above. Then, at block 514, the simulation can be run. In an embodiment, a simulation is run by executing a model (e.g., a model selected from the model database), which takes the configuration as input during execution (e.g., as an argument passed to a model when executed). At block 516, the metric results of the simulation can be output by the simulator. The metric results are a set of performance metrics can be stored as an entry in a metrics database. In an embodiment, the entry also includes the model and resources used by the simulator to generate the set of performance metrics.
At decision point 518, if additional permutations (e.g., variations on the resources used by the simulator) remain, then the process can return to block 512. If additional models remain in the model database, then the process can also return to block 512, but a different model can be selected.
In an embodiment, only a subset of all total possible permutations and models are simulated. The subset of possible permutations and models can be limited to a set of simulations that are most likely to satisfy client demand. For example, a permutation with only one bed in a hospital will likely not satisfy client demand and so the permutation need not be simulated.
At block 520, an entry is selected from the metrics database. In an embodiment, the entries stored in the metrics database are queried based on an attribute corresponding to a user-defined performance level. For example, a user can specify a low wait-time performance level and so the metrics database will be queried for the entry with the lowest wait-time metric.
At block 522, a space program is generated based on the set of resources associated with the selected entry. As described with reference to
At block 524, departments can be placed within a building floor plan, and at block 526, the rooms in the generated space program can be placed within the departments. In an embodiment, a department is a logical grouping of rooms or areas in which an associated function is performed. For example, in a hospital, an x-ray department can be defined as a group of rooms including waiting rooms, administrative areas, changing rooms, and procedure rooms. In a hotel, a conference department can be defined as a group of rooms including display halls, meeting rooms, and catering staging areas. In an embodiment, the rooms can be placed within departments using a constraint solver.
At block 528, content can be placed within the rooms placed at block 526. In an embodiment, the content is selected from the set of resources. For example, the set of resources for a hospital may include beds, sinks, mirrors, chairs, etc. These resources can be placed within rooms as content by a content placer. In an embodiment, the content placer can be implemented using a constraint solver.
At block 530, it is determined if placement at blocks 522, 524, 526, and 528 was possible. If not, the process returns to block 520 and a different entry is selected and the process repeats. In an embodiment, a check can also be performed after each block and if placement fails at any block, as determined by each placer, then the process can return to block 520.
If placement was possible at each block, then, at block 532, the building plan layout is output to a user. In an alternative embodiment, the building plan layout can be output to another computer-implemented system in the building realization platform for further operations.
Thus, by incorporating rules into a computer-implemented system, a building plan layout can be automatically generated. Additionally, by automating the generation of a building plan layout, customer needs will likely be more completely satisfied. Furthermore, if a customer decides to make changes to the needs of the building or wishes to change the optimization goal of the building (e.g., minimize staff instead of minimize cost), a new building plan layout can be automatically generated that satisfies the changed needs or optimization goal without great effort by an architect or building planner. In further embodiment, the performance metrics can be further utilized in conjunction with the building plan layout to optimize the performance of operations or processes within the building (e.g., the protocols or steps for providing services, or the routes patients should take between departments.)
As introduced with respect to block 514 in
Typically, a simulator can be used as an alternative to mathematical modeling of a system when a finite number of states is too great to be practically calculated for the system. A finite number of states is too great to be practically calculated when the system is defined by a large set of parameters and initial conditions that cause the behavior of the system to change over the simulation. For example, a simulator can be used to determine metrics related to the interaction of stimuli with resources. For example, if a hospital is being modeled, then a simulator can be used to determine information such as cost, throughput, and usage given resources to be included in the hospital, hospital staff, and patients to be serviced by the hospital.
An approach used in computer simulation is to define each resource and stimulus as a state-machine. For example, as described above with reference to
An integral part of computer simulation is the internal coordination of the various defined state-machines. For example, in order for the simulation to be accurate, the state-machine of the patient receiving an x-ray can only transition through all of its states in coordination with the x-ray machine's transitions through its states. That is, the patient state-machine will enter the “x-ray” state, but will remain in the “x-ray” state until the x-ray machine enters the “available” state and the x-ray activity can start.
In accordance with an embodiment of the invention, the various defined state-machines are coordinated by a self-coordinating discrete event simulator. In an embodiment, the discrete event simulator includes a model having at least one activity instance, wherein the at least one activity has an activity type that defines a participating entity type list and a duration of time over which the activity instance will be performed, at least one activity queue, wherein the at least one activity queue is configured to hold the at least one activity instance in an order, and at least one entity, wherein the at least one entity is associated with at least one behavior and is configured to join at least one activity instance, and a configuration, wherein the configuration further defines the at least one entity, wherein the at least one entity is configured to perform the at least one associated behavior when, upon joining the at least one activity instance, an entity for each type in the participating entity type list of the activity instance has joined the activity instance. That is, entities can be synchronized by synchronously triggering the performance of entities' respective behaviors once all entities needed, as defined by an activity type, have joined an instance of the activity.
Thus, the coordination of the various defined state-machines can be performed without a need for an external control (e.g., from a centralized resource scheduler or a similar central controller within a simulator) and, thus, computational overhead typically allocated to external control can be reduced.
Resource entities include, for example, a hospital bed, an elevator, or an x-ray machine. In an embodiment, resource entities are predetermined. Behaviors for resource entities alternate between available and in-use, as described in respect to
Custom entities include, for example, patients, shoppers, guests, or other types of customers. In an embodiment, custom entities can be predefined or automatically generated to increase the randomness of the distribution, which results in a more accurate simulation. A custom entity can have more than one behavior and each behavior can be specified on a per-department basis such as an x-ray department, as described above with respect to
In an embodiment, schedules (not shown) can also be defined for entities. Thus, an entity will not join an activity outside of its hours of operation. For example, an x-ray machine can be defined with a schedule such that it will not join an x-ray activity outside of normal business hours (e.g., at midnight) even if an x-ray activity is available to join. In an embodiment, multiple schedules can be defined for an entity such as a weekday schedule and a weekend schedule or a work schedule and an appointment schedule, wherein the appointment schedule is a subset of the work schedule that indicates time slots at which appointments can be made (e.g., on the hour versus a random time like 11:43 am).
In an embodiment, activity instances are the primary coordination mechanism for the simulation and represent tasks in which an entity may participate. In an embodiment, an activity type can be defined for each activity to be performed in a model. Thus, for each activity there is a single activity type, but a model can include multiple instances of the activity.
An activity type can be defined by a participating entity type list and by a duration of time over which the activity will be performed. In an embodiment, the duration is defined as some finite period of time or, if the activity is on-going, as an indefinite period of time.
A model can be defined with an activity queue for each type of activity to be included in the model. For example, a model can have an activity queue for an x-ray activity and for a patient check-in activity. In an embodiment, instances of an activity type are queued in their corresponding queue (e.g., an instance of an x-ray activity type is queued in the x-ray activity queue, while an instance of a patient check-in activity type is queued in the patient check-in activity queue).
When an entity desires to or is able to participate in a task associated with an activity instance, the entity can “join” the associated activity instance. In an embodiment, an entity “joins” an activity instance in one of two ways. If there are no instances of the activity instance an entity wants to join in the corresponding activity queue or no instance of the activity instance an entity wants to join missing a participant of the entity's type, then a new instance of the activity type is created and added to the corresponding activity queue. The entity is then added to the participating entity list of the newly-created instance of the activity type. For example, if a queue for an x-ray activity instance has no x-ray activity instances or all x-ray activity instances already have a patient entity in the participating entity type list, then a new instance of an x-ray activity type is created and the patient is added to the participating entity type list.
Alternatively, if the queue corresponding to an activity the entity wants to join includes an instance and the instance in the queue still needs an entity of the entity's type, then the entity is added to the instance's participating entity type list.
In an embodiment, entities join activity instances in accordance with the following priorities: an entity will first filter for the oldest instance in an activity queue that needs only the entity in order for the activity instance to complete its entity type list, an entity will next filter for the oldest instance in the activity queue that still needs an entity of the entity's type, and finally, if an activity queue is empty and a new activity instance is created, as described above, an entity will join the newly created activity instance.
When an entity of each type in an activity instance's participating entity type list has joined the activity instance (e.g., the patient entity, the x-ray machine entity, and the x-ray technician entity), then the activity instance can start (e.g., the entities can being performing associated behaviors). As a result, the behaviors for the patient entity, x-ray machine entity, and x-ray technician entity are synchronized by the activity without the need for an external event scheduler or other external control mechanisms.
Meanwhile, at blocks 924 and 944, the x-ray machine entity and the x-ray technician entity join the x-ray activity as soon as they become available and, at decision points 926 and 946, wait until the patient entity joins the x-ray activity. As described above, if another x-ray activity becomes ready (e.g., all entities have joined the x-ray activity), then the x-ray machine entity and the x-ray technician entity may leave the x-ray activity.
Once the patient entity, the x-ray machine entity, and the x-ray technician entity have joined the x-ray activity, the x-ray activity can be performed. At the completion of the x-ray activity, each entity leaves the activity and enters the next state of their respective behaviors. For example, at block 914, the patient entity would enter x-ray consult after disgowning, while, at block 932, the x-ray machine entity would return to the available state and, at block 952, the x-ray technician entity would also return to the available state.
Thus, the activity synchronizes the behaviors of the patient entity, the x-ray machine entity, and the x-ray technician entity without external control by beginning performance of an activity only once all entities in an activity have joined, which affects entity behaviors accordingly.
At block 1006, the model is executed. When the model is executed an entity joins an activity instance if the entity desires or is available to perform a task associated with the activity. If all entities that may join the activity have joined the activity, then the activity is performed. In an embodiment, upon completing performance of the activity, each entity that joined the activity leaves the activity and continues to transition through their respective behavior, as described above with reference to the patient entity, the x-ray machine entity, and the x-ray technician entity of
Throughout the execution of the model, new activity instances are created and new entities are generated. The generated entities can join the activity instances and the activities can be performed. Thus, by joining an activity instance and waiting until all entities have joined the activity instance, behaviors of entities can be synchronized independent from external control.
In an embodiment, the above-described functionality is performed by a computer or computers, which executes computer readable instructions.
Although the operations of the method(s) herein are shown and described in a particular order, the order of the operations of each method may be altered so that certain operations may be performed in an inverse order or so that certain operations may be performed, at least in part, concurrently with other operations. In another embodiment, instructions or sub-operations of distinct operations may be implemented in an intermittent and/or alternating manner.
It should also be noted that at least some of the operations for the methods may be implemented using software instructions stored on a computer useable storage medium for execution by a computer. As an example, an embodiment of a computer program product includes a computer useable storage medium to store a computer readable program that, when executed on a computer, causes the computer to perform operations, as described herein.
Furthermore, embodiments of at least portions of the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The computer-useable or computer-readable medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device), or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disc, and an optical disc. Current examples of optical discs include a compact disc with read only memory (CD-ROM), a compact disc with read/write (CD-R/W), a digital video disc (DVD), and a Blu-ray disc.
In the above description, specific details of various embodiments are provided. However, some embodiments may be practiced with less than all of these specific details. In other instances, certain methods, procedures, components, structures, and/or functions are described in no more detail than to enable the various embodiments of the invention, for the sake of brevity and clarity.
Although specific embodiments of the invention have been described and illustrated, the invention is not to be limited to the specific forms or arrangements of parts so described and illustrated. The scope of the invention is to be defined by the claims appended hereto and their equivalents.