The present disclosure relates to electronics. More particularly, this disclosure relates to a wireless protocol for sensing systems.
Vehicles may use a variety of sensors to monitor the health and performance of various components. For example, sensors in an engine may be used to monitor the health of the engine. As another example, sensors coupled to batteries may be used to monitor the health and charge of the battery. In the case of electric vehicles that are powered by an array of battery cells, each cell or module of cells may have its own sensor. Thus, a vehicle may have multiple sensors needing to transmit sensor data for analysis.
In a particular embodiment, a method for utilizing a wireless protocol in a sensing system is disclosed that includes a wireless network controller (WNC) sending to a plurality of wireless sensor nodes, based on a time division multiple access (TDMA), a synchronization message. The method also includes the wireless network controller receiving, based on the TDMA, first sensor data from each wireless sensor node of the plurality of wireless sensor nodes.
In a particular embodiment, a sensing system that utilizes a wireless protocol is disclosed that includes a plurality of wireless sensor nodes and a wireless network controller (WNC). In the sensing system, the wireless network controller is configured to send to the plurality of wireless sensor nodes, based on a time division multiple access (TDMA), a synchronization message. The wireless network controller is also configured to receive, based on the TDMA, first sensor data from each wireless sensor node of the plurality of wireless sensor nodes.
As will be explained in greater detail below, the synchronization message may be used for network synchronization between the WNC and the wireless sensor nodes, so that each wireless sensor node provides sensor data to the wireless network controller in accordance with the correct TDMA. Because the wireless sensor nodes transmit and the wireless network controller receives sensor data based on TDMA, communication between the wireless network controller and the wireless sensor nodes is improved.
The terminology used herein for the purpose of describing particular examples is not intended to be limiting for further examples. Whenever a singular form such as “a”, “an” and “the” is used and using only a single element is neither explicitly nor implicitly defined as being mandatory, further examples may also use plural elements to implement the same functionality. Likewise, when a functionality is subsequently described as being implemented using multiple elements, further examples may implement the same functionality using a single element or processing entity. It will be further understood that the terms “comprises”, “comprising”, “includes” and/or “including”, when used, specify the presence of the stated features, integers, steps, operations, processes, acts, elements and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, processes, acts, elements, components and/or any group thereof.
It will be understood that when an element is referred to as being “connected” or “coupled” to another element, the elements may be directly connected or coupled or via one or more intervening elements. If two elements A and B are combined using an “or”, this is to be understood to disclose all possible combinations, i.e., only A, only B, as well as A and B. An alternative wording for the same combinations is “at least one of A and B”. The same applies for combinations of more than two elements.
Accordingly, while further examples are capable of various modifications and alternative forms, some particular examples thereof are shown in the figures and will subsequently be described in detail. However, this detailed description does not limit further examples to the particular forms described. Further examples may cover all modifications, equivalents, and alternatives falling within the scope of the disclosure. Like numbers refer to like or similar elements throughout the description of the figures, which may be implemented identically or in modified form when compared to one another while providing for the same or a similar functionality.
The sensing system 100 of
The WNC 102 and WSNs 104a-n also each include a respective wireless transceiver 110. The wireless transceiver 110 includes a radio and/or antenna to facilitate transmissions between the WNC 102 and WSNs 104a-n. In some embodiments, the wireless transceivers 110 may include dual- or multi-channel radios to provide both hardware redundancy of radio and frequency channel diversity on the data link. Additional antennas (e.g., additional wireless transceivers 110) can be supported to provide more degrees of spatial diversity for improving the signal-to-noise ratio (SNR) of the link.
The WNC 102 includes an external interface 112 communicatively coupling the WNC 102 to an external device such as a vehicle control system or other external computing device. Each WSN 104a-n may include a sensor interface 114a-n. Each sensor interface 114a-n communicatively couples a WSN 104a-n to one or more external sensors (e.g., thermal sensors, light sensors, voltage or power systems, or any other sensor as can be appreciated). Alternatively, each WSN 104a-n may include the sensors themselves. Each WSN 104a-n may then generate and/or process sensor data based on measurements from their respective sensors.
The WNCs 102 and 104a-n are configured to communicate using a particular protocol. The protocol may be developed for energy efficient high reliability, low latency sensing systems including engine health monitoring for aerospace or nuclear applications, and battery monitoring in automotive and heavy vehicle off road (HVOR) markets. The protocol utilizes time division multiple access (TDMA) whereby messages are sent from the WNC 102 to the WSNs 104a-n. These SYNC messages are used for network synchronization and may provide network management functions such as frequency hopping information, and/or system specific commands. The WSNs 104a-n respond sequentially, each at its own time slot. For example, the SYNC message may indicate, to each of the WSNs 104a-n, a particular time slot for responding to the SYNC message or providing sensor data to the WNC 102. Each WSN 104a-n can correct its local system clock based on when it receives the SYNC message from the WNC 102.
In some embodiments, the WNC 102 implements a prescriptive hop, whereby all radio frequency channel hopping is controlled by the WNC 102. In some embodiments, the WNC 102 is configured to send, to each WSN 104a-n, the next few steps in the frequency hop sequence (FHS). The FHS enables simplified channel blacklisting (the mechanism of avoiding certain frequency channels due to poor performance or unwanted interference) as channels are simply omitted from the prescriptive hop sequence, and enables simple, reliable control of uniform, pseudo random, or random hop sequences. A benefit of the FHS to system performance is that each WSN 104a-n can continue to operate correctly and send its data to the WNC 102 for a period of time without receiving a SYNC message from the WNC, while maintaining frequency hopping and channel backlisting. This mechanism improves the reliability of the wireless link without decreasing the available network bandwidth necessary for sending retries of missed SYNC packets.
In some embodiments, the protocol can support counter with cipher block chaining message authentication code (CCM) or Galois/Counter Mode (GCM) encryption and cipher-based message authentication code (CMAC) generation utilizing Additional Authentication Data (AAD), with Elliptic-curve Diffie-Hellman (ECHD) key exchange. For example,
For further explanation,
In some embodiments, sending 402 the SYNC message includes sending 402 the SYNC message at a predetermined frequency. For example, where the SYNC message is the first SYNC message to be sent from the WNC 102 to the WSNs 104a-n, the WNC 102 may send the SYNC message at a predefined or default frequency, or a last used frequency. In some embodiments, the SYNC message is sent at a current frequency in a frequency hop sequence (FHS). For example, in some embodiments, a SYNC message will indicate, to the WSNs 104a-n, the FHS. After the WSNs 104a-n and WNC 102 change their operational frequencies to the next frequency in the FHS, a next sent SYNC message will be sent via the new operational frequency. In some embodiments, the SYNC message will indicate multiple frequencies in the FHS (e.g., N frequencies). Accordingly, in some embodiments, the SYNC message will only be sent after WSNs 104a-n and WNC 102 have changed to the last frequency in the FHS, or after having changed to some other defined index in the FHS (e.g., after having changed to the N−1st frequency in the FHS).
In some embodiments, the SYNC message includes TDMA data indicating a particular time slot for each WSN 104a-n to send sensor data to the WNC 102. For example, assuming sixteen WSNs 104a-n, the SYNC message may indicate, for each WSN 104a-n, one of sixteen time slots for sending sensor data to the WNC 102. A time slot for sending sensor data to the WNC 102 is a subdivision of a time window for collecting sensor data by the WNC 102 (e.g., a time slot 208 of
The method of
For further explanation,
For further explanation,
For further explanation,
For further explanation,
In view of the explanations set forth above, readers will recognize that the benefits of a wireless protocol for sensing systems include:
Exemplary embodiments of the present disclosure are described largely in the context of a fully functional computer system utilizing a wireless protocol for sensing systems. Readers of skill in the art will recognize, however, that the present disclosure also can be embodied in a computer program product disposed upon computer readable storage media for use with any suitable data processing system. Such computer readable storage media can be any storage medium for machine-readable information, including magnetic media, optical media, or other suitable media. Examples of such media include magnetic disks in hard drives or diskettes, compact disks for optical drives, magnetic tape, and others as will occur to those of skill in the art. Persons skilled in the art will immediately recognize that any computer system having suitable programming means will be capable of executing the steps of the method of the disclosure as embodied in a computer program product. Persons skilled in the art will recognize also that, although some of the exemplary embodiments described in this specification are oriented to software installed and executing on computer hardware, nevertheless, alternative embodiments implemented as firmware or as hardware are well within the scope of the present disclosure.
The present disclosure can be a system, a method, and/or a computer program product. The computer program product can include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present disclosure.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium can be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM) or Flash memory, a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network can include copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present disclosure can be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions can execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer can be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection can be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) can execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present disclosure.
Aspects of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions can be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions can also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein includes an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions can also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams can represent a module, segment, or portion of instructions, which includes one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block can occur out of the order noted in the figures. For example, two blocks shown in succession can, in fact, be executed substantially concurrently, or the blocks can sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Advantages and features of the present disclosure can be further described by the following statements:
1. A method, apparatus, system, computer program product, non-transitory medium for a wireless protocol in a sensing system, the method, apparatus, system, computer program product, non-transitory medium including sending, by a wireless network controller (WNC), to a plurality of wireless sensor nodes, based on a time division multiple access (TDMA), a synchronization message; and receiving, by the WNC, based on the TDMA, first sensor data from each wireless sensor node of the plurality of wireless sensor nodes.
2. The method, apparatus, system, computer program product, non-transitory medium of statement 1, wherein the synchronization message includes a frequency hop sequence indicating a plurality of frequency channels, and the method further comprises switching, by the WNC and the plurality of wireless sensor nodes, a communication frequency based on a next frequency channel in the frequency hop sequence.
3. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1 and 2, wherein the frequency hop sequence comprises a random sequence, a pseudorandom sequence, or a uniform sequence.
4. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-3, further comprising receiving, by the WNC, based on the TDMA, second sensor data from each wireless sensor node of the plurality of wireless sensor nodes via the next frequency channel.
5. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-4, wherein the second sensor data is received without the WNC sending another synchronization message after switching the communication frequency.
6. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-5, further comprising synchronizing, by the plurality of wireless sensor nodes, a corresponding clock based on the synchronization message.
7. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-6, further comprising performing a key exchange between the WNC and the plurality of wireless sensor nodes.
8. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-7, wherein at least one of the synchronization message and the sensor data comprise one or message authentication codes based on an exchanged key.
9. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-8, wherein the key exchange comprises a Elliptic-curve Diffie-Hellman (ECHD) key exchange.
10. The method, apparatus, system, computer program product, non-transitory medium of any of statements 1-9, wherein the one or more message authentication codes comprise a cipher block chaining message authentication code (CCM) cipher-based message authentication code (CMAC).
11. A sensing system utilizing a wireless protocol, the sensing system comprising: a plurality of wireless sensor nodes; and a wireless network controller (WNC) configured to perform steps comprising: sending to the plurality of wireless sensor nodes, based on a time division multiple access (TDMA), a synchronization message; and receiving, based on the TDMA, first sensor data from each wireless sensor node of the plurality of wireless sensor nodes.
12. The sensing system of statement 11, wherein the synchronization message includes a frequency hop sequence indicating a plurality of frequency channels, and the steps further comprise switching, by the WNC and the plurality of wireless sensor nodes, a communication frequency based on a next frequency channel in the frequency hop sequence.
13. The sensing system of any of statements 11 and 12, wherein the frequency hop sequence comprises a random sequence, a pseudorandom sequence, or a uniform sequence.
14. The sensing system of any of statements 11-13, wherein the steps further comprise receiving, by the WNC, based on the TDMA, second sensor data from each wireless sensor node of the plurality of wireless sensor nodes via the next frequency channel.
15. The sensing system of any of statements 11-14, wherein the second sensor data is received without the WNC sending another synchronization message after switching the communication frequency.
16. The sensing system of any of statements 11-15, wherein the steps further comprise synchronizing, by the plurality of wireless sensor nodes, a corresponding clock based on the synchronization message.
17. The sensing system of any of statements 11-16, wherein the steps further comprise performing a key exchange between the WNC and the plurality of wireless sensor nodes.
18. The sensing system of any of statements 11-17, wherein at least one of the synchronization message and the sensor data comprise one or message authentication codes based on an exchanged key.
19. The sensing system of any of statements 11-18, wherein the key exchange comprises a Elliptic-curve Diffie-Hellman (ECHD) key exchange.
20. The sensing system of any of statements 11-19, wherein the one or more message authentication codes comprise a cipher block chaining message authentication code (CCM) cipher-based message authentication code (CMAC).
One or more embodiments may be described herein with the aid of method steps illustrating the performance of specified functions and relationships thereof. The boundaries and sequence of these functional building blocks and method steps have been arbitrarily defined herein for convenience of description. Alternate boundaries and sequences can be defined so long as the specified functions and relationships are appropriately performed. Any such alternate boundaries or sequences are thus within the scope and spirit of the claims. Further, the boundaries of these functional building blocks have been arbitrarily defined for convenience of description. Alternate boundaries could be defined as long as the certain significant functions are appropriately performed. Similarly, flow diagram blocks may also have been arbitrarily defined herein to illustrate certain significant functionality.
To the extent used, the flow diagram block boundaries and sequence could have been defined otherwise and still perform the certain significant functionality. Such alternate definitions of both functional building blocks and flow diagram blocks and sequences are thus within the scope and spirit of the claims. One of average skill in the art will also recognize that the functional building blocks, and other illustrative blocks, modules and components herein, can be implemented as illustrated or by discrete components, application specific integrated circuits, processors executing appropriate software and the like or any combination thereof.
While particular combinations of various functions and features of the one or more embodiments are expressly described herein, other combinations of these features and functions are likewise possible. The present disclosure is not limited by the particular examples disclosed herein and expressly incorporates these other combinations.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2021/014492 | 1/22/2021 | WO |
Number | Date | Country | |
---|---|---|---|
62976751 | Feb 2020 | US |