The disclosure relates generally to the field of alarm systems, and more particularly to a system and method for providing a comprehensive user interface for monitoring and controlling a plurality of alarm systems.
Alarm systems, such as fire alarm and security systems, typically include one or more centralized alarm panels that receive information from various sensors that are distributed throughout a structure or area. For example, referring to
The exemplary alarm system 10 may also include a workstation 18, such as a personal computer (PC) or server, which is operatively connected to the alarm panel 14 of the alarm system 10. If the alarm system 10 includes a plurality of alarm panels 14, the panels 14 may be networked, such as in a ring configuration, and the workstation 18 may be connected to the network as a network node as shown in
A first shortcoming associated with many existing alarm systems of the type described above is that UI software applications that were implemented in such systems in the past are only capable of accommodating a limited total number of points (i.e. initiating devices and notification appliances). For example, UI applications in many existing alarm systems are configured to provide an interface for a maximum of 50,000 points. Until recently, such capacity was thought to be sufficient for most applications. However, some large-scale users of alarm systems, such as hotel chains and universities, have begun to expand their alarm systems beyond, and in some cases well beyond, the point capacities of their UI applications. One solution for handling such expansion is to modify the UI software in existing alarm systems to provide greater point capacities, but this is generally recognized as being an impractically expensive and burdensome endeavor. Instead, most large-scale users have simply resorted to installing additional workstations, each with its own, independent UI software application having an independent point capacity. For example, in the exemplary system 20 shown in
A second shortcoming associated with many existing alarm systems is commonly realized by large-scale users having multiple, remotely-located sites that require monitoring. Particularly, such users must generally employ a separate workstation having its own, independent UI at each remote site. This requires the user to employ personnel at each site to monitor the various workstations, which can be very expensive and logistically burdensome. Alternatively, referring to the exemplary arrangement shown in
In view of the forgoing, a system and method are disclosed for allowing users of alarm systems to interface with a virtually unlimited number of alarm system points from a single UI application on a single workstation without rewriting UI software to accommodate such capacity. The system and method also may enable users to interface with alarm system points installed at a plurality of remotely-located sites from a single UI application on a single workstation.
In accordance with the present disclosure, a system and method for providing a comprehensive user interface for alarm systems are disclosed.
An exemplary embodiment of an interface system in accordance with the present disclosure can include two or more alarm system workstations, each having a user interface application installed thereon. One or more alarm panels may be connected to each of the alarm system workstations, and one or more points may be connected to each of the alarm panels. The interface system may further include a broker workstation connected to the two or more alarm system workstations, and one or more client workstations connected to the broker workstation. The interface system may further include a user interface broker installed on the broker workstation, wherein the user interface broker is configured to provide the one or more client workstations with a user interface that presents the status of, and that provides control over, all of the points.
An exemplary method in accordance with the present disclosure may be implemented for providing a comprehensive user interface for at least one alarm system having at least two alarm system workstations, each alarm system workstation having a user interface application installed thereon, at least one alarm panel connected to each of the at least two alarm system workstations, at least one point connected to the at least one alarm panel, and at least one client workstation. The exemplary method may include providing a first user interface broker that is operatively connected to each of the at least two alarm system workstations and the at least one client workstation. The exemplary method may further include the first user interface broker receiving user interface data from the user interface applications residing on the at least two alarm system workstations, and the first user interface broker providing the at least one client workstation with a user interface that presents the status of, and that provides control over, all of the points.
An exemplary user interface broker for providing a comprehensive user interface for alarm systems including at least two alarm system workstations, at least one alarm panel connected to each of the at least two alarm system workstations, at least one point connected to the at least one alarm panel, and at least one client workstation may be configured to perform a number of steps including receiving user interface data from user interface applications residing on the at least two alarm system workstations, and providing the at least one client workstation with a user interface that presents the status of, and that provides control over, the at least one point.
By way of example, specific embodiments of the disclosed device will now be described, with reference to the accompanying drawings, in which:
A system and method for providing a comprehensive user interface for alarm systems in accordance with the present disclosure will now be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This disclosed system and method, however, may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. In the drawings, like numbers refer to like elements throughout.
It will be appreciated by those of ordinary skill in the art that the user interface system and method described herein may be implemented in virtually any type of alarm or monitoring system, including, but not limited to, fire alarm systems, burglar alarm systems, surveillance systems, air quality monitoring systems, inventory monitoring systems, etc., or any combination thereof, such as may be provided for detecting an alarm event (e.g. a security breach) or a warning condition (e.g. an elevated temperature) in a building, structure, enclosure, or area (collectively referred to herein as “sites”). Many other applications are contemplated and may be implemented without departing from the scope of the present disclosure. All such applications are collectively referred to herein as “alarm systems.”
A first exemplary interface system 100 in accordance with the present disclosure is depicted in
The interface system 100 may further include a software application or module referred to herein as a “UI broker.” The UI broker may be installed on a broker workstation 110 (such installation represented by the dashed bubble and arrow shown in
Generally, the UI broker may be an architectural pattern for UI data validation, UI data transformation, and UI data routing. The UI broker may mediate communication amongst UI applications, minimizing the mutual awareness that applications have of each other in order to be able to exchange UI data, effectively implementing decoupling. The general purpose of the UI broker is to take incoming UI data from UI applications and perform some action on them. For example, the UI broker may perform some or all of the following actions: route UI data to one or more of many destinations; transform UI data into an alternative representation; perform UI data aggregation; decompose UI data into multiple data packets and send them to appropriate destinations, then recompose the data into a single packet to return to a user; interact with an external repository to augment UI data or store it; invoke Web services to retrieve data; and respond to events or errors.
In the present example, the UI broker may be an interface application that is configured to receive and aggregate interface data provided by each of the UI applications residing on the respective workstations 104 in the alarm system 102. Particularly, the UI broker may be configured to receive status information pertaining to each of the points 108 in the entire alarm system 102, such data being provided by each individual UI application, and may further be configured to issue command and control instructions to each of the UI applications in response to operator input as further described below.
The interface system 100 may further include one or more client workstations 112 (e.g. PCs or servers) that may be directly or indirectly connected to the broker workstation 110 via a secure, wired or wireless network connection. Such connections may be “permanent,” as in the case of a client server that may be continuously connected to the broker workstation 110 from a fixed location, or “transient,” as in the case of a client laptop that may intermittently connect to the broker workstation 110 from various locations. When connected to the broker workstation 110, the client workstations 112 may be provided with access to the UI broker residing thereon. The client workstations 112 may be loaded with software applications and/or authentication means (e.g. digital certificates) to facilitate secure connection and access to the UI broker.
The UI broker may provide each of the connected client workstations 112 with a UI that facilitates access to all of the points in the entire alarm system 102 as aggregated by the UI broker. Particularly, the UI broker may aggregate point configuration data provided by the UI applications residing on each of the alarm system workstations 104 connected thereto into a single data file that is sent to each client workstation 112. Thus, from the point of view of a human user, each client workstation 112 appears to be connected to a single, large, “virtual” alarm system workstation to which all of the points in the system 102 are connected. In addition, the UI broker may route global and point specific messages (e.g. command and control signals) from each client workstation 112 to appropriate alarm system workstations 104 for allowing users to access and exert control over specified points in the alarm system 102. Still further, the UI broker may monitor its connections to the various alarm system workstations 104 and may report any faults or connection issues to the client workstations 112 for display to users. Each client workstation 112 may thereby provide users with a single, comprehensive interface that facilitates observation of, and control over, all of the points in the alarm system 102 in a seamless, unified manner regardless of the point capacities of the individual workstations 104 in the alarm system 102.
As a result of implementing the above-described interface system 100, monitoring personnel are no longer required to monitor separate UI applications residing on the separate alarm system workstations 104 in order to be apprised of the status of the entire alarm system 102. Instead, personnel need only monitor and interact with a single interface on a single client workstation 112.
It is contemplated that in some embodiments the UI broker can be added to a previously-installed alarm system in a “retrofit” manner by connecting the broker workstation 110 to the existing workstations of the alarm system. Alternatively, the UI broker can be implemented as an integral component of a new alarm system installation having a plurality of alarm system workstations. In the former case, there is essentially no disruption or change to the alarm system from the point of view of a client, except that the client will interface with the UI broker instead of the individual UI applications. If a client requires additional point capacity, additional alarm system workstations can be added to the system and connected to the UI broker at any time. The UI broker may integrate the newly added points into the UI provided by the UI broker, and new points are thereby presented to a client in the unified, seamless manner described above. For example, if each of the three alarm system workstations 104 in
Referring to
Referring to
As with the previous embodiment, the broker workstation 310 of the multi-site interface system 300 may be located in any of a variety of locations, such as at any one of the monitored user sites, at the location of one of the client workstations 312, or elsewhere. It is further contemplated that the individual broker workstation 310 may be omitted, and that the UI broker may instead reside on one or more of the alarm system workstations 304 or client workstations 312 that is/are accessible by the other alarm system workstations 312 and client workstations 304 in the alarm systems. The UI broker may reside on one of the alarm system workstations 304 at any of the monitored user sites, with each of the other alarm system workstations 304 and client workstations 312 being directly or indirectly connected thereto via a secure, wired or wireless network connection. In such a case, the workstation on which the UI broker is installed may be referred to as the “broker workstation.”
Referring to
The topology of
The topology of
It will be appreciated that the topology depicted in
For example, a client that may employ the topology shown in
It is contemplated that for practical reasons UI brokers that are higher up in a particular hierarchy may be configured to provide less detailed information regarding alarm systems connected thereto relative to UI brokers that are lower in the hierarchy. For example, a client that is connected to the national tier UI broker of the above-described hotel chain system may be interested in knowing whether an alarm condition exists in a particular hotel, but may not be interested in knowing the specific point in the hotel that initiated the alarm condition. Conversely, a client that is connected to a state, city, or local tier UI broker may be interested in knowing precisely which point in a hotel alarm system initiated an alarm condition so that the client may inform response personnel (e.g. fire or police personnel) of the location in the hotel where the condition originated.
Referring now to
At a third step 520 in the flow diagram, a first UI broker may be directly or indirectly connected to the at least two alarm system workstations and the at least one client workstation via a secure, wired or wireless network connection. The first UI broker may be configured as described above for aggregating interface data provided by UI applications residing on the alarm system workstations connected thereto. Particularly, each alarm system workstation may send configuration data and other information to the first UI broker as though the alarm system workstation were communicating directly with a client workstation. The first UI broker may be installed on a separate broker workstation, or may be installed on one or more of the alarm system workstations or on a client workstation.
The first UI broker may provide each of the connected client workstations with a UI that facilitates access to all of the points connected to any of the alarm system workstations. Particularly, the first UI broker may aggregate point configuration data (e.g. data detailing the number, type, and location of points) and other information provided by the alarm system workstations into a single data file that is sent to each of the client workstations. The alarm system workstations continuously communicate event information and status updates relating to connected points to the first UI broker, which in turn continuously aggregates such data and sends it to the client workstations for presentation to users. The first UI broker also routes instructions and messages from each of the client workstations to appropriate alarm system workstations for allowing users to exert control over specified points in a system. Each client workstation may therefore provide users with a single, comprehensive interface that facilitates observation of, and control over, all of the points in a seamless, unified manner.
At an optional fourth step 530 in the flow diagram, an additional alarm system workstation that is connected to corresponding additional alarm panels and points may be connected to the first UI broker. The first UI broker may then access the UI application residing on the newly added alarm system workstation and may integrate the points of the workstation into the UI that is presented to the one or more client workstations in a unified, seamless manner.
At an optional fifth step 540 in the flow diagram, the first UI broker and a second UI broker may be directly or indirectly connected to a third, higher-tier UI broker workstation via secure, wired or wireless network connection means. The third UI broker may be configured as described above for further aggregating the aggregated interface data provided by the first and second UI brokers connected thereto.
At an optional sixth step 550 in the flow diagram, one or more additional client workstations may be directly or indirectly connected to the third UI broker via secure, wired or wireless network connection means. The third UI broker may provide each of the additional client workstations with a UI that facilitates access to all of the points aggregated by the first and second UI brokers. Each connected client workstation may therefore provide users with a single, comprehensive interface that facilitates observation of, and control over, all of the aggregated points in a seamless, unified manner
As used herein, an element or step recited in the singular and proceeded with the word “a” or “an” should be understood as not excluding plural elements or steps, unless such exclusion is explicitly recited. Furthermore, references to “one embodiment” of the present invention are not intended to be interpreted as excluding the existence of additional embodiments that also incorporate the recited features.
While certain embodiments of the disclosure have been described herein, it is not intended that the disclosure be limited thereto, as it is intended that the disclosure be as broad in scope as the art will allow and that the specification be read likewise. Therefore, the above description should not be construed as limiting, but merely as exemplifications of particular embodiments. Those skilled in the art will envision other modifications within the scope and spirit of the claims appended hereto.
The various embodiments or components described above, for example, the alarm system workstations, broker workstations, and the components or processors therein, may be implemented as part of one or more computer systems. Such a computer system may include a computer, an input device, a display unit and an interface, for example, for accessing the Internet. The computer may include a microprocessor. The microprocessor may be connected to a communication bus. The computer may also include memories. The memories may include Random Access Memory (RAM) and Read Only Memory (ROM). The computer system further may include a storage device, which may be a hard disk drive or a removable storage drive such as a floppy disk drive, optical disk drive, and the like. The storage device may also be other similar means for loading computer programs or other instructions into the computer system.
As used herein, the term “computer” may include any processor-based or microprocessor-based system including systems using microcontrollers, reduced instruction set circuits (RISCs), application specific integrated circuits (ASICs), logic circuits, and any other circuit or processor capable of executing the functions described herein. The above examples are exemplary only, and are thus not intended to limit in any way the definition and/or meaning of the term “computer.”
The computer system executes a set of instructions that are stored in one or more storage elements, in order to process input data. The storage elements may also store data or other information as desired or needed. The storage element may be in the form of an information source or a physical memory element within the processing machine.
The set of instructions may include various commands that instruct the computer as a processing machine to perform specific operations such as the methods and processes of the various embodiments of the invention. The set of instructions may be in the form of a software program. The software may be in various forms such as system software or application software. Further, the software may be in the form of a collection of separate programs, a program module within a larger program or a portion of a program module. The software also may include modular programming in the form of object-oriented programming. The processing of input data by the processing machine may be in response to user commands, or in response to results of previous processing, or in response to a request made by another processing machine.
As used herein, the term “software” includes any computer program stored in memory for execution by a computer, such memory including RAM memory, ROM memory, EPROM memory, EEPROM memory, and non-volatile RAM (NVRAM) memory. The above memory types are exemplary only, and are thus not limiting as to the types of memory usable for storage of a computer program.