REAL TIME LOCATION PLATFORM BEACON PROTOCOL SYSTEMS AND METHODS
20190327161 ยท 2019-10-24
Inventors
- Matthew James Cannell (Glen Allen, VA, US)
- Philip Crawley (Glen Allen, VA, US)
- Shawn Reed (Glen Allen, VA, US)
Cpc classification
H04W4/80
ELECTRICITY
H04W4/30
ELECTRICITY
G16H40/20
PHYSICS
G01S1/68
PHYSICS
H04L67/52
ELECTRICITY
International classification
H04W4/80
ELECTRICITY
G01S1/68
PHYSICS
Abstract
A cloud based processing system receives location information and health status information of a plurality of beacon devices. The location information indicates real-time locations of the plurality of beacon devices, and the health status information indicates real-time conditions of the plurality of beacon devices. The processing system tracks movements of at least some of the plurality of beacon devices based on the location information and identifies problematic beacon devices based on the health status information.
Claims
1. A cloud based processing system configured to: receive location information and health status information of a plurality of beacon devices, wherein the location information indicates real-time locations of the plurality of beacon devices, and the health status information indicates real-time conditions of the plurality of beacon devices; track movements of at least some of the plurality of beacon devices based on the location information; and identify problematic beacon devices based on the health status information.
2. The cloud based processing system of claim 1, wherein the plurality of beacon devices comprises beacon tags installed in or attached to fixed location assets, beacon tags affixed to mobile assets, and reader badgers worn by healthcare workers.
3. The cloud based processing system of claim 1, wherein the health status information comprises at least one of battery information and operation error information.
4. The cloud based processing system of claim 1, wherein the location information and health status information are transmitted as fields in frames following a custom beacon communication protocol.
5. The cloud based processing system of claim 4, wherein the custom beacon communication protocol facilitates Bluetooth Low Energy (BLE) communication.
6. The cloud based processing system of claim 4, wherein the custom beacon communication protocol also provides fields for installation specific data.
7. The cloud based processing system of claim 4, wherein the custom beacon protocol also provides fields for beacon security information.
8. A method performed by a cloud based processing system, the method comprising: receiving location information and health status information of a plurality of beacon devices, wherein the location information indicates real-time locations of the plurality of beacon devices, and the health status information indicates real-time conditions of the plurality of beacon devices; tracking movements of at least some of the plurality of beacon devices based on the location information; and identifying problematic beacon devices based on the health status information.
9. The method of claim 8, wherein the plurality of beacon devices comprises beacon tags installed in or attached to fixed location assets, beacon tags affixed to mobile assets, and reader badgers worn by healthcare workers.
10. The method of claim 8, wherein the health status information comprises at least one of battery information and operation error information.
11. The method of claim 8, wherein the location information and health status information are transmitted as fields in frames following a custom beacon communication protocol.
12. The method of claim 11, wherein the custom beacon communication protocol facilitates Bluetooth Low Energy (BLE) communication.
13. The method of claim 11, wherein the custom beacon communication protocol also provides fields for installation specific data.
14. The method of claim 11, wherein the custom beacon protocol also provides fields for beacon security information.
15. A non-transitory computer readable storage medium including instructions, when executed, cause a processing system to perform operations of: receiving location information and health status information of a plurality of beacon devices, wherein the location information indicates real-time locations of the plurality of beacon devices, and the health status information indicates real-time conditions of the plurality of beacon devices; tracking movements of at least some of the plurality of beacon devices based on the location information; and identifying problematic beacon devices based on the health status information.
16. The medium of claim 15, wherein the plurality of beacon devices comprises beacon tags installed in or attached to fixed location assets, beacon tags affixed to mobile assets, and reader badgers worn by healthcare workers.
17. The medium of claim 15, wherein the health status information comprises at least one of battery information and operation error information.
18. The medium of claim 15, wherein the location information and health status information are transmitted as fields in frames following a custom beacon communication protocol.
19. The medium of claim 18, wherein the custom beacon communication protocol facilitates Bluetooth Low Energy (BLE) communication.
20. The method of claim 18, wherein the custom beacon communication protocol also provides fields for installation specific data and fields for beacon security information.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0005] The features and technical aspects of the system and method disclosed herein will become apparent in the following Detailed Description set forth below when taken in conjunction with the drawings in which like reference numerals indicate identical or functionally similar elements.
[0006]
[0007]
[0008]
[0009]
[0010]
[0011]
[0012]
[0013]
[0014]
[0015]
[0016]
DETAILED DESCRIPTION
[0017] In the following detailed description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific examples that may be practiced. These examples are described in sufficient detail to enable one skilled in the art to practice the subject matter, and it is to be understood that other examples may be utilized and that logical, mechanical, electrical and other changes may be made without departing from the scope of the subject matter of this disclosure. The following detailed description is, therefore, provided to describe an exemplary implementation and not to be taken as limiting on the scope of the subject matter described in this disclosure. Certain features from different aspects of the following description may be combined to form yet new aspects of the subject matter discussed below.
[0018] When introducing elements of various embodiments of the present disclosure, the articles a, an, the, and said are intended to mean that there are one or more of the elements. The terms comprising, including, and having are intended to be inclusive and mean that there may be additional elements other than the listed elements.
[0019] I. Overview
[0020] Certain examples of the presently disclosed technology improve proximity detection and location tracking of resources in an environment such as a hospital. An example system disclosed herein includes one or more beacon tags affixed to assets within the environment and that transmit (e.g., periodically, aperiodically and/or as a one-time event) beacon messages. The beacon messages are received by a mobile reader badge that listens for beacon messages transmitted in the environment. For example, disclosed example reader badges (sometimes referred to herein as readers, badges or mobile wireless bridges) may include a network interface to receive beacon messages transmitted via low power Bluetooth Low Energy (BLE). In some disclosed examples, the reader badges process the received beacon messages and communicate information obtained from the beacon messages to one or more real-time location services (RTLS) servers via a communication infrastructure. For example, disclosed example reader badges may aggregate and communicate a batch of beacon messages (e.g., a threshold number of beacon messages, a threshold interval of time (e.g., a window of interest), etc.) to an RTLS server via a Wi-Fi infrastructure (e.g., a wireless network). In some disclosed examples, the RTLS server processes the received batch of beacon messages to facilitate real-time location tracking of the resources in the environment. In some disclosed examples, the RTLS server may report the location of resources via charts, graphs, tables, etc.
[0021] Real-time location services enable improved patient workflow via proximity detection and location tracking in a healthcare environment, such as a hospital. Location tracking can be used to locate resources such as mobile assets (e.g., patients, intravenous (IV) pumps, telemetry units, wheelchairs, etc.) within the hospital. For example, location tracking can be used to locate a lost or missing IV pump within a patient's room. Proximity detection facilitates an improved understanding of how interactions occur during the patient workflow. For example, based on the proximity to a soap dispenser, a user (e.g., a system administrator) can determine whether a caretaker washed their hands prior to interacting with a patient.
[0022] Examples systems and methods disclosed herein facilitate improved proximity detection and location tracking by creating a hospital tracking network within the hospital using the communication infrastructure already installed in the hospital. Beacon tags are installed throughout a location or building. For example, beacon tags can be affixed to stationary assets (e.g., patient room entry ways, sinks, water fountains, hallways, etc.) and mobile assets such as hospital beds, IV pumps, soap dispensers, etc. In some disclosed examples, the beacon tags are also included in disposable patient tags provided to the patient upon admission of a hospital stay. Beacon tags are low-cost, low-power transmitters of beacon messages. A beacon message (sometimes referred to herein as a beacon) includes information about the beacon tag such as a unique identifier (e.g., a tag identifier such as a media access control (MAC) address) and a tag type identifier (e.g., whether the beacon tag is affixed to a fixed-location asset or to a mobile asset). In some disclosed examples, the beacon tags broadcast (e.g., advertise, communicate, transmit, etc.) beacon messages at pre-set frequencies (e.g., ten times a second, once a second, once a minute, etc.). For example, a beacon tag affixed to a fixed-location asset (e.g., a sink) may broadcast beacon messages ten times a second, while a beacon tag affixed to a mobile asset (e.g., a wheelchair) may broadcast beacon messages at relatively shorter intervals (e.g., once a second).
[0023] A reader badge is a mobile wireless bridge that facilitates mobile tracking by listening and receiving beacon messages broadcast by beacon tags. The reader badge includes a BLE controller to receive connection-less beacon messages broadcast by beacon tags. The reader badge also includes a Wi-Fi controller to establish a connection with an RTLS server. The reader badge may be worn or transported by hospital caregivers. For example, a reader badge may be worn as a lanyard or clipped to the caregiver's clothing. As the caregiver moves about the hospital, the reader badge passively collects beacon messages and communicates reader messages to an RTLS server at the backend of the system. In some examples, the reader badge collects a number (e.g., a predetermined number) of beacon messages or waits a period (e.g., a predetermined period of time) prior to communicating the reader messages. In some examples, the reader badge generates and communicates a reader message as a beacon message from a beacon tag is received. A reader message includes information received from the beacon message such as a unique identifier of the source beacon tag and a spatial location of the source beacon tag. In some examples, the reader badge includes a timestamp identifying when the beacon message was received by the reader badge in the reader message. In some examples, the reader badge includes a received signal strength indication (RSSI) value (e.g., a power ratio in decibels of the measured power to one milli-watt (dBm)).
[0024] Example reader badges disclosed herein include a proximity engine to process the beacon messages and determine distance from the source (e.g., the beacon tag that broadcast the corresponding beacon message). For example, a hospital room may include a first beacon tag affixed to a door, a second beacon tag affixed to an infusion pump, a third beacon tag affixed to a bed, and a fourth beacon tag included in a patient tag (e.g., a disposable bracelet including patient identification information such as name, sex, date of birth information). As the caregiver moves about the hospital room, the reader badge may receive beacon messages from each of the beacon tags. The proximity engine can determine the RSSI strength for each of the beacon messages and associate RSSI strength with a respective beacon tag.
[0025] In some examples, the proximity engine determines which beacon tags are proximate (e.g., near or closely located) to the reader badge. For example, the proximity engine can compare the RSSI strength of a beacon message to a threshold and if the RSSI strength satisfies the threshold (e.g., the RSSI strength is greater than a threshold), the proximity engine identifies the source beacon tag as proximate to the reader badge. In some examples, the proximity engine discards beacon messages that are not proximate to the reader badge.
[0026] Example systems and methods disclosed herein include an RTLS server that monitors and/or reports tracking location and interactions between people and assets in an environment. For example, the RTLS server can aggregate reader messages from the one or more reader badges included in an environment (e.g., the hospital). The RTLS server may be in connection with the reader badges via a wireless Intranet network (e.g., a wireless local area network, etc.) and/or a wireless Internet connection.
[0027] As healthcare assets continue to become smaller and more ergonomic, RTLS tracking with a small footprint becomes increasingly important. Additionally, as a hospital's inventory of healthcare equipment gets leaner, the equipment is likely to be cleaned more often. Therefore, an asset tracking beacon should withstand frequent, repeated cleaning with harsh disinfecting chemicals.
[0028] Certain examples provide an improved housing that can be applied with BLE and/or other location tracking technology to healthcare assets (e.g., scanner, IV pumps, monitors, etc.). In certain examples, a computerized maintenance management system (CMMS) and/or source system can organize and monitor assets and can remove and re-associate beacons from one asset to another asset on demand Beacons can be installed on ergonomic items that do not have flat surfaces. Beacons can be developed with housings to withstand rigorous healthcare cleaning protocols while maintaining a small footprint to not disturb normal usage of equipment to which the beacon is applied.
[0029] A quality of location data provided by a real time location platform can depend on health of devices deployed to receive sensory and/or location events. If deployed devices are not functioning as intended, the location data produced by the system may be inaccurate/unreliable. To help ensure accurate location data, support teams can monitor system health, isolate problematic devices and correct the problems through reconfiguration/replacement/upgrades/etc.
[0030] Certain examples provide receiver health methods and systems for real time location platforms. Certain examples define a mechanism and associated application programming interface (API) specification by which location receivers deployed as part of a real time location platform can transmit system health information using an event-based messaging framework. The data/events provided can be captured and utilized to maintain the system and help ensure improved or optimal performance.
[0031] Devices used to implement a real time location platform may have numerous dependencies, including a reliable power supply (e.g., battery, outlet, etc.), network connectivity and acceptable environmental conditions (e.g. min/max operating temperature, etc.). With a large number of devices deployed, it is not feasible or cost effective to manually inspect each device in the field on a regular basis. Certain examples facilitate device self-reporting of health status and associated system events to help maintain a functioning system.
[0032] In certain examples, location devices are designed to submit event data (e.g., as JavaScript Object Notation (JSON) documents, etc.) to a service interface (e.g., a representational state transfer (REST) or RESTful service interface, etc.). There are numerous events defined, and these events can be sent in response to a condition (e.g., device regaining network connectivity, device placed on charger, device removed from charger, etc.) or on a time schedule that is configurable as part of the device profile. Events include a set of base (e.g., header, etc.) attributes that are used for ongoing system health management. In addition, each event includes a details section where attributes/data specific to an event type can be included.
[0033] In certain examples, receiver health includes a set of events defined for receiver devices (e.g., Bluetooth receiver devices, BLE receiver devices, etc.). The set of events can be defined according to an API, for example. In certain examples, a gateway client API includes a service interface specification or API for the RESTful service used by the device to post receiver health events, etc.
[0034] Certain examples provide a centralized health and monitoring capability for large scale systems that include a plurality of devices deployed in a wide range of environments. Without such monitoring, deployed systems may fall into disrepair over time and/or the costs of monitoring/maintaining such systems may threaten the commercial viability of the dependent products, for example.
[0035] Certain examples, when utilized, result in improved system performance, higher customer satisfaction, higher return on investment for the customer, lower cost of ownership for the customer, lower support costs for the supplier and increased profit margin for the supplier, etc.
[0036] Types and details of health events reported by devices can be extended/modified in a variety of ways to propose a unique set of health events. The mechanisms/protocols by which the events are delivered (e.g. JSON/XML/CSV or HTTP/JMS/SMTP, etc.) and/or captured can also be varied to propose a unique solution, for example.
[0037] Certain examples provide a custom beacon protocol (e.g., a custom BLE beacon protocol, etc.) that provides all involved fields for message processing and location determination, as well as system health status including low battery indication (e.g., in days remaining, hours remaining, percent remaining, battery value, etc.), custom fields for additional installation specific data (e.g., profile identifier (ID), floor designation, department ID, etc.), beacon security, and/or other item(s). While no single existing protocol fulfills these needs, certain examples provide a new protocol that enable location systems to provide customers with system health and security information/messaging and also enable additional device level functionality by allowing custom data within the protocol.
[0038] II. Example Operating Environment
[0039] Health information, also referred to as healthcare information and/or healthcare data, relates to information generated and/or used by a healthcare entity. Health information can include reader messages and RTLS server information, for example. Health information can be information associated with health of one or more patients, for example. Health information may include protected health information (PHI), as outlined in the Health Insurance Portability and Accountability Act (HIPAA), which is identifiable as associated with a particular patient and is protected from unauthorized disclosure. Health information can be organized as internal information and external information. Internal information includes patient encounter information (e.g., patient-specific data, aggregate data, comparative data, etc.) and general healthcare operations information, etc. External information includes comparative data, expert and/or knowledge-based data, etc. Information can have both a clinical (e.g., diagnosis, treatment, prevention, etc.) purpose and an administrative (e.g., scheduling, billing, management, etc.) purpose.
[0040] Institutions, such as healthcare institutions, having complex network support environments and sometimes chaotically driven process flows utilize secure handling and safeguarding of the flow of sensitive information (e.g., personal privacy). A need for secure handling and safeguarding of information increases as a demand for flexibility, volume, and speed of exchange of such information grows. For example, healthcare institutions provide enhanced control and safeguarding of the exchange and storage of sensitive patient PHI and employee information between diverse locations to improve hospital operational efficiency in an operational environment typically having a chaotic-driven demand by patients for hospital services. In certain examples, patient identifying information can be masked or even stripped from certain data depending upon where the data is stored and who has access to that data. In some examples, PHI that has been de-identified can be re-identified based on a key and/or other encoder/decoder.
[0041] A healthcare information technology infrastructure can be adapted to service multiple business interests while providing clinical information and services. Such an infrastructure may include a centralized capability including, for example, a data repository, reporting, discreet data exchange/connectivity, smart algorithms, personalization/consumer decision support, etc. This centralized capability provides information and functionality to a plurality of users including medical devices, electronic records, access portals, pay for performance (P4P), chronic disease models, and clinical health information exchange/regional health information organization (HIE/RHIO), and/or enterprise pharmaceutical studies, home health, for example.
[0042] Interconnection of multiple data sources helps enable an engagement of all relevant members of a patient's care team and helps improve an administrative and management burden on the patient for managing his or her care. Particularly, interconnecting the patient's electronic medical record and/or other medical data can help improve patient care and management of patient information. Furthermore, patient care compliance is facilitated by providing tools that automatically adapt to the specific and changing health conditions of the patient and provide comprehensive education and compliance tools to drive positive health outcomes.
[0043] In certain examples, healthcare information can be distributed among multiple applications using a variety of database and storage technologies and data formats. To provide a common interface and access to data residing across these applications, a connectivity framework (CF) can be provided which leverages common data models (CDM) and common service models (CSM) and service oriented technologies, such as an enterprise service bus (ESB) to provide access to the data.
[0044] In certain examples, a variety of user interface frameworks and technologies can be used to build applications for health information systems including, but not limited to, MICROSOFT ASP.NET, AJAX, MICROSOFT Windows Presentation Foundation, GOOGLE Web Toolkit, MICROSOFT Silverlight, ADOBE, and others. Applications can be composed from libraries of information widgets to display multi-content and multi-media information, for example. In addition, the framework enables users to tailor layout of applications and interact with underlying data.
[0045] In certain examples, an advanced Service-Oriented Architecture (SOA) with a modern technology stack helps provide robust interoperability, reliability, and performance Example SOA includes a three-fold interoperability strategy including a central repository (e.g., a central repository built from Health Level Seven (HL7) transactions), services for working in federated environments, and visual integration with third-party applications. Certain examples provide portable content enabling plug n play content exchange among healthcare organizations. A standardized vocabulary using common standards (e.g., LOINC, SNOMED CT, RxNorm, FDB, ICD-9, ICD-10, etc.) is used for interoperability, for example. Certain examples provide an intuitive user interface to help minimize end-user training. Certain examples facilitate user-initiated launching of third-party applications directly from a desktop interface to help provide a seamless workflow by sharing user, patient, and/or other contexts. Certain examples provide real-time (or at least substantially real time assuming some system delay) patient data from one or more information technology (IT) systems and facilitate comparison(s) against evidence-based best practices. Certain examples provide one or more dashboards for specific sets of patients. Dashboard(s) can be based on condition, role, and/or other criteria to indicate variation(s) from a desired practice, for example.
[0046] A. Example Healthcare Information System
[0047] An information system can be defined as an arrangement of information/data, processes, and information technology that interact to collect, process, store, and provide informational output to support delivery of healthcare to one or more patients. Information technology includes computer technology (e.g., hardware and software) along with data and telecommunications technology (e.g., data, image, and/or voice network, etc.).
[0048] Turning now to the figures,
[0049] As illustrated in
[0050] The example input 110 of
[0051] The example output 120 of
[0052] The example processor 130 of
[0053] The example memory 140 of
[0054] In certain examples, the memory 140 stores and controls access to encrypted information, such as patient records, encrypted update-transactions for patient medical records, including usage history, etc. In an example, medical records can be stored without using logic structures specific to medical records. In such a manner, the memory 140 is not searchable. For example, a patient's data can be encrypted with a unique patient-owned key at the source of the data. The data is then uploaded to the memory 140. The memory 140 does not process or store unencrypted data thus minimizing privacy concerns. The patient's data can be downloaded and decrypted locally with the encryption key.
[0055] For example, the memory 140 can be structured according to provider, patient, patient/provider association, and document. Provider information may include, for example, an identifier, a name, and address, a public key, and one or more security categories. Patient information may include, for example, an identifier, a password hash, and an encrypted email address. Patient/provider association information may include a provider identifier, a patient identifier, an encrypted key, and one or more override security categories. Document information may include an identifier, a patient identifier, a clinic identifier, a security category, and encrypted data, for example.
[0056] The example communication interface 150 of
[0057] In certain examples, a Web-based portal may be used to facilitate access to information, patient care and/or practice management, etc. Information and/or functionality available via the Web-based portal may include one or more of order entry, laboratory test results review system, patient information, clinical decision support, medication management, scheduling, electronic mail and/or messaging, medical resources, etc. In certain examples, a browser-based interface can serve as a zero footprint, zero download, and/or other universal viewer for a client device.
[0058] In certain examples, the Web-based portal serves as a central interface to access information and applications, for example. Data may be viewed through the Web-based portal or viewer, for example. Additionally, data may be manipulated and propagated using the Web-based portal, for example. Data may be generated, modified, stored and/or used and then communicated to another application or system to be modified, stored and/or used, for example, via the Web-based portal, for example.
[0059] The Web-based portal may be accessible locally (e.g., in an office) and/or remotely (e.g., via the Internet and/or other private network or connection), for example. The Web-based portal may be configured to help or guide a user in accessing data and/or functions to facilitate patient care and practice management, for example. In certain examples, the Web-based portal may be configured according to certain rules, preferences and/or functions, for example. For example, a user may customize the Web portal according to particular desires, preferences and/or requirements.
[0060] B. Example Healthcare Infrastructure
[0061]
[0062] In the illustrated example of
[0063] In the illustrated example of
[0064] In the illustrated example of
[0065] In the illustrated example, the interface unit 210 receives images, medical reports, administrative information, exam workload distribution information, and/or other clinical information from the information systems 204, 206, 208 via the corresponding interface connections 216, 218, 220. If necessary (e.g., when different formats of the received information are incompatible), the interface unit 210 translates or reformats (e.g., into Structured Query Language (SQL) or standard text) the medical information, such as medical reports, to be properly stored at the data center 212. The reformatted medical information can be transmitted using a transmission protocol to enable different medical information to share common identification elements, such as a patient name or social security number. Next, the interface unit 210 transmits the medical information to the data center 212 via the data center interface connection 222. Finally, medical information is stored in the data center 212 in, for example, the DICOM format, which enables medical images and corresponding medical information to be transmitted and stored together.
[0066] The medical information is later viewable and easily retrievable at the workstation 214 (e.g., by their common identification element, such as a patient name or record number). The workstation 214 can be any equipment (e.g., a personal computer) capable of executing software that permits electronic data (e.g., medical reports) and/or electronic medical images (e.g., x-rays, ultrasounds, MRI scans, etc.) to be acquired, stored, or transmitted for viewing and operation. The example workstation 214 of
[0067] The example data center 212 of
[0068] In the illustrated example, the example data center 212 of
[0069] Certain examples can be implemented as cloud-based clinical information systems and associated methods of use. An example cloud-based clinical information system enables healthcare entities (e.g., patients, clinicians, sites, groups, communities, and/or other entities) to share information via web-based applications, cloud storage and cloud services. For example, the cloud-based clinical information system may enable a first clinician to securely upload information into the cloud-based clinical information system to allow a second clinician to view and/or download the information via a web application. Thus, for example, the first clinician may upload an x-ray image into the cloud-based clinical information system, and the second clinician may view the x-ray image via a web browser and/or download the x-ray image onto a local information system employed by the second clinician.
[0070] In certain examples, users (e.g., a patient and/or care provider) can access functionality provided by the healthcare information system 200 via a software-as-a-service (SaaS) implementation over a cloud or other computer network, for example. In certain examples, all or part of the healthcare information system 200 can also be provided via platform as a service (PaaS), infrastructure as a service (IaaS), etc. For example, the healthcare information system 200 can be implemented as a cloud-delivered Mobile Computing Integration Platform as a Service. A set of consumer-facing Web-based, mobile, and/or other applications enable users to interact with the PaaS, for example.
[0071] C. Industrial Internet Examples
[0072] The Internet of things (also referred to as the Industrial Internet) relates to an interconnection between a device that can use an Internet connection to talk (e.g., communicate) with other devices on the network. Using the connection, devices can communicate to trigger events/actions (e.g., changing temperature, turning on/off, providing a status, etc.). In certain examples, machines can be merged with big data to improve efficiency and operations, providing improved data mining, facilitate better operation, etc.
[0073] Big data can refer to a collection of data so large and complex that it becomes difficult to process using traditional data processing tools/methods. Challenges associated with a large data set include data capture, sorting, storage, search, transfer, analysis, and visualization. A trend toward larger data sets is due at least in part to additional information derivable from analysis of a single large set of data, rather than analysis of a plurality of separate, smaller data sets. By analyzing a single large data set, correlations can be found in the data, and data quality can be evaluated.
[0074]
[0075] As shown in the example of
[0076] Thus, the example health-related assets 310-312 within the industrial internet configuration 300 become intelligent as a network with advanced sensors, controls, analytical-based decision support and hosting software applications. Using such an infrastructure, advanced analytics can be provided to associated data. The analytics combines physics-based analytics, predictive algorithms, automation, and deep domain expertise. Via the example cloud 320, the health-related assets 310-312 and associated people can be connected to support more intelligent design, operations, maintenance, and higher server quality and safety, for example.
[0077] Using the industrial internet infrastructure, for example, a proprietary machine data stream can be extracted from the asset 310. Machine-based algorithms and data analysis are applied to the extracted data. Data visualization can be remote, centralized, etc. Data is then shared with authorized users, and any gathered and/or gleaned intelligence is fed back into the assets 310-312.
[0078] D. Data Mining Examples
[0079] Imaging informatics includes determining how to tag and index a large amount of data acquired in diagnostic imaging in a logical, structured, and machine-readable format. By structuring data logically, information can be discovered and utilized by algorithms that represent clinical pathways and decision support systems. Data mining can be used to help ensure patient safety, reduce disparity in treatment, provide clinical decision support, etc. Mining both structured and unstructured data from radiology reports, as well as actual image pixel data, can be used to tag and index both imaging reports and the associated images themselves.
[0080] E. Example Methods of Use
[0081] Clinical workflows are typically defined to include one or more steps or actions to be taken in response to one or more events and/or according to a schedule. Events may include receiving a healthcare message associated with one or more aspects of a clinical record, opening a record(s) for new patient(s), receiving a transferred patient, reviewing and reporting on an image, and/or any other instance and/or situation that requires or dictates responsive action or processing. The actions or steps of a clinical workflow may include placing an order for one or more clinical tests, scheduling a procedure, requesting certain information to supplement a received healthcare record, retrieving additional information associated with a patient, providing instructions to a patient and/or a healthcare practitioner associated with the treatment of the patient, radiology image reading, and/or any other action useful in processing healthcare information. The defined clinical workflows may include manual actions or steps to be taken by, for example, an administrator or practitioner, electronic actions or steps to be taken by a system or device, and/or a combination of manual and electronic action(s) or step(s). While one entity of a healthcare enterprise may define a clinical workflow for a certain event in a first manner, a second entity of the healthcare enterprise may define a clinical workflow of that event in a second, different manner. In some examples, different healthcare entities may treat or respond to the same event or circumstance in different fashions. Differences in workflow approaches may arise from varying preferences, capabilities, requirements or obligations, standards, protocols, etc. among the different healthcare entities.
[0082] In certain examples, a medical exam conducted on a patient can involve review by a healthcare practitioner, such as a radiologist, to obtain, for example, diagnostic information from the exam. In a hospital setting, medical exams can be ordered for a plurality of patients, all of which require review by an examining practitioner. Each exam has associated attributes, such as a modality, a part of the human body under exam, and/or an exam priority level related to a patient criticality level. Hospital administrators, in managing distribution of exams for review by practitioners, can consider the exam attributes as well as staff availability, staff credentials, and/or institutional factors such as service level agreements and/or overhead costs.
[0083] Additional workflows can be facilitated such as bill processing, revenue cycle management, population health management, patient identity, consent management, etc.
[0084] III. Example Hospital Tracking Network
[0085] The foregoing systems and methods can be deployed to provide real-time location services. Real-time location services (RTLS) facilitate tracking people and assets in an industrial setting, such as a hospital. The example RTLS system described herein is designed to create location awareness of assets by capturing location and proximity information from beacon tags installed throughout the hospital. Examples disclosed herein utilize reader badges worn by healthcare workers (e.g., doctors, nurses, administrators, janitors, etc.) that receive beacon messages from beacon tags that are installed in and/or affixed to assets such as hallways, rooms, equipment, patients, etc. for which location and/or proximity information is to be collected between the beacon tags and the tagged asset. For example, the beacon tags may broadcast beacon messages including a unique identifier (e.g., a signature, a MAC address, a serial number, etc.) associated with the corresponding beacon tags. As the healthcare workers walk around the hospital, their reader badges collect beacon messages transmitted from beacon tags throughout the hospital. In some disclosed examples, the reader badges aggregate the beacon messages and transmit a batch of beacon messages to an RTLS server for processing. The example RTLS server disclosed herein processes the beacon messages to create location awareness through proximity and probability.
[0086] In some disclosed examples, beacon tags are installed in and/or attached to fixed-location (e.g., placed on stationary (or near stationary)) assets. For example, some known location beacon tags may be affixed to hallways, doors, windows, sinks, etc. As disclosed below, in some examples, the RTLS server utilizes the beacon messages received from known location beacon tags to determine a location for the reader badge.
[0087] In some disclosed examples, beacon tags are affixed to mobile assets such as equipment. For example, some mobile location beacon tags may be affixed to beds, wheelchairs, patients, etc. As disclosed below, in some examples, the RTLS server utilizes the beacon messages received from the mobile location beacon tags to determine what assets are near the corresponding reader badges (e.g., the reader badge that aggregated and transmitted a batch of beacon messages).
[0088] In addition, comparing the asset locations during different timestamp intervals may be useful in determining how the assets were moved and/or when caregivers interacted with the assets. For example, consider an example in which a wheelchair (e.g., a mobile-location asset) is located in a first patient room. In the illustrated example, assume that the wheelchair is affixed with a mobile-location asset beacon tag and that the first patient room is affixed with a fixed-location asset beacon tag. In the illustrated example, when a caregiver wearing a reader badge walks into the first patient room, their reader badge collects beacon messages broadcast by the wheelchair beacon tag and the first patient room beacon tag. In the illustrated example, the caregiver location is assigned to the first patient room based on the beacon messages broadcast by the first patient room beacon tag. In addition, since the wheelchair is seen in the same location, the wheelchair location may also be updated to the first patient room.
[0089] In the illustrated example, while the caregiver is in the first patient room, their reader badge collects beacon messages broadcast by the wheelchair beacon tag and the first patient room beacon tag. If the caregiver begins moving the wheelchair (e.g., from the first patient room to a second patient room), their reader badge will continue to collect beacon tags broadcast by the first patient room badge tag, but will also begin collecting beacon messages broadcast by a second patient room beacon tag. In the illustrated example, once the caregiver enters the second patient room, the caregiver location is updated to the second patient room. Additionally, in the illustrated example, since the wheelchair is still seen by the caregiver (e.g., the wheelchair location is determined to be proximate to the caregiver), the location of the wheelchair is also updated to the second patient room.
[0090] In the illustrated example, after the wheelchair is moved from the first patient room to the second patient room, confidence that the wheelchair is located in the second patient room rather than the first patient room may be low. However, in the illustrated example, each time a caregiver walks into the first patient room and does not see the wheelchair, confidence that the wheelchair is located in the first patient room decreases. Additionally, in the illustrated example, each time a caregiver walks into the second patient room and does see the wheelchair, confidence that the wheelchair is located in the second patient room increases. In the illustrated example, the crowd (e.g., the caregivers) provides different snapshots of what is seen at different locations and at different times. As disclosed herein, an RTLS server may analyze the different snapshots to facilitate proximity detection and location tracking of assets in an environment.
[0091] Referring to
[0092] In the illustrated example of
[0093] In the illustrated example of
[0094] In the illustrated example, the beacon messages 410 include tag identifying information 415 and tag-type identifying information 420. For example, tag identifying information 415 may be a unique identifier of the beacon tag 405 such as a MAC address, a serial number, an alphanumeric signature, etc. The example tag-type identifying information 420 identifies whether the beacon tag 405 broadcasting the beacon message 410 is affixed to a fixed-location asset or affixed to a mobile-location asset. However, the beacon messages 410 may include additional or alternative information. For example, the beacon messages 410 may include information identifying the software version being executed by the beacon tags 405, may include information identifying a power level of the beacon tag 405, etc.
[0095] In the illustrated example of
[0096] In the illustrated example of
[0097] In the illustrated example of
[0098] In the illustrated example of
[0099] In the illustrated example, the RTLS server 455 is in communication with the reader badge 425 via one or more wireless networks represented by example network 460. Example network 460 may be implemented using any suitable wireless network(s) including, for example, one or more data busses, one or more wireless Local Area Networks (LANs), one or more cellular networks, the Internet, etc. As used herein, the phrase in communication, including variances thereof (e.g., communicates, in communication with, etc.), encompasses direct communication and/or indirect communication through one or more intermediary components and does not require direct physical (e.g., wired) communication and/or constant communication, but rather additionally includes communication at periodic or aperiodic intervals, as well as one-time events.
[0100] In the illustrated example of
[0101] In the illustrated example of
[0102] In the illustrated example of
[0103] In the illustrated of
[0104] In the illustrated example, when a mobile-location asset is classified as relatively-far, the example RTLS server 455 of
[0105] When a mobile-location asset is classified as a relatively-immediate asset, high signal strength (e.g., an RSSI value greater than (40) decibels) may be indicative of a mobile-location asset that is in-front of the hospital worker 426, is being used by the hospital worker 426 and/or is being moved by the hospital worker 426. In some such instances, the location of the mobile-location asset may be assumed to be the same as the location of the reader badge 425. In the illustrated example, the example RTLS server 455 of
[0106] In the illustrated example of
[0107] In the illustrated example of
[0108]
[0109] In the illustrated example of
[0110] The hub module 506 may be leveraged to identify particular locations. As an example, the beacon badge 504 may be coupled, via a badge connection 534, to a hub module 506 placed on an entrance to a restricted area to identify when a person wearing a beacon tag 502 enters (or approaches) the restricted area. In one embodiment, the hub module 506 includes a system-on-a-chip (SOC) 528 to manage components of the hub module 506, one or more power sources 530 (e.g., one or more batteries and an external power source (e.g., an AC/DC connection)) to extend the battery life and capabilities of the beacon badge 504, one or more sensors 532 communicatively coupled to the SOC 528, and a badge connection 534 for connecting the beacon badge 504 to the hub module 506.
[0111] In the illustrated example, the beacon badge 504 may be connectable (e.g., mechanically coupled, electronically coupled, etc.) to the example dock module 508. In the illustrated example, the dock module 508 may be used to charge one or more beacon badges 504. Accordingly, and in one embodiment, the dock module 508 includes an external power connector 536 (e.g., an AC connector), a charging indicator 538 to indicate whether the beacon badge 504 is charged or charging, and a badge connection 540 for connecting the beacon badge 504 to the dock module 508. In one embodiment, the dock module 508 is portable. For example, the dock module 508 may be placed throughout one or more environments, such as at cash registers, podiums, counters, nursing stations, break rooms, hallways, etc., and a caregiver may couple their beacon badge 504 to the dock module 508, via a badge connection 540, when they are off-duty.
[0112]
[0113] The beacons 608, 610 are detected and read (e.g., via Bluetooth, Bluetooth Low Energy (BLE), near field communication (NFC), etc.) by one or more mobile receivers 612 and/or fixed receivers 614, for example. For example, the mobile receiver 612 includes logic to process its location (e.g., with respect to the fixed beacon 608, etc.). The mobile receiver 612 can be worn by a person and/or mobile asset to create a crowdsourced environment in which the mobile receiver 612 interacts with beacons 608, 610 and informs the system 600 of the receiver 612 location and presence of beacon(s) 608, 610 within range of the location, for example. The fixed receiver 614 is configured with its location in the facility 602. The fixed receiver 614 can be mounted on a wall in a location where crowdsourcing is reduced (e.g., storage locations, enclosed locations, etc.) to interact with beacons 608, 610 and inform the system 600 of the receiver 614 location and presence of beacon(s) 608, 610 within range of the location, for example. The mobile receiver(s) 612 and fixed receiver(s) 614 process which asset(s) are located within range (e.g., as indicated mobile beacon(s) 610 and/or fixed beacon(s) 608, etc.) and notify other component(s) of the system 600.
[0114] The receiver(s) 612, 614 communicate over a channel 616, such as Wi-Fi, etc., with a middleware gateway 618 to transmit information regarding beacon 608, 610 location to a middleware engine 620. The middleware gateway 618 can be an edge device, gateway device, hub, and/or other electronic device to interface between the premises 602 and the cloud 606, for example. The middleware engine 620 can reside on the cloud 606 to process received beacon 608, 610 and receiver 612, 614 data and calculate location information. The middleware engine 620 can also publish location events to one or more receiving/subscribing recipients, for example.
[0115] For example, one or more consuming applications 622 access location data from the middleware engine 620 via the cloud 606 to leverage the location data for scheduling, tracking, (re)ordering, maintenance, billing, protocol compliance, treatment evaluation, employee evaluation, resource evaluation, and/or other resource management application(s), etc. Alternatively or in addition, an application programming interface (API) 624 provides location awareness data for consumption by one or more hospital applications 626-632 at a second facility (e.g., hospital, clinic, etc.) 604. For example, a hospital computerized maintenance management system (CMMS) 626, a hospital bed management system 628, and/or other hospital system 630, hospital application 632, etc., can receive and process asset location information via the API 624.
[0116]
[0117] Additionally, firmware 704 can communicate with the badge 714 to update firmware, settings, etc., on the badge 714. The example firmware 704 can provide and/or be associated with a software development kit (SDK) to enable integration of application(s) into the badge 714, for example. Using the SDK, the firmware 704 can provide notifications, offers, and/or other customizations to the badge 714 and/or a user/wearer of the badge 714, for example.
[0118] The example hospital network 602 of
[0119] The example hospital network 602 of
[0120] The client location gateway 618a communicates with the server location gateway 618b at the cloud 606. The client location gateway 618a also communicates with a middleware engine 620 such as a locationing server 620. The example server 620 provides a plurality of features including a management user interface (UI), a system health monitor, configuration information, insights/analytics, etc. The example server 620 communicates with beacon/site management services 720 and a site builder 724, which helps to map out a location (e.g., the hospital network 602, etc.) and beacons found at the location.
[0121] Using a service bus 722, the server location gateway 618b, beacon/site management services 720, and/or the site builder 724 can communicate with a geographic information system (GIS) 726 to create map(s) of the facility 602 to be stored using georeferenced location coordinates, for example. Fixed receivers placed in the facility 602 can be identified and added to the map using the site builder 724 and GIS 726. A location engine 728 can be used to leverage the map(s) and geographic information to associate location(s) with detected beacon events to derive a location for a particular asset, for example. Using the GIS 726 and site builder 724, maps can be modified/updated in real time (or substantially real time given some data processing, transmission, and/or storage latency, etc.) to make fast, fluid changes based on incoming data, for example. The GIS 726 provides spatial context to the inside of the facility 602 mapped by the site builder 724, for example. Using the GIS 726 platform, distance(s) between objects can be derived and georeferenced coordinates can be included. Information generated by the location engine 728 can be consumed by one or more products 732 including asset management 734, hospital information system (HIS) 736, and/or other third party system 738, etc. Badge configuration services 730 can also help with badge configuration on the server/cloud side, helping to update the badge configuration tool 702 at the hospital 602, for example.
[0122] Thus, certain examples provide systems and methods to monitor and manage badge(s), beacon(s), and receiver(s) and provide health statistics for such devices. Certain examples provide APIs that allow devices installed at a location to communicate status information to the cloud 606 infrastructure to be processed to display reports, analytics, facilitate interaction for repair/update, etc., to drive notifications, alerts, maintenance, etc., for system health and ongoing system operation. Certain examples facilitate monitoring and evaluation of network and system performance and retuning/reconfiguring/redefining desired network and/or system operation.
[0123] More generally,
[0124] The cloud health processor 830 defines a mechanism and associated API specification by which location receivers 612, 614, 710 deployed as part of a real time location platform 600, 700 can transmit system health information using an event-based messaging framework. The data/events provided can be captured and utilized to maintain the system 600, 700 and help ensure optimal and/or otherwise improved performance
[0125] In certain examples, given numerous dependencies, connectivity issues, and power concerns, the system 800 is configured such that the devices 802-806 self-report their health status and associated system events to the health processor 830 via the edge device 810 to help maintain a functional system 600, 700, 800. For example, location devices 802-806 are designed to submit event data (e.g., JSON documents, and/or other format/protocol such as XML, CSV, HTTP, JMS, SMTP, etc.) via the edge device 810 to an interface (e.g., a RESTful service interface, etc.) at the health processor 830.
[0126] A plurality of events can be defined. An event includes a set of base (e.g., header, etc.) attributes that are used for ongoing system health management. In addition, each event includes a details section in which attributes/data specific to an event type can be included. For example, numerous events can be defined, and these events can be sent in response to a specified condition (e.g., device regaining network connectivity, e.g., device placed on charger, e.g., device removed from charger, etc.) and/or on a time schedule that is configurable as part of the device profile. The following table provides some examples of receiver health-related events:
TABLE-US-00001 Event Occurrence/Trigger On Charge When a badge is placed on charge Off Charge When a badge is taken off charge Forced Reboot When the badge operating system restarts Unforced Reboot/ When the badge operating restarts after a system error System Error WiFi Reconnect When the badge reconnects to WiFi not associated with a reboot event Heartbeat When the receiver profile configured time interval has elapsed
[0127] Thus, each receiver transmits health/operating details to the processor 830 via the API (e.g., API 624, etc.) when associated events are executed. In certain examples, a WiFi reconnect does not include a roaming and/or access point transition for a mobile receiver. In certain examples, a heartbeat timer restarts on device reboot. In certain examples, a heartbeat interval is set to be frequent enough to monitor temperature changes, eliminating a need for temperature threshold events, for example.
[0128] In certain examples, a service interface (e.g., API) specification can be provided, such as for a RESTful service, etc., used by device(s) 802-806 to post health events. The service interface can define a health API and/or a reference API that provides definition for location events, time, firmware updates, system health, receiver configuration, etc. For example, a location event request can be formatted as a JSON object to include a beacon MAC address, UUID, RSSI, battery life (e.g., percentage of battery life remaining, battery value, etc.), timestamp (e.g., a time at which the beacon event was received, etc.), receiver MAC address, etc. A get time request can be implemented as a JSON formatted object including a time, such as a UNIX time, POSIX time, Epoch time, UTC time, etc., for example. A firmware update can be implemented as a binary file providing an application/octet stream to a target device 802-806, for example. A system health request can be implemented, for example, as a JSON formatted object including an event type, device MAC address, timestamp, firmware version, depth of discharge (e.g., percent of battery life remaining, etc.), temperature (e.g., device temperature in Fahrenheit, Celsius, etc.), details (e.g., any additional details provided for the event), etc. A receiver configuration request can be implemented, for example, as a JSON formatted object including a scan interval (e.g., a period of time for which received beacons are being evaluated to determine which beacons should be transmitted, etc.), a scan channel (e.g., BLE channel(s) on which the device should listen, etc.), heartbeat interval, WiFi transmission frequency, profile name/ID, beacon type, proximity range, RSSI low (e.g., weakest RSSI signal strength considered within the range that a beacon should be processed, etc.), RSSI high (e.g., strongest RSSI signal strength considered within the range that a beacon should be processed, etc.), beacon hit count (e.g., a number of beacon hits required to be received within a scan interval, etc.), scan retention interval (e.g., a number of scans that occur before results of a scan are stored for transmission, etc.), send closest only (e.g., if true, all beacons received within the given range will be transmitted by the device, else only the closest (e.g., highest RSSI value) beacon is to be transmitted, etc.), suppress repeats (e.g., if true, transmissions from the device will be suppressed if they are the same as the previous scan interval, etc.), time service URL (e.g., uniform resource locator exposing the time service, etc.), event service URL (e.g., uniform resource locator exposing the event service, etc.), firmware service URL (e.g., uniform resource locator exposing the firmware service, etc.), firmware filename, etc.
[0129] The quality of location data provided by the real time location platform 600, 700 is dependent on the health of the devices deployed to receive sensory/location events. If the deployed devices are not functioning as intended, the location data produced by the system has the potential to be inaccurate/unreliable. To help ensure accurate location data, support system(s) and/or team(s) (e.g., health processor 830 and management service 840) must be able to monitor system health, isolate problematic devices and correct the problems through reconfiguration, replacement, upgrade, etc. Thus, certain examples provide a centralized health and monitoring capability for large scale systems that include many thousands of devices deployed in a wide range of environments. Without this system, deployed systems would fall into disrepair over time and/or the costs of monitoring/maintaining such systems would threaten the commercial viability of the dependent products. Certain examples monitor system health and provide maintenance/solutions to enable improved system performance, higher customer satisfaction, higher return on investment for a customer, lower cost of ownership for the customer, lower support costs for a supplier, increased profit margin for the supplier, etc.
[0130]
[0131] The example message receiver 910 monitors for a message from a receiver (e.g., from one or more devices 802-806 including one or more beacons, badges, and/or receivers 608, 610, 612, 614, 708, 710, 712, 714, 716, 718, etc.). When a message is received, the example message evaluator 920 evaluates the received message to determine a message type associated with the message (e.g., location message, firmware message, time message, receiver configuration message, health message, etc.). If the message is not a receiver health message, then, the message evaluator 920 sends the message to another processor, such as the location engine 728, site builder 724, consuming product(s) 732, etc.
[0132] If the message is a health message, then the message evaluator 920 sends the message to the event processor 930. The example event processor 930 processes the health message to identify an event type indicated by the message. For example, the message may indicate an on charge event, off charge event, forced reboot event, unforced reboot/system error event, WiFi reconnect event, heartbeat event, etc. Based on the event type, the event processor 930 processes the details of the event.
[0133] The event processor 930 provides the message details and event type to the health analyzer. Based on the event type, the example health analyzer 940 compares the details of the event to a threshold, range, standard, norm, etc. If the event is within normal or expected behavior, the event can be logged via the output generator 960. If the event is outside the prescribed bound(s), the health alert notifier 950 can be triggered in response to the event. In some examples, the health alert notifier 950 can generate a response message or instruction to the device via the output generator 960 to adjust a level, setting, mode, etc., in response to the event (e.g., not charging enough, not charging properly, irregular heartbeat, reboot needed, etc.) such as to send a message to a user, automatically adjust a device setting, trigger a maintenance request, alert hospital staff to a failing device, change in setting/configuration warranted, etc. Thus, the output generator 960 can provide an update and/or other message to the device and/or a third party (e.g., beacon/site management services 720, badge configuration services 730, consuming product(s) 732, etc.) to repair, replace, and/or adjust the affected device(s). An alert, update, and/or other message can be generated to help ensure reliable operation and uptime of the RTLS system 600, 700, for example.
[0134] While example implementations of the systems 100, 200, 300, 400, 600, 700, 800, 900 are illustrated in
[0135] A flowchart representative of example machine readable instructions for implementing the systems of
[0136] As mentioned above, the example process(es) of
[0137]
[0138] If the message is a health message, then, at block 1010, the health message is processed to identify an event type indicated by the health message. For example, the message evaluator 920 sends the message to the event processor 930. The example event processor 930 processes the health message to identify an event type indicated by the message. For example, the message may indicate an on charge event, off charge event, forced reboot event, unforced reboot/system error event, WiFi reconnect event, heartbeat event, etc. At block 1012, based on the event type, the event processor 930 processes the details of the event. For example, the event processor 930 digests information associated with the event type and additional details if provided in the message.
[0139] At block 1014, the event is compared to prescribed bound(s) for the event. For example, the event processor 930 provides the message details and event type to the health analyzer. Based on the event type, the example health analyzer 940 compares the details of the event to a threshold, range, standard, norm, etc. At block 1016, if the event is within normal or expected behavior, the event is logged. For example, the event can be logged via the output generator 960. At block 1018, if the event is outside the prescribed bound(s), a response to the event is triggered. For example, the health alert notifier 950 can be triggered in response to the event. In some examples, the health alert notifier 950 can generate a response message or instruction to the device via the output generator 960 to adjust a level, setting, mode, etc., in response to the event (e.g., not charging enough, not charging properly, irregular heartbeat, reboot needed, etc.) such as to send a message to a user, automatically adjust a device setting, trigger a maintenance request, alert hospital staff to a failing device, change in setting/configuration warranted, etc. At block 1020, an output is provided. For example, the output generator 960 can provide an update and/or other message to the device and/or a third party (e.g., beacon/site management services 720, badge configuration services 730, consuming product(s) 732, etc.) to repair, replace, and/or adjust the affected device(s). An alert, update, and/or other message can be generated to help ensure reliable operation and uptime of the RTLS system 600, 700, for example.
[0140]
[0141] The processor platform 1100 of the illustrated example includes a processor 1112. The processor 1112 of the illustrated example is hardware. For example, the processor 1112 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer.
[0142] The processor 1112 of the illustrated example includes a local memory 1113 (e.g., a cache). The processor 1112 of the illustrated example executes the instructions to implement the example message receiver 910, the example message evaluator 920, the example event processor 930, the example health analyzer 940, the example health alert notifier 950, the example output generator 960, and/or, more generally, the example health processor of
[0143] The processor platform 1100 of the illustrated example also includes an interface circuit 1120. The interface circuit 1120 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
[0144] In the illustrated example, one or more input devices 1122 are connected to the interface circuit 1120. The input device(s) 1122 permit(s) a user to enter data and commands into the processor 1112. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, isopoint and/or a voice recognition system.
[0145] One or more output devices 1124 are also connected to the interface circuit 1120 of the illustrated example. The output devices 1124 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a printer and/or speakers). The interface circuit 1120 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
[0146] The interface circuit 1120 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 1126 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
[0147] The processor platform 1100 of the illustrated example also includes one or more mass storage devices 1128 for storing software and/or data. Examples of such mass storage devices 1128 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives.
[0148] The coded instructions 1132 of
[0149] Thus, certain examples communicate via messages or beacon communications to provide status information, location information, firmware upgrade, etc. Certain examples provide a custom beacon protocol (e.g., a custom BLE beacon protocol, etc.) that provides all involved fields for message processing and location determination, as well as system health status including low battery indication (e.g., in days remaining, hours remaining, percent remaining, battery value, etc.), custom fields for additional installation specific data (e.g., profile identifier (ID), floor designation, department ID, etc.), beacon security, and/or other item(s). While no single existing protocol fulfills these needs, certain examples provide a new protocol that enable location systems to provide customers with system health and security information/messaging and also enable additional device level functionality by allowing custom data within the protocol. Certain examples provide a protocol including data encryption as well as battery life information, system health information, location information, and/or other custom information. Using this protocol, the health processor 830, management services 840, edge device 810, location gateway 618, location server 620, badge configuration tool 702, firmware 704, location toolbox app 706, beacon/site management services 720, site builder 724, GIS 726, location engine 728, badge configuration services 730, consuming products 732, etc., can communicate and use the protocol to transmit and/or receive a plurality of information.
[0150] For example, a BLE proximity-sensing protocol can transmit a UUID along with several additional bytes to determine a device's physical location, track device movement, trigger a location-based action on the device, gauge device health, update device firmware, etc., via push and/or pull communication. Certain examples provide a protocol with a plurality of frame types that can be used individually and/or in various combinations to communication information from a beacon to a receiver. For example, a frame can include an identifier, a type, a flag, a length, a data value, an encrypted value, etc. A frame can include a variable data value and an indication of how the receiver is to interpret that value.
[0151] Certain examples can specify a security type (e.g., WPA-Enterprise, etc.), an encryption type (e.g., TKIP, etc.), an authentication method (e.g., Cisco: PEAP, etc.), authentication credentials (e.g., username/password, certificate, etc.), gateway host, gateway port, etc. Profile and proximity range can also be defined, for example. Configuration setting and corresponding BLE channel(s) can also be defined, for example. Other parameters such as location beacon broadcast, badge scan profile indicator, proximity range identifier, transmit interval, transmit window, hit count, suppress repetitive, etc., can be defined according to the protocol, for example.
[0152] From the foregoing, it will appreciate that the above disclosed methods, apparatus and articles of manufacture facilitate proximity detection and location tracking of assets in an industrial setting. As described above, example disclosures uniquely eliminate the expensive and difficult-to-maintain infrastructure. An example benefit of the disclosed techniques includes determining location awareness of assets in the industrial setting without constructing a new infrastructure. In some disclosed examples, the location awareness of assets is determined by crowd-sourcing probability proximity locations of the assets.
[0153] Although certain example methods, apparatus and articles of manufacture have been disclosed herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the claims of this patent.