US20200178033A1 - Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability - Google Patents

Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability Download PDF

Info

Publication number
US20200178033A1
US20200178033A1 US16/669,177 US201916669177A US2020178033A1 US 20200178033 A1 US20200178033 A1 US 20200178033A1 US 201916669177 A US201916669177 A US 201916669177A US 2020178033 A1 US2020178033 A1 US 2020178033A1
Authority
US
United States
Prior art keywords
motion
wireless
wireless communication
probability vector
values
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US16/669,177
Inventor
Mohammad Omer
Stephen Arnold Devison
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Cognitive Systems Corp
Original Assignee
Cognitive Systems Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Cognitive Systems Corp filed Critical Cognitive Systems Corp
Priority to US16/669,177 priority Critical patent/US20200178033A1/en
Publication of US20200178033A1 publication Critical patent/US20200178033A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0278Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves involving statistical or probabilistic considerations
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/80Services using short range communication, e.g. near-field communication [NFC], radio-frequency identification [RFID] or low energy communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • H04W4/029Location-based management or tracking services
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/01Determining conditions which influence positioning, e.g. radio environment, state of motion or energy consumption
    • G01S5/014Identifying transitions between environments
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W64/00Locating users or terminals or network equipment for network management purposes, e.g. mobility management
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S13/00Systems using the reflection or reradiation of radio waves, e.g. radar systems; Analogous systems using reflection or reradiation of waves whose nature or wavelength is irrelevant or unspecified
    • G01S13/003Bistatic radar systems; Multistatic radar systems
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S7/00Details of systems according to groups G01S13/00, G01S15/00, G01S17/00
    • G01S7/003Transmission of data between radar, sonar or lidar systems and remote stations
    • G01S7/006Transmission of data between radar, sonar or lidar systems and remote stations using shared front-end circuitry, e.g. antennas
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/30Services specially adapted for particular environments, situations or purposes
    • H04W4/33Services specially adapted for particular environments, situations or purposes for indoor environments, e.g. buildings

Definitions

  • the following description relates to determining a location of motion detected from wireless signals.
  • Motion detection systems have been used to detect movement, for example, of objects in a room or an outdoor area.
  • infrared or optical sensors are used to detect movement of objects in the sensor's field of view.
  • Motion detection systems have been used in security systems, automated control systems and other types of systems.
  • FIG. 1 is a diagram showing an example wireless communication system.
  • FIGS. 2A and 2B are diagrams showing example wireless signals communicated between wireless communication devices in a motion detection system.
  • FIG. 3 is a schematic diagram of an example wireless communication network that includes a plurality of wireless nodes.
  • FIG. 4 is a schematic graph of an example probability map having map values that are based on a wireless node's status as a transmitting wireless node (Tx), a receiving wireless node (Rx), or other wireless node.
  • Tx transmitting wireless node
  • Rx receiving wireless node
  • FIG. 5 is a schematic diagram of an example multi-path propagation environment between a transmitting wireless node and a receiving wireless node.
  • FIG. 6 is a flowchart of an example process for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • FIG. 7 is a schematic diagram of an example wireless communication network in which dashed arrows indicate potential transitions of detected motion between wireless nodes.
  • FIG. 8 is a flowchart of another example process for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • the location of motion in a space may be detected using information from multiple wireless communication devices communicating with each other wirelessly.
  • wireless signals received at each of the wireless communication devices in a wireless communication network may be analyzed to determine channel information for the different communication links in the network (between respective pairs of wireless communication devices in the network).
  • the channel information may be representative of a physical medium that applies a transfer function to wireless signals that traverse the space.
  • the channel information includes channel response information.
  • Channel response information may refer to known channel properties of a communication link, and may describe how a wireless signal propagates from a transmitter to a receiver, representing the combined effect of, for example, scattering, fading, and power decay within the space between the transmitter and receiver.
  • the channel information includes beamforming state information.
  • Beamforming may refer to a signal processing technique used in multi antenna (multiple-input/multiple-output (MIMO)) radio systems for directional signal transmission or reception. Beamforming can be achieved by combining elements in an antenna array in such a way that signals at particular angles experience constructive interference while others experience destructive interference. Beamforming can be used at both the transmitting and receiving ends in order to achieve spatial selectivity.
  • a beamforming steering matrix is used by a transmitter.
  • the beamforming steering matrix may include a mathematical description of how the antenna array should use each of its individual antenna elements to select a spatial path for transmission. While certain aspects are described herein with respect to channel response information, beamforming state information or beamformer steering matrix state may also be used in the aspects described as well.
  • the channel information for each of the communication links may be analyzed (e.g., by a hub device or other device in the network, or a remote device communicably coupled to the network) to detect whether motion has occurred in the space, to determine a relative location of the detected motion, or both.
  • the channel information for each of the communication links may be analyzed to detect whether an object is present or absent, e.g., when no motion is detected in the space.
  • the wireless communication network may include a wireless mesh network.
  • a wireless mesh network may refer to a decentralized wireless network whose nodes (e.g. wireless communication devices) communicate directly in a point-to-point manner without using a central access point, base station or network controller.
  • Wireless mesh networks may include mesh clients, mesh routers, or mesh gateways.
  • a wireless mesh network is based on the IEEE 802.11s standard.
  • a wireless mesh network is based on Wi-Fi ad hoc or another standardized technology. Examples of commercially-available wireless mesh networks include Wi-Fi systems sold by Google, Eero, and others.
  • each node is connected to one or more other nodes through one or more bi-directional links.
  • Each node can analyze the wireless signals that it receives to identify the perturbation or disturbance on each of the links.
  • the disturbance on each link can be represented as a motion indicator value, for example, as a scalar quantity that can be normalized.
  • the link disturbance values from the nodes in the wireless communication network can be used to determine the probability of motion at the locations associated with the respective node. For example, the probability of motion at each node can be used to tell which node has the highest probability of having motion in its vicinity, and that node can be identified as the node around which the motion occurred.
  • the analysis can be case in a Bayesian estimation framework, for the recursive computation of probabilities.
  • the probabilistic framework offers a number of technical advantages, for example, providing recursive estimation and hence eventual convergence to a correct result, simplistic logic with no conditions for each special situation, performance that is more accurate and robust (e.g., to artifacts) and others.
  • physical insights regarding the motion detection system can inform the Bayesian estimation framework that is used to detect the location of motion. For example, the relative magnitude of excitation on a link (between a transmitter node and receiver node) is likely to be greater when the motion that creates the excitation is nearer the receiver node. Accordingly, as an initial probability estimate for where motion occurred, the highest probabilities can be assigned to the receiver nodes on wireless links associated with the highest motion indicator values. This initial probability estimate can be combined with a conditional probability distribution (e.g., based on prior motion data) to produce a recursively refined probability estimate according to a Bayesian framework.
  • a conditional probability distribution e.g., based on prior motion data
  • the likelihood of motion transitioning between distinct locations can be higher or lower, relative to the likelihood of motion remaining in a single location.
  • location transition probabilities can be incorporated into the Bayesian framework.
  • a transition probability matrix can be combined with the initial probability estimate and the conditional probability distribution to produce the recursively refined probability estimate according to the Bayesian framework.
  • FIG. 1 is a diagram showing an example wireless communication system 100 .
  • the example wireless communication system 100 includes three wireless communication devices—a first wireless communication device 102 A, a second wireless communication device 102 B, and a third wireless communication device 102 C.
  • the example wireless communication system 100 may include additional wireless communication devices 102 and/or other components (e.g., one or more network servers, network routers, network switches, cables, or other communication links, etc.).
  • the example wireless communication devices 102 A, 102 B, 102 C can operate in a wireless network, for example, according to a wireless network standard or another type of wireless communication protocol.
  • the wireless network may be configured to operate as a Wireless Local Area Network (WLAN), a Personal Area Network (PAN), a metropolitan area network (MAN), or another type of wireless network.
  • WLANs include networks configured to operate according to one or more of the 802.11 family of standards developed by IEEE (e.g., Wi-Fi networks), and others.
  • PANs include networks that operate according to short-range communication standards (e.g., BLUETOOTH®, Near Field Communication (NFC), ZigBee), millimeter wave communications, and others.
  • the wireless communication devices 102 A, 102 B, 102 C may be configured to communicate in a cellular network, for example, according to a cellular network standard.
  • cellular networks include networks configured according to 2G standards such as Global System for Mobile (GSM) and Enhanced Data rates for GSM Evolution (EDGE) or EGPRS; 3G standards such as Code Division Multiple Access (CDMA), Wideband Code Division Multiple Access (WCDMA), Universal Mobile Telecommunications System (UMTS), and Time Division Synchronous Code Division Multiple Access (TD-SCDMA); 4G standards such as Long-Term Evolution (LTE) and LTE-Advanced (LTE-A); 5G standards, and others.
  • the wireless communication devices 102 A, 102 B, 102 C can be, or may include, standard wireless network components.
  • the wireless communication devices 102 A, 102 B, 102 C may be commercially-available Wi-Fi devices.
  • the wireless communication devices 102 A, 102 B, 102 C may be Wi-Fi access points or another type of wireless access point (WAP).
  • the wireless communication devices 102 A, 102 B, 102 C may be configured to perform one or more operations as described herein that are embedded as instructions (e.g., software or firmware) on the wireless communication devices.
  • one or more of the wireless communication devices 102 A, 102 B, 102 C may be nodes of a wireless mesh network, such as, for example, a commercially-available mesh network system (e.g., Google Wi-Fi, Eero Wi-Fi systems, etc.).
  • a commercially-available mesh network system e.g., Google Wi-Fi, Eero Wi-Fi systems, etc.
  • another type of standard or conventional Wi-Fi transceiver device may be used.
  • the wireless communication devices 102 A, 102 B, 102 C may be implemented without Wi-Fi components; for example, other types of wireless protocols for wireless communication, either standard or non-standard, may be used for
  • the wireless communication devices transmit wireless signals over a communication channel (e.g., according to a wireless network standard, a motion detection protocol, a presence detection protocol, or other standard or non-standard protocol).
  • a communication channel e.g., according to a wireless network standard, a motion detection protocol, a presence detection protocol, or other standard or non-standard protocol.
  • the wireless communication devices may generate motion probe signals for transmission to probe a space to detect motion or presence of an object.
  • the motion probe signals may include standard signaling or communication frames that include standard pilot signals used in channel sounding (e.g., channel sounding for beamforming according to the IEEE 802.11ac-2013 standard).
  • the motion probe signals include reference signals known to all devices in the network.
  • one or more of the wireless communication devices may process motion detection signals, which are signals received based on motion probe signals transmitted through the space.
  • the motion detection signals may be analyzed to detect motion of an object in a space, lack of motion in the space, or the presence or absence of an object in the space when lack of motion is detected, based on changes (or lack thereof) detected in the communication channel.
  • the wireless communication devices transmitting motion probe signals may be referred to as source devices.
  • wireless communication devices 102 A, 102 B may broadcast the wireless motion probe signals (e.g., described above).
  • the wireless communication devices 102 A, 102 B may send wireless signals addressed to another wireless communication device 102 C and other devices (e.g., a user equipment, a client device, a server, etc.).
  • the wireless communication device 102 C as well as the other devices may receive the wireless signals transmitted by the wireless communication devices 102 A, 102 B.
  • the wireless signals transmitted by the wireless communication devices 102 A, 102 B are repeated periodically, for example, according to a wireless communication standard or otherwise.
  • the wireless communication device 102 C which may be referred to as a sensor device, processes the wireless signals received from the wireless communication devices 102 A, 102 B to detect motion, or lack of motion, of an object in a space accessed by the wireless signals.
  • another device or computing system processes the wireless signals received by the wireless communication device 102 C from the wireless communication devices 102 A, 102 B to detect motion, or lack of motion, of an object in a space accessed by the wireless signals.
  • the wireless communication device 102 C (or another system or device) processes the wireless signals to detect the presence or absence of an object in a space when lack of motion is detected.
  • the wireless communication device 102 C may perform one or more operations as described in relation to FIG. 6 or in the example method described method to FIG. 8 , or another type of process for detecting motion, detecting lack of motion, or detecting the presence or absence of an object when lack of motion is detected.
  • the wireless communication system 100 may be modified, for instance, such that the wireless communication device 102 C can transmit wireless signals, e.g. as a source device, and the wireless communication devices 102 A, 102 B may process the wireless signals, e.g. as sensor devices, from the wireless communication device 102 C, to detect motion, lack of motion, or presence when no motion is detected. That is, each of the wireless communication devices 102 A, 102 B, 102 C, may be configured, in some cases, as a source device, a sensor device, or both.
  • the wireless signals used for motion and/or presence detection can include, for example, a beacon signal (e.g., Bluetooth Beacons, Wi-Fi Beacons, other wireless beacon signals), pilot signals (e.g., pilot signals used for channel sounding, such as in beamforming applications, according to the IEEE 802.11ac-2013 standard), or another standard signal generated for other purposes according to a wireless network standard, or non-standard signals (e.g., random signals, reference signals, etc.) generated for motion and/or presence detection or other purposes.
  • a beacon signal e.g., Bluetooth Beacons, Wi-Fi Beacons, other wireless beacon signals
  • pilot signals e.g., pilot signals used for channel sounding, such as in beamforming applications, according to the IEEE 802.11ac-2013 standard
  • non-standard signals e.g., random signals, reference signals, etc.
  • the wireless signals may propagate through an object (e.g., a wall) before or after interacting with a moving object, which may allow the moving object's movement to be detected without an optical line-of-sight between the moving object and the transmission or receiving hardware.
  • the wireless signals when received by a wireless communication device, e.g. 102 C, may indicate lack of motion in a space, for example, that an object is not moving, or no longer moving, in the space.
  • the wireless signals when received by a wireless communication device, e.g. 102 C, may indicate the presence of an object in the space when lack of motion is detected. Conversely, the wireless signals may indicate the absence of an object in the space when lack of motion is detected.
  • the third wireless communication device 102 C may generate motion data, presence data, or both.
  • the third wireless communication device 102 C may communicate the motion detection and/or presence data, to another device or system, such as a security system, that may include a control center for monitoring movement within a space, such as a room, building, outdoor area, etc.
  • the wireless communication devices 102 A, 102 B may be configured to transmit motion probe signals (e.g., as described above) on a wireless communication channel separate from wireless network traffic signals (e.g., a frequency channel or coded channel).
  • a wireless communication channel separate from wireless network traffic signals (e.g., a frequency channel or coded channel).
  • the modulation applied to the payload of a motion probe signal and the type of data or data structure in the payload may be known by the third wireless communication device 102 C, which may reduce the amount of processing that the third wireless communication device 102 C performs for motion and presence detection.
  • the header may include additional information such as, for example, an indication of whether motion or lack of motion was detected by another device in the communication system 100 , whether a presence of an object was detected by another device in the communication system 100 , an indication of the modulation type, an identification of the device transmitting the signal, and so forth.
  • the wireless communication system 100 is illustrated as a wireless mesh network, with wireless communication links between each of the respective wireless communication devices 102 .
  • the wireless communication links between the third wireless communication device 102 C and the first wireless communication device 102 A can be used to probe a first motion detection zone 110 A
  • the wireless communication links between the third wireless communication device 102 C and the second wireless communication device 102 B can be used to probe a second motion detection zone 110 B
  • the wireless communication links between the first wireless communication device 102 A and the second wireless communication device 102 B can be used to probe a third motion detection zone 110 C.
  • each wireless communication device 102 may be configured to detect motion, lack of motion, and/or the presence or absence of an object when no motion is detected, in each of the motion detection zones 110 accessed by that device by processing received signals that are based on wireless signals transmitted by the wireless communication devices 102 through the motion detection zones 110 . For example, when a person 106 moves in the first motion detection zone 110 A and the third motion detection zone 110 C, the wireless communication devices 102 may detect the motion based on signals they receive that are based on wireless signals transmitted through the respective motion detection zones 110 .
  • the first wireless communication device 102 A can detect motion of the person in both the first and third motion detection zones 110 A, 110 C
  • the second wireless communication device 102 B can detect motion of the person 106 in the third motion detection zone 110 C
  • the third wireless communication device 102 C can detect motion of the person 106 in the first motion detection zone 110 A.
  • lack of motion by the person 106 and, in other cases, the presence of the person 106 when the person 106 is not detected to be moving may be detected in each of the motion detection zones 110 A, 110 B, 110 C.
  • the motion detection zones 110 can include, for example, air, solid materials, liquids, or another medium through which wireless electromagnetic signals may propagate.
  • the first motion detection zone 110 A provides a wireless communication channel between the first wireless communication device 102 A and the third wireless communication device 102 C
  • the second motion detection zone 110 B provides a wireless communication channel between the second wireless communication device 102 B and the third wireless communication device 102 C
  • the third motion detection zone 110 C provides a wireless communication channel between the first wireless communication device 102 A and the second wireless communication device 102 B.
  • wireless signals transmitted on a wireless communication channel are used to detect movement or lack of movement of an object in a space, and may be used to detect the presence (or absence) of an object in the space when there is a lack of movement detected.
  • the objects can be any type of static or moveable object, and can be living or inanimate.
  • the object can be a human (e.g., the person 106 shown in FIG. 1 ), an animal, an inorganic object, or another device, apparatus, or assembly, an object that defines all or part of the boundary of a space (e.g., a wall, door, window, etc.), or another type of object.
  • motion information from the wireless communication devices may trigger further analysis to determine the presence or absence of an object when motion of the object is not detected.
  • the wireless communication system 100 may be, or may include, a motion detection system.
  • the motion detection system may include one or more of the wireless communication devices 102 A, 102 B, 102 C and possibly other components.
  • One or more wireless communication devices 102 A, 102 B, 102 C in the motion detection system may be configured for motion detection, presence detection, or both.
  • the motion detection system may include a database that stores signals.
  • One of the wireless communication devices 102 A, 102 B, 102 C of the motion detection system may operate as a central hub or server for processing received signals and other information to detect motion and/or presence.
  • FIGS. 2A and 2B are diagrams showing example wireless signals communicated between wireless communication devices 204 A, 204 B, 204 C in a motion detection system.
  • the wireless communication devices 204 A, 204 B, 204 C may be, for example, the wireless communication devices 102 A, 102 B, 102 C shown in FIG. 1 , or may be other types of wireless communication devices. Examples of wireless communication devices include wireless mesh devices, stationary wireless client devices, mobile wireless client devices, and so forth.
  • a combination of one or more of the wireless communication devices 204 A, 204 B, 204 C can form, or may be part of, a dedicated motion detection system.
  • one or more of the wireless communication devices 204 A, 204 B, 204 C may be configured for motion detection, presence detection, or both, in the motion detection system.
  • a combination of one or more of the wireless communication devices 204 A, 204 B, 204 C may be, or may be part of, an ad hoc motion detection system that also performs other types of functions.
  • the example wireless communication devices 204 A, 204 B, 204 C may transmit and/or receive wireless signals through a space 200 .
  • the example space 200 may be completely or partially enclosed or open at one or more boundaries of the space 200 .
  • the space 200 may be or may include an interior of a room, multiple rooms, a building, an indoor area, outdoor area, or the like.
  • a first wall 202 A, a second wall 202 B, and a third wall 202 C at least partially enclose the space 200 in the example shown.
  • the first wireless communication device 204 A is operable to transmit wireless motion probe signals repeatedly (e.g., periodically, intermittently, at scheduled, unscheduled or random intervals, etc.), e.g., as a source device.
  • the second and third wireless communication devices 204 B, 204 C are operable to receive signals based on the motion probe signals transmitted by the wireless communication device 204 A, e.g., as a sensor device.
  • the motion probe signals may be formatted as described above.
  • the motion probe signals include standard signaling or communication frames that include standard pilot signals used in channel sounding (e.g., channel sounding for beamforming according to the IEEE 802.11ac-2013 standard).
  • the wireless communication devices 204 B, 204 C each have an interface, modem, processor, or other component that is configured to process received motion detection signals to detect motion or lack of motion, of an object in the space 200 .
  • the wireless communication devices 204 B, 204 C may each have an interface, modem, processor, or other component that is configured to detect the presence or absence of an object in the space 200 when lack of motion is detected, for example, whether the space is occupied or non-occupied.
  • the moving object in the space 200 is represented as a human, but the moving object can be another type of object.
  • the moving object can be an animal, an inorganic object (e.g., a system, device, apparatus, or assembly), an object that defines all or part of the boundary of the space 200 (e.g., a wall, door, window, etc.), or another type of object.
  • first wireless communication device 204 A multiple example paths of the wireless signals transmitted from the first wireless communication device 204 A are illustrated by dashed lines.
  • first signal path 216 the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the first wall 202 A toward the second wireless communication device 204 B.
  • second signal path 218 the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the second wall 202 B and the first wall 202 A toward the third wireless communication device 204 C.
  • the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the second wall 202 B toward the third wireless communication device 204 C.
  • fourth signal path 222 the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the third wall 202 C toward the second wireless communication device 204 B.
  • the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the object at the first position 214 A toward the third wireless communication device 204 C.
  • a surface of the object moves from the first position 214 A to a second position 214 B in the space 200 (e.g., some distance away from the first position 214 A).
  • the wireless signal is transmitted from the first wireless communication device 204 A and reflected off the object at the second position 214 B toward the third wireless communication device 204 C.
  • a signal path can be added, removed, or otherwise modified due to movement of an object in a space.
  • the example wireless signals shown in FIGS. 2A and 2B may experience attenuation, frequency shifts, phase shifts, or other effects through their respective paths and may have portions that propagate in another direction, for example, through the walls 202 A, 202 B, and 202 C.
  • the wireless signals are radio frequency (RF) signals.
  • the wireless signals may include other types of signals.
  • the first wireless communication device 204 A may be configured as a source device and may repeatedly transmit a wireless signal.
  • the transmitted signal may be transmitted continuously, periodically, at random or intermittent times or the like, or a combination thereof.
  • the transmitted signal may have a number of frequency components in a frequency bandwidth.
  • the transmitted signal may be transmitted from the first wireless communication device 204 A in an omnidirectional manner, in a directional manner or otherwise.
  • the wireless signals traverse multiple respective paths in the space 200 , and the signal along each path may become attenuated due to path losses, scattering, reflection, or the like and may have a phase or frequency offset.
  • the signals from various paths 216 , 218 , 220 , 222 , 224 A, and 224 B combine at the third wireless communication device 204 C and the second wireless communication device 204 B to form received signals.
  • the space 200 may be represented as a transfer function (e.g., a filter) in which the transmitted signal is input and the received signal is output.
  • the output of that transfer function e.g. the received signal
  • a change in the received signal can be used to detect movement of an object.
  • the output of the transfer function—the received signal does not change. Lack of change in the received signal (e.g., a steady state) may indicate lack of movement in the space 200 .
  • a transmitted signal f(t) transmitted from the first wireless communication device 204 A may be described according to Equation (1):
  • Equation (2) an output signal r k (t) from a path k may be described according to Equation (2):
  • ⁇ n,k represents an attenuation factor (or channel response; e.g., due to scattering, reflection, and path losses) for the n th frequency component along path k
  • ⁇ n,k represents the phase of the signal for n th frequency component along path k
  • Equation (3) Substituting Equation (2) into Equation (3) renders the following Equation (4):
  • the received signal R at a wireless communication device can then be analyzed.
  • the received signal R at a wireless communication device can be transformed to the frequency domain, for example, using a Fast Fourier Transform (FFT) or another type of algorithm.
  • the transformed signal can represent the received signal R as a series of n complex values, one for each of the respective frequency components (at the n frequencies ⁇ n ).
  • a complex value Y n may be represented as follows in Equation (5):
  • the complex value Y n for a given frequency component ⁇ n indicates a relative magnitude and phase offset of the received signal at that frequency component ⁇ n .
  • the complex value Y n changes due to the channel response ⁇ n,k of the space changing. Accordingly, a change detected in the channel response (and thus, the complex value Y n ) can be indicative of movement of an object within the communication channel.
  • a stable channel response (or “steady state”), for example, when no change or only small changes are detected in the channel response (or the complex value Y n ), indicates lack of movement.
  • the complex value Y n for each of multiple devices in a wireless mesh network can be analyzed to detect whether motion has occurred, or whether there is lack of motion, in a space traversed by the transmitted signals f(t). In some cases, when lack of movement is detected, further analysis may be performed on the channel response to determine if an object is present in the space, but not moving.
  • beamforming may be performed between devices based on some knowledge of the communication channel (e.g., through feedback properties generated by a receiver), which can be used to generate one or more steering properties (e.g., a steering matrix) that are applied by a transmitter device to shape the transmitted beam/signal in a particular direction or directions.
  • changes to the steering or feedback properties used in the beamforming process indicate changes, which may be caused by moving objects, in the space accessed by the wireless communication system.
  • motion may be detected by substantial changes in the communication channel, e.g., as indicated by a channel response, or steering or feedback properties, or any combination thereof, over a period of time.
  • a steering matrix may be generated at a transmitter device (beamformer) based on a feedback matrix provided by a receiver device (beamformee) based on channel sounding. Because the steering and feedback matrices are related to the propagation characteristics of a channel, these matrices change as objects move within the channel. Changes in the channel characteristics are accordingly reflected in these matrices, and by analyzing the matrices, motion can be detected, and different characteristics of the detected motion can be determined.
  • a spatial map may be generated based on one or more beamforming matrices. The spatial map may indicate a general direction of an object in a space relative to a wireless communication device. In some cases, “modes” of a beamforming matrix (e.g., a feedback matrix or steering matrix) can be used to generate the spatial map. The spatial map may be used to detect the presence of motion in the space or to detect a location of the detected motion.
  • the channel information (e.g., channel response information or beamforming state information, as described above) derived from wireless signals can be used to compute motion indicator values.
  • a set of motion indicator values for a given time frame may represent the levels of disturbance detected on the respective wireless links that communicated the wireless signals during the time frame.
  • the channel information can be filtered or otherwise modified, for instance, to reduce the effects of noise and interference on the motion indicator values.
  • a higher magnitude motion indicator value may represent a higher level of disturbance, while a lower magnitude motion indicator value may represent a relatively lower level of disturbance.
  • each motion indicator value can be an individual scalar quantity, and the motion indicator values can be normalized (e.g., to unity or otherwise).
  • the motion indicator values associated with a time frame can be used collectively to make an overall determination, for example, whether motion occurred in the space during the time frame, where motion occurred in the space during the time frame, etc.
  • a motion consensus value for a time frame may indicate the overall determination of whether motion occurred in the space based on all (or a subset) of motion indicator values for the time frame.
  • a more accurate, reliable or robust determination can be made by analyzing multiple motion indicator values for a time frame collectively.
  • data sets can be updated recursively to further improve the accuracy, for example, of location determinations.
  • the motion indicator values for each sequential time frame can be used to recursively update data sets representing the conditional probability of detecting motion at distinct locations in the space, and the recursively updated data sets can be used to make an overall determination of where motion occurred during a subsequent time frame.
  • FIG. 3 is a schematic diagram of an example wireless communication network 300 that includes a plurality of wireless nodes 302 .
  • the plurality of wireless nodes 302 may be analogous to the wireless communication devices 102 , 204 of FIGS. 1 and 2A-2B , respectively.
  • three wireless nodes 302 are depicted, labeled N 0 , N 1 , and N 2 .
  • the wireless communication network 300 may include one or more network servers, network routers, network switches, network repeaters, or other type of networking or computing equipment.
  • the wireless communication network 300 includes wireless communication channels 304 communicatively coupling respective pairs of wireless nodes 302 . Such communicative coupling may allow an exchange of wireless signals between wireless nodes 302 over a time frame.
  • the wireless communication channels 304 allow bi-directional communication between the respective pairs of wireless nodes 302 . Such communication may occur along two directions simultaneously (e.g., full duplex) or along only one direction at a time (e.g., half duplex).
  • the wireless communication channels 304 communicatively couple every pair of the plurality of wireless nodes 302 .
  • one or more pairs of wireless nodes 302 may lack a corresponding wireless communication channel 304 .
  • Each wireless communication channel 304 includes two or more wireless links, including at least one for each direction in the bi-directional communication.
  • an arrow represents each individual wireless link.
  • the arrow is labeled L ij where a first subscript, i, indicates a transmitting wireless node and a second subscript, j, indicates a receiving wireless node.
  • wireless nodes N 0 and N 1 are communicatively coupled by two wireless links that are indicated in FIG. 3 by two arrows, L 01 and L 10 .
  • Wireless link L 01 corresponds to wireless communication along a first direction from N 0 to N 1
  • wireless link L 10 corresponds wireless communication along a second, opposing direction from N 1 to N 0 .
  • the wireless communication network 300 obtains motion data associated with a first time frame, which may include the processes of motion detection described in relation to FIGS. 2A-2B .
  • the motion data includes a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame.
  • the motion may be detected on a plurality of wireless links (e.g., the wireless links L 01 , L 10 , L 02 , L 20 , L 12 , and L 21 of FIG. 3 ) in a wireless communication network (e.g., the wireless communication network 300 ).
  • Each of the wireless links can be defined between a respective pair of wireless communication devices in the wireless communication network (e.g., pair combinations of wireless nodes N 0 , N 1 , and N 2 ).
  • each of the motion indicator values is associated with a respective wireless link.
  • the wireless communication network 300 may include a data processing apparatus that executes program instructions (e.g., a network server, a wireless communication device, a network router, etc.).
  • the program instructions may cause the data processing apparatus to assign a unique node identifier to each of the wireless nodes 302 in the wireless communication network 300 .
  • the unique node identifier may be mapped to a media access control (MAC) address value, which corresponds to a MAC address (or portion thereof) associated with a wireless node.
  • MAC media access control
  • the wireless nodes N 0 , N 1 , and N 2 of FIG. 3 may be associated with a six-character portion of their respective MAC addresses, which is then mapped to a unique node identifier:
  • the MAC address values of e565c0, e56783, and e57349 are mapped to respective unique node identifiers 0, 1, and 2.
  • the program instructions may also cause the data processing apparatus to associate the wireless links with their respective pairs of wireless nodes via corresponding pairs of MAC address values.
  • the MAC address values may then be mapped to a unique link identifier to form a link table.
  • the wireless links L 01 , L 10 , L 02 , L 20 , L 12 , and L 21 of FIG. 3 may be mapped to unique link identifiers according to:
  • the MAC address values may be ordered, from left to right, to indicate respective pairs of transmitting and receiving wireless nodes in a wireless link.
  • the left MAC address value may correspond to a transmitting wireless node and the right MAC address value may correspond to a receiving wireless node.
  • Such mappings of unique node and link identifiers may aid the data processing apparatus in performing operations, such as searching, sorting, and matrix manipulation, during processes of motion detection.
  • the program instructions may additionally cause the data processing apparatus to poll the wireless links (or wireless nodes 302 ) to obtain motion indicator values for each wireless link in the plurality of wireless links.
  • the wireless links of the wireless communication network 300 of FIG. 3 may report motion indicator values according to a data structure, such as shown below:
  • the first column corresponds to the unique link identifiers of the wireless links and the second column of the data structure corresponds to their respective motion indicator values.
  • the data structure may be an array, as shown above, or some other type of data structure (e.g., a vector). Although data structure is presented as having six significant digits for each motion indicator value, other numbers of significant digits are possible for the motion indicator values (e.g., 3, 5, 9, etc.).
  • the program instructions may further cause the data processing apparatus to identify a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values.
  • the data processing apparatus may sort or filter through the motion indicator values to identify the first wireless link. For example, the data processing apparatus may sort the data structure according to magnitude, thereby determining a highest motion indicator value. In the data structure, the highest motion indicator value (i.e., 0.022051) corresponds to unique link identifier 1 , which maps to wireless link e565c0-e57349 (or L 02 in FIG. 3 ). The data processing apparatus may then identify wireless link 1 as the first wireless link.
  • a node in the wireless communication network 300 generates a first probability vector based on a predetermined map and the first wireless link.
  • the first probability vector includes first values assigned to the respective wireless communication devices in the wireless communication network 300 .
  • the first values represent first probabilities of motion at the respective wireless communication devices during the first time frame.
  • the first probability vector is represented by a probability vector, P(L j
  • the probability values correspond to probabilities that a wireless link, L j , exhibits link activity given motion at a wireless node, N i .
  • the data processing apparatus may identify wireless link 1 as the first wireless link.
  • N i ) P(1
  • N i ) ⁇ P(1
  • 0) corresponds to the probability that motion at wireless node 0 induces link activity along wireless link 1
  • 1) corresponds to the probability that motion at wireless node 1 induces link activity along wireless link 1
  • 2) corresponds to the probability that motion at wireless node 2 induces link activity along wireless link 1 .
  • These probability values can be generated using map values from the probability map.
  • the probability map may include map values that are based on a characteristic of a wireless communication device.
  • FIG. 4 is a schematic graph of an example probability map 400 having map values 402 that are based on a wireless node's status as a transmitting wireless node (Tx), a receiving wireless node (Rx), or other wireless node.
  • the map values 402 are highest for the transmitting wireless node (Tx) in a wireless link, second-highest for the receiving wireless node (Rx) in the wireless link, and lowest for wireless nodes not associated with the wireless link.
  • the example probability map 400 may reflect a multi-path propagation environment that is richer around a transmitting wireless node than a receiving wireless node.
  • FIG. 5 is a schematic diagram of an example multi-path propagation environment between a transmitting wireless node 502 and a receiving wireless node 504 .
  • Wireless communication between the nodes 502 , 504 is represented by arrows 506 , which are denser around the transmitting wireless node 502 than the receiving wireless node 504 .
  • the arrows 506 indicate a plurality of possible propagation paths for electromagnetic radiation traveling from the transmitting wireless node 502 to the receiving wireless node 504 .
  • the electromagnetic radiation may encounter objects, such as a wall 508 and a moving body 510 . Such encounters may include interactions with the objects, including absorption, reflection, scattering, and so forth.
  • the moving body 510 may have an increased interaction with the electromagnetic radiation due to a denser distribution of propagation paths. Conversely, if the moving body 510 enters a region proximate the receiving wireless node 504 , the moving body 510 may have a decreased interaction with the electromagnetic radiation due to a less-dense distribution of propagation paths. As such, motion proximate the transmitting wireless node 502 may have a greater probability to induce link activity along a wireless link communicatively coupling the nodes 502 , 504 than motion proximate the receiving wireless node 504 .
  • a probability map such as the probability map 400 of FIG. 4 —can reflect this bias by using map values that favor the transmitting wireless node 502 .
  • map values may be based on other characteristics of the wireless communication devices. Such characteristics include a location of a wireless node, a wireless signal frequency of a wireless link, a distance between wireless nodes, a time of day, and so forth.
  • the probability map may be constructed using a priori information about a wireless node's locality. For example, a received signal strength indicator (RSSI) of a wireless link can be used as a proxy for how far apart two wireless nodes of interest are. If a wireless node is very from both the transmitting and receiving node of the wireless link far—as represented by a weak RSSI—the wireless node can be assigned a very low probability based on the static channel conditions.
  • RSSI received signal strength indicator
  • the first probability vector is generated based on the predetermined map and the identified first wireless link. For example, if the map values 402 of FIG. 4 are 1.0, 0.9, and 0.2 the transmitting wireless node (Tx), the receiving wireless node (Rx), and all other wireless nodes, respectively, the data processing apparatus may output P(1
  • N i ) ⁇ 1.0, 0.2, 0.9 ⁇ . In doing so, the data processing apparatus identifies wireless node 0 as the transmitting wireless node and assigns P(1
  • the node in the wireless communication network 300 obtains a second probability vector generated from motion data associated with a prior time frame.
  • the second probability vector includes second values assigned to the respective wireless communication devices.
  • the second values represent prior probabilities of motion at the respective wireless communication devices during the prior time frame.
  • the second probability vector is represented by a probability vector, P(N i ), that includes probability values (or second values) representing a probability of motion at a wireless node, N i .
  • the probability of motion at wireless node, N i , for P(N i ) is independent of link activity along any of wireless links, L j , and may also be independent of other factors.
  • P(N i ) has probability values of P(0), P(1), and P(2), which correspond to the probability of motion at (or proximate to) wireless nodes 0 , 1 , and 2 , respectively.
  • a node in the wireless communication network 300 may determine a location of the motion detected from the wireless signals exchanged during the first time frame. The location of the motion can be determined based on the second probability vector and the first probability vector.
  • a node in the wireless communication network 300 may generate a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector.
  • the third probability vector may include third values assigned to the respective wireless communication devices.
  • the third values represent current probabilities of motion at the respective wireless communication devices during the first time frame.
  • the node in the wireless communication network 300 identifies a first wireless communication device associated with the highest of the third values.
  • determining the location of the motion includes identifying a location (e.g., a room, zone, floor, quadrant, etc.) associated with the wireless communication device as the location of the motion detected during the first time frame.
  • the third probability vector is represented by P(N i
  • L j ), includes third values that represent a probability of motion at wireless node, N i , given link activity along wireless link, L j .
  • the respective third values may then be represented by P(0
  • 1) ⁇ P(0
  • 1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 0
  • 1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 1
  • 1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 2 .
  • L j ) may be determined according to Eq. (1):
  • Eq. (1) may allow the wireless communication network 300 (or data processing apparatus) to determine the location of detected motion using Bayesian statistics. For example, if in the wireless communication network 300 of FIG. 3 , wireless link 1 is the first wireless link and P(1
  • N i ) ⁇ 1, 0.2, 0.9 ⁇ , the program instructions may then cause the data processing apparatus to calculate the third probability vector, P(N i
  • 1 ) P ⁇ ( 1
  • N i ) ⁇ P ⁇ ( N i ) ⁇ 1.0 ⁇ 0.333 , 0.2 ⁇ 0.333 , 0.9 ⁇ 0.333 ⁇ ( 1.0 ⁇ 0.333 ) + ( 0.2 ⁇ 0.333 ) + ( 0.9 ⁇ 0.333 )
  • 1) may therefore represent a probability distribution normalized to unity.
  • 1) corresponds to the largest of the third values, indicating that motion detected by the wireless communication network 300 along wireless link 1 has the highest probability of being located at (or proximate to) wireless node 0 .
  • the program instructions may cause the data processing apparatus to look up the MAC address value of wireless node 0 , and when found, output the result (e.g., output e565c0).
  • a node in the wireless communication network 300 performs an iterative process for sequential time frames. For example, the node may repeat the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion for each sequential time frame.
  • the third probability vector of a previous iteration serves as the second probably vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
  • the third probability vector from the prior time frame may serve as the second probability vector from the first time frame to generate the first probability vector, e.g., P(N i
  • the data processing apparatus may nest the calculation of P(N i
  • the probabilities for motion at (or proximate to) each wireless communication device (or wireless node 302 ) may therefore be recursively updated each cycle using Bayesian statistics.
  • the wireless communication network 300 may determine a location of motion using multiple wireless links.
  • identifying the first wireless link includes identifying a plurality of wireless links based on a magnitude of motion indicator values associated with each wireless link. The magnitude of motion may be relative to the other motion indicator values in the set of motion indicator values (or link table).
  • generating the first probability vector includes generating a first probability vector for each of the plurality of identified wireless links based on the predetermined map and each respective wireless link
  • the plurality of identified wireless links includes the first wireless link and a second wireless link.
  • the magnitude of the motion indicator associated with the first wireless link may be a highest motion indicator value, and a magnitude of the motion indicator value associated with the second wireless link may be a second-highest motion indicator value.
  • a node in the wireless communication network 300 may poll the wireless links (or wireless nodes 302 ) to obtain motion indicator values for each wireless link.
  • the motion indicator values may correspond to the first time frame or another time frame (e.g., subsequent to the first time frame of the previous example).
  • the wireless links of the wireless communication network 300 of FIG. 3 may report motion indicator values in a data structure, as shown below:
  • the program instructions may also cause the data processing apparatus to sort the data structure according to magnitude to determine the two highest motion indicator values.
  • the two highest motion indicator values correspond to wireless links 1 and 2 (or L 02 and L 10 in FIG. 3 ).
  • the data processing apparatus may normalize the two highest motion indicator values to unity, thereby producing a second data structure:
  • each of the motion indicator values is divided by a sum of all motion indicator values.
  • the normalized motion indicator values may be used to generate scaled third probability vectors of each of the plurality of identified wireless links, as will be described below.
  • the second data structure is presented as having three significant digits for each normalized motion indicator value, other numbers of significant digits are possible for the motion indicator values (e.g., 2, 4, 6, 9, etc.).
  • a node in the wireless communication network 300 generates a third probability vector by combining the second values from the second probability vector with the first values from each generated first probability vector.
  • the third probability vector may include third values assigned to the respective wireless communication devices.
  • the third values represent current probabilities of motion at the respective wireless communication devices during the first time frame.
  • the wireless communication network 300 may also identify a first wireless communication device associated with the highest of the third values.
  • the wireless communication network 300 may determine the location the motion by identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
  • the third probability vector is represented by P(N i
  • Program instructions may then cause the data processing apparatus to generate a third probability vector for each identified wireless link.
  • the third probability vectors may then be scaled and summed to generate an effective third probability vector, P e (N i
  • the effective third probability vector may be determined according to Eq. (2):
  • c(L j ) corresponds to a scaling constant for an identified wireless link, L j
  • the summation over j corresponds to all identified wireless links (id.).
  • the scaling constant, c(L j ) is generated from the normalized motion indicator value of a respective identified wireless link, L j , such as that stored in the second data structure.
  • the second data structure described above includes a normalized motion indicator value for each of identified wireless links 1 and 2 .
  • N i ) ⁇ 1.0, 0.2, 0.9 ⁇ for identified wireless link 1 and P(2
  • N i ) ⁇ 0.9, 1.0, 0.2 ⁇ for identified wireless link 2 .
  • 1) ⁇ 0.476, 0.095, 0.429 ⁇ .
  • the program instructions may cause the data processing apparatus to generate the third probability vector, P(N i
  • the program instructions may also cause the data processing apparatus to generate the third probability vector, P(N i
  • the program instructions may additionally cause the data processing apparatus to generate an effective third probability vector by summing the third probability vectors for wireless node 1 and wireless node 2 .
  • the data processing apparatus may generate P e (N i
  • 2) ⁇ 0.626, 0.092, 0.282 ⁇ .
  • the data processing apparatus distributes the third probability vectors for each identified wireless link more finely in the final output.
  • 1, 2) indicates that motion detected by the wireless communication network 300 has the highest probability of being located at (or proximate to) wireless node 0 , as shown by P e (0
  • 1, 2) 0.626.
  • the distribution of effective third values is more uneven and strongly favors wireless node 0 , e.g., compare the newly-generated ⁇ 0.626, 0.092, 0.282 ⁇ to the previously-generated ⁇ 0.476, 0.095, 0.429 ⁇ .
  • FIG. 6 is a flowchart showing an example process 600 for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • Operations in the example process 600 may be performed by a data processing apparatus (e.g., a processor in a wireless communication device 102 in FIG. 1A ) to detect a location of motion based on signals received at wireless communication devices.
  • the example process 600 may be performed by another type of device.
  • operations of the process 600 may be performed by a system other than a wireless communication device (e.g., a computer system connected to the wireless communication system 100 of FIG. 1A that aggregates and analyzes signals received by the wireless communication devices 102 ).
  • the example process 600 may include additional or different operations, and the operations may be performed in the order shown or in another order.
  • one or more of the operations shown in FIG. 6 are implemented as processes that include multiple operations, sub-processes or other types of routines.
  • operations can be combined, performed in another order, performed in parallel, iterated, or otherwise repeated or performed another manner.
  • the example process 600 includes obtaining motion data associated with a first time frame, as shown by operation 602 .
  • the motion data includes a set of motion indicator values that indicate motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in the wireless communication network.
  • Each of the wireless links is defined between a respective pair of wireless communication devices in the wireless communication network, and each of the motion indicator values is associated with a respective wireless link.
  • the example process 600 also includes identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link, as shown by operation 604 .
  • the magnitude is analyzed relative to the other motion indicator values in the set of motion indicator values.
  • the example process 600 additionally includes generating a first probability vector based on a predetermined map and the identified first wireless link, as shown by operation 606 .
  • the first probability vector includes first values assigned to the respective wireless communication devices.
  • the first values represent first probabilities of motion at the respective wireless communication devices during the first time frame.
  • the example process 600 yet also includes obtaining a second probability vector generated from motion data associated with a prior time frame, as shown by operation 608 .
  • the second probability vector includes second values assigned to the respective wireless communication devices.
  • the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame.
  • the example process 600 additionally includes determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, as shown by operation 610 .
  • the location of the detected motion is determined based on combining the prior probabilities from the second probability vector with the first probabilities from the first probability vector.
  • the wireless communication network 300 may determine a location of motion detected by the wireless links by accounting for potential transitions of the motion from one wireless node 302 to another.
  • the potential transitions of the motion may also include those remaining at, or in the immediate vicinity of, a wireless node 302 .
  • the wireless communication network 300 may detect motion at or near a first wireless node disposed in a bedroom of a house.
  • the wireless communication network 300 may account for a transition towards a second wireless node in a kitchen of the house if a corresponding time period of detection is during an eating time (e.g., breakfast, lunch, etc.).
  • wireless communication network 300 may account for the detected motion remaining at or near the second wireless nodes for a future time period within the eating time. Other criteria for the potential transitions are possible.
  • potential transitions of detected motion include criteria of time, location, or both. For example, if a time period of detection occurs during night time, a probability of detected motion transitioning from a bedroom to a washroom may be high. In contrast, a probability of the detected motion transitioning to a front door may be low.
  • a transition probability matrix may be used to represent these differences, which are based predominantly on time: The transition probability matrix may assign a high transition probability to the detected motion transitioning from the bedroom to the washroom while assigning a low transition probability to the detection motion transitioning from the bedroom to the front door.
  • the transition probability matrix may also account for a location of the detected motion. For example, motion detected in a living room may have a similar probability of transitioning to any another wireless node. This similar probability may incorporate considerations of time (e.g., night time, day time, etc.).
  • FIG. 7 is a schematic diagram of a wireless communication network 700 in which dashed arrows indicate potential transitions of detected motion between wireless nodes 702 .
  • the wireless communication network 700 of FIG. 7 may be analogous to the wireless communication network of FIG. 3 .
  • Features common to FIG. 3 and FIG. 7 are related via coordinated numerals that differ in increment by four hundred.
  • dashed arrows represent each potential transition for detected motion between wireless nodes 702 of the wireless communication network 700 .
  • the dashed arrows are labeled T ij where a first subscript, i, indicates an originating location and a second subscript, j, indicates a destination location.
  • wireless nodes N 0 and N 1 may each serve as an originating location and a destination location depending on a particular transition.
  • Transition T 01 corresponds to the detected motion transitioning from N 0 to N 1 and transition T 10 to the detected motion transitioning from N 1 to N 0 .
  • a node in the wireless communication network 700 obtains a transition probability matrix that includes transition values and non-transition values.
  • the transition values may represent probabilities of motion transitioning between locations associated with distinct wireless communication devices, and the non-transition values representing probabilities of motion remaining within locations associated with the respective wireless communication devices.
  • the transition probability matrix is represented by T(N i t
  • the present time frame may be equivalent to a first time frame.
  • M i t ⁇ 1 ) may be expanded according to Eq. (3):
  • M i t - 1 ) ⁇ T ⁇ ( 0 t
  • the diagonal terms may represent probabilities of transitioning between (or remaining at) the same wireless communication device during the present (or first) time period, e.g., T(0 t
  • the off-diagonal terms represent probabilities of transitioning from one wireless communication device to another during the present (or first) time period, e.g., T(0 t
  • the off-diagonal terms may correspond to transition probability values (or transition values).
  • potential transitions T 00 , T 11 , and T 22 may be represented by respective non-transition probability values T(0 t
  • potential transitions T 01 , T 10 , T 02 , T 20 , T 12 , and T 21 may be represented by respective transition probability values T(1 t
  • M i t ⁇ 1 ), may then be constructed according to Eq. (3):
  • M i t - 1 ) ⁇ T ⁇ ( 0 t
  • M i t ⁇ 1 ), are assigned values based on a stickiness factor.
  • the stickiness factor may be a probability of remaining at a wireless communication device divided by a probability of transitioning away from the wireless communication device (e.g., a probability ratio). For example, for the wireless communication network 700 of FIG. 7 , the detected motion may be known to remain, five times out of eight, proximate any given wireless node 702 . The stickiness factor may then be determined to be 0.625.
  • M i t ⁇ 1 ), may be constructed as follows:
  • M i t - 1 ) ⁇ 0.625 0.1875 0.1875 0.1875 0.625 0.1875 0.1875 0.1875 0.1875 0.625 0.1875 0.1875 0.1875 0.625 ⁇
  • a node in the wireless communication network 700 determines a location of the motion detected from the wireless signals exchanged during the first time frame. The location determined is based on the first probability vector, the second probability vector, and the transition probability matrix. In further implementations, the wireless communication network 700 generates a third probability vector by combining the first probability vector, the second probability vector and the transition probability matrix. Generating the third probability vector may result from the data processing apparatus executing program instructions. The third probability vector includes the third values representing third probabilities of motion at the respective wireless communication devices during the first time frame. In executing the program instructions, the wireless communication network 300 may also identify a first wireless communication device associated with the highest of the third values. Moreover, the wireless communication network 300 may determine the location of the motion by identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
  • the third probability vector is represented by P(N i t
  • L j t ) includes third values that represent, at the first time frame, a probability of motion at wireless node, N i , given link activity along wireless link, L j .
  • L j t ), may be determined according to Eq. (4):
  • N i t ), and P(N i t ) are as described above in relation to Eqs. (1) and (3).
  • the subscript, t indicates unique node or link identifier from the first time frame (t).
  • L j t ⁇ 1 ) may serve as the second probability vector, P(N i t ), of the first time frame.
  • P(N i t ) P(N i t ⁇ 1
  • Eqs. (4) and (5) may allow the wireless communication network 700 (or data processing apparatus) to determine the location of detected motion using Bayesian statistics while accounting for potential transitions between wireless nodes 702 .
  • a node in the wireless communication network 700 performs an iterative process for sequential time frames.
  • the node may repeat the operations, over multiple iterations of respective time frames, of obtaining motion data, generating the first probability vector, obtaining the second probability vector, obtaining the transition probability matrix, generating the third probability vector, identifying the first wireless communication device, and determining the location of the motion.
  • the third probability vector of a previous iteration serves as the second probably vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
  • a node in the wireless communication network 700 obtains the transition probability matrix by selecting between a first transition probability matrix and a second, distinct probability matrix. In some instances, such selections are based on a time of day. For example, program instructions may cause a data processing apparatus to select the first transition probability matrix when the first time frame corresponds to day time and the second transition probability matrix when the first time frame corresponds to night time. Other time periods are possible.
  • the wireless communication network 700 obtains a consensus value of motion based on the set of motion indicator values.
  • obtaining the transition probability matrix includes selecting between a first transition probability matrix and a second transition probability matrix. The first transition probability matrix can be selected when the consensus value of motion has a first value (e.g., zero), and the second transition probability matrix can be selected when the consensus value of motion has another value (e.g., unity).
  • the first transition probability matrix is associated with no motion being detected during the first time frame.
  • the second transition probability matrix is associated with motion being detected during the first time frame.
  • the non-transition values of the first transition probability matrix are greater than the transition values of the first transition probability matrix.
  • the transition values of the second transition probability matrix are greater than the non-transition values of the second transition probability matrix.
  • the transition probability matrix is represented by T(N i t
  • M i t ⁇ 1 ) of the transition probability matrix may be changed or selected, such as through the execution of program instructions by the data processing apparatus. For example, if C 0, the wireless communication network 700 may indicate no detected motion during the first time frame. In response, the data processing apparatus may change or select the probability values T(N i t
  • the wireless communication network 700 may indicate detected motion during the first time frame.
  • the data processing apparatus may change or select the probability values T(N i t
  • the second transition probability matrix may reflect a state in which the detected motion has a heightened probability of re-locating to another wireless node 702 .
  • the consensus value of motion, C has been presented in the context of binary values, other values are possible for C.
  • the consensus value of motion may correspond to a plurality of values, each have a respective transition probability matrix.
  • FIG. 8 is a flowchart showing another example process 800 for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • Operations in the example process 800 may be performed by a data processing apparatus (e.g., a processor in a wireless communication device 102 in FIG. 1A ) to detect a location of motion based on signals received at wireless communication devices.
  • the example process 800 may be performed by another type of device.
  • operations of the process 800 may be performed by a system other than a wireless communication device (e.g., a computer system connected to the wireless communication system 100 of FIG. 1A that aggregates and analyzes signals received by the wireless communication devices 102 ).
  • the example process 800 may include additional or different operations, and the operations may be performed in the order shown or in another order.
  • one or more of the operations shown in FIG. 8 are implemented as processes that include multiple operations, sub-processes or other types of routines.
  • operations can be combined, performed in another order, performed in parallel, iterated, or otherwise repeated or performed another manner.
  • the process 800 includes obtaining motion data associated with a first time frame, as shown by operation 802 .
  • the motion data includes a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network.
  • Each of the wireless links can be defined between a respective pair of wireless communication devices in the wireless communication network, and each of the motion indicator values is associated with a respective wireless link.
  • the example process 800 also includes generating a first probability vector based on the set of motion indicator values, as shown by operation 804 .
  • the first probability vector includes first values assigned to the respective wireless communication devices.
  • the first values represent first probabilities of motion at the respective wireless communication devices during the first time frame.
  • the example process 800 additionally includes obtaining a second probability vector generated from motion data associated with a prior time frame, as shown by operation 806 .
  • the second probability vector includes second values assigned to the respective wireless communication devices.
  • the second values represent prior probabilities of motion at the respective wireless communication devices during the prior time frame.
  • the example process 800 also includes obtaining a transition probability matrix that includes transition values and non-transition values, as shown by operation 808 .
  • the transition values represent probabilities of motion transitioning between locations associated with distinct wireless communication devices, and the non-transition values representing probabilities of motion remaining within locations associated with the respective wireless communication devices.
  • the example process 800 yet additionally includes determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, as shown by operation 810 . The location determined is based on the first probability vector, the second probability vector, and the transition matrix.
  • Some of the subject matter and operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them.
  • Some of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on a computer storage medium for execution by, or to control the operation of, data-processing apparatus.
  • a computer storage medium can be, or can be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them.
  • a computer storage medium is not a propagated signal
  • a computer storage medium can be a source or destination of computer program instructions encoded in an artificially generated propagated signal.
  • the computer storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices).
  • Some of the operations described in this specification can be implemented as operations performed by a data processing apparatus on data stored on one or more computer-readable storage devices or received from other sources.
  • data-processing apparatus encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing.
  • the apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
  • the apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them.
  • a computer program (also known as a program, program instructions, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment.
  • a computer program may, but need not, correspond to a file in a file system.
  • a program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code).
  • a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
  • Some of the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output.
  • the processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and processors of any kind of digital computer.
  • a processor will receive instructions and data from a read-only memory or a random-access memory or both.
  • Elements of a computer can include a processor that performs actions in accordance with instructions, and one or more memory devices that store the instructions and data.
  • a computer may also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic disks, magneto optical disks, or optical disks.
  • mass storage devices for storing data, e.g., magnetic disks, magneto optical disks, or optical disks.
  • a computer need not have such devices.
  • a computer can be embedded in another device, e.g., a phone, an electronic appliance, a mobile audio or video player, a game console, a Global Positioning System (GPS) receiver, or a portable storage device (e.g., a universal serial bus (USB) flash drive).
  • Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices (e.g., EPROM, EEPROM, flash memory devices, and others), magnetic disks (e.g., internal hard disks, removable disks, and others), magneto optical disks, and CD ROM and DVD-ROM disks.
  • the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
  • a computer having a display device (e.g., a monitor, or another type of display device) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse, a trackball, a tablet, a touch sensitive screen, or another type of pointing device) by which the user can provide input to the computer.
  • a display device e.g., a monitor, or another type of display device
  • a keyboard and a pointing device e.g., a mouse, a trackball, a tablet, a touch sensitive screen, or another type of pointing device
  • Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • a computer can interact with a user by sending documents to and receiving documents from a device that is used
  • a computer system may include a single computing device, or multiple computers that operate in proximity or generally remote from each other and typically interact through a communication network.
  • Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), an inter-network (e.g., the Internet), a network comprising a satellite link, and peer-to-peer networks (e.g., ad hoc peer-to-peer networks).
  • LAN local area network
  • WAN wide area network
  • Internet inter-network
  • peer-to-peer networks e.g., ad hoc peer-to-peer networks.
  • a relationship of client and server may arise by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
  • motion may be detected by exchanging wireless signals between wireless communication devices in a wireless communication network.
  • location of the detected motion may also be determined, as described by the following examples:
  • a method comprising:
  • the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
  • the predetermined map comprises a third map value assigned to one or more wireless communication devices not associated with the first wireless link.
  • a motion detection system comprising:
  • a non-transitory computer-readable medium comprising instructions that, when executed, cause data processing apparatus to perform one or more operations of any one of Examples 1 through 12.
  • the location of the detected motion may be determined using a transition probability matrix, as shown by the following examples:
  • a method comprising:
  • the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
  • obtaining the transition probability matrix comprises selecting between a first transition probability matrix and a second, distinct transition probability matrix.
  • a motion detection system comprising:
  • a non-transitory computer-readable medium comprising instructions that, when executed, cause the data processing apparatus to perform one or more of the operations of any one of Examples 15 through 32.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Probability & Statistics with Applications (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Position Fixing By Use Of Radio Waves (AREA)

Abstract

In a general aspect, a method for determining a location of motion detected by wireless communication devices in a wireless communication network includes obtaining motion data associated with a first time frame. The method also includes identifying a first wireless link, of a plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in a set of motion indicator values. The method additionally includes generating a first probability vector based on a predetermined map and the first wireless link and obtaining a second probability vector generated from motion data associated with a prior time frame. The method further includes determining, by operation of a data processing apparatus, a location of motion detected from wireless signals exchanged during the first time frame.

Description

    BACKGROUND
  • The following description relates to determining a location of motion detected from wireless signals.
  • Motion detection systems have been used to detect movement, for example, of objects in a room or an outdoor area. In some example motion detection systems, infrared or optical sensors are used to detect movement of objects in the sensor's field of view. Motion detection systems have been used in security systems, automated control systems and other types of systems.
  • DESCRIPTION OF DRAWINGS
  • FIG. 1 is a diagram showing an example wireless communication system.
  • FIGS. 2A and 2B are diagrams showing example wireless signals communicated between wireless communication devices in a motion detection system.
  • FIG. 3 is a schematic diagram of an example wireless communication network that includes a plurality of wireless nodes.
  • FIG. 4 is a schematic graph of an example probability map having map values that are based on a wireless node's status as a transmitting wireless node (Tx), a receiving wireless node (Rx), or other wireless node.
  • FIG. 5 is a schematic diagram of an example multi-path propagation environment between a transmitting wireless node and a receiving wireless node.
  • FIG. 6 is a flowchart of an example process for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • FIG. 7 is a schematic diagram of an example wireless communication network in which dashed arrows indicate potential transitions of detected motion between wireless nodes.
  • FIG. 8 is a flowchart of another example process for determining a location of motion detected by wireless communication devices in a wireless communication network.
  • DETAILED DESCRIPTION
  • In some aspects of what is described here, the location of motion in a space (e.g., the particular room in a house where a person is moving, a particular floor or quadrant of a building where a person is moving, etc.) may be detected using information from multiple wireless communication devices communicating with each other wirelessly.
  • For instance, wireless signals received at each of the wireless communication devices in a wireless communication network may be analyzed to determine channel information for the different communication links in the network (between respective pairs of wireless communication devices in the network). The channel information may be representative of a physical medium that applies a transfer function to wireless signals that traverse the space. In some instances, the channel information includes channel response information. Channel response information may refer to known channel properties of a communication link, and may describe how a wireless signal propagates from a transmitter to a receiver, representing the combined effect of, for example, scattering, fading, and power decay within the space between the transmitter and receiver. In some instances, the channel information includes beamforming state information. Beamforming (or spatial filtering) may refer to a signal processing technique used in multi antenna (multiple-input/multiple-output (MIMO)) radio systems for directional signal transmission or reception. Beamforming can be achieved by combining elements in an antenna array in such a way that signals at particular angles experience constructive interference while others experience destructive interference. Beamforming can be used at both the transmitting and receiving ends in order to achieve spatial selectivity. In some cases (e.g., the IEEE 802.11ac standard), a beamforming steering matrix is used by a transmitter. The beamforming steering matrix may include a mathematical description of how the antenna array should use each of its individual antenna elements to select a spatial path for transmission. While certain aspects are described herein with respect to channel response information, beamforming state information or beamformer steering matrix state may also be used in the aspects described as well.
  • The channel information for each of the communication links may be analyzed (e.g., by a hub device or other device in the network, or a remote device communicably coupled to the network) to detect whether motion has occurred in the space, to determine a relative location of the detected motion, or both. In some aspects, the channel information for each of the communication links may be analyzed to detect whether an object is present or absent, e.g., when no motion is detected in the space.
  • In some implementations, the wireless communication network may include a wireless mesh network. A wireless mesh network may refer to a decentralized wireless network whose nodes (e.g. wireless communication devices) communicate directly in a point-to-point manner without using a central access point, base station or network controller. Wireless mesh networks may include mesh clients, mesh routers, or mesh gateways. In some instances, a wireless mesh network is based on the IEEE 802.11s standard. In some instances, a wireless mesh network is based on Wi-Fi ad hoc or another standardized technology. Examples of commercially-available wireless mesh networks include Wi-Fi systems sold by Google, Eero, and others.
  • In some example wireless communication networks, each node is connected to one or more other nodes through one or more bi-directional links. Each node can analyze the wireless signals that it receives to identify the perturbation or disturbance on each of the links. The disturbance on each link can be represented as a motion indicator value, for example, as a scalar quantity that can be normalized. The link disturbance values from the nodes in the wireless communication network can be used to determine the probability of motion at the locations associated with the respective node. For example, the probability of motion at each node can be used to tell which node has the highest probability of having motion in its vicinity, and that node can be identified as the node around which the motion occurred. In order to do this, the analysis can be case in a Bayesian estimation framework, for the recursive computation of probabilities. The probabilistic framework offers a number of technical advantages, for example, providing recursive estimation and hence eventual convergence to a correct result, simplistic logic with no conditions for each special situation, performance that is more accurate and robust (e.g., to artifacts) and others.
  • In addition, physical insights regarding the motion detection system can inform the Bayesian estimation framework that is used to detect the location of motion. For example, the relative magnitude of excitation on a link (between a transmitter node and receiver node) is likely to be greater when the motion that creates the excitation is nearer the receiver node. Accordingly, as an initial probability estimate for where motion occurred, the highest probabilities can be assigned to the receiver nodes on wireless links associated with the highest motion indicator values. This initial probability estimate can be combined with a conditional probability distribution (e.g., based on prior motion data) to produce a recursively refined probability estimate according to a Bayesian framework. As another example, in certain contexts the likelihood of motion transitioning between distinct locations can be higher or lower, relative to the likelihood of motion remaining in a single location. Accordingly, location transition probabilities can be incorporated into the Bayesian framework. For example, a transition probability matrix can be combined with the initial probability estimate and the conditional probability distribution to produce the recursively refined probability estimate according to the Bayesian framework.
  • FIG. 1 is a diagram showing an example wireless communication system 100. The example wireless communication system 100 includes three wireless communication devices—a first wireless communication device 102A, a second wireless communication device 102B, and a third wireless communication device 102C. The example wireless communication system 100 may include additional wireless communication devices 102 and/or other components (e.g., one or more network servers, network routers, network switches, cables, or other communication links, etc.).
  • The example wireless communication devices 102A, 102B, 102C can operate in a wireless network, for example, according to a wireless network standard or another type of wireless communication protocol. For example, the wireless network may be configured to operate as a Wireless Local Area Network (WLAN), a Personal Area Network (PAN), a metropolitan area network (MAN), or another type of wireless network. Examples of WLANs include networks configured to operate according to one or more of the 802.11 family of standards developed by IEEE (e.g., Wi-Fi networks), and others. Examples of PANs include networks that operate according to short-range communication standards (e.g., BLUETOOTH®, Near Field Communication (NFC), ZigBee), millimeter wave communications, and others.
  • In some implementations, the wireless communication devices 102A, 102B, 102C may be configured to communicate in a cellular network, for example, according to a cellular network standard. Examples of cellular networks include networks configured according to 2G standards such as Global System for Mobile (GSM) and Enhanced Data rates for GSM Evolution (EDGE) or EGPRS; 3G standards such as Code Division Multiple Access (CDMA), Wideband Code Division Multiple Access (WCDMA), Universal Mobile Telecommunications System (UMTS), and Time Division Synchronous Code Division Multiple Access (TD-SCDMA); 4G standards such as Long-Term Evolution (LTE) and LTE-Advanced (LTE-A); 5G standards, and others. In the example shown in FIG. 1, the wireless communication devices 102A, 102B, 102C can be, or may include, standard wireless network components. For example, the wireless communication devices 102A, 102B, 102C may be commercially-available Wi-Fi devices.
  • In some cases, the wireless communication devices 102A, 102B, 102C may be Wi-Fi access points or another type of wireless access point (WAP). The wireless communication devices 102A, 102B, 102C may be configured to perform one or more operations as described herein that are embedded as instructions (e.g., software or firmware) on the wireless communication devices. In some cases, one or more of the wireless communication devices 102A, 102B, 102C may be nodes of a wireless mesh network, such as, for example, a commercially-available mesh network system (e.g., Google Wi-Fi, Eero Wi-Fi systems, etc.). In some cases, another type of standard or conventional Wi-Fi transceiver device may be used. The wireless communication devices 102A, 102B, 102C may be implemented without Wi-Fi components; for example, other types of wireless protocols for wireless communication, either standard or non-standard, may be used for motion detection.
  • In the example shown in FIG. 1, the wireless communication devices, e.g., 102A, 102B, transmit wireless signals over a communication channel (e.g., according to a wireless network standard, a motion detection protocol, a presence detection protocol, or other standard or non-standard protocol). For example, the wireless communication devices may generate motion probe signals for transmission to probe a space to detect motion or presence of an object. In some implementations, the motion probe signals may include standard signaling or communication frames that include standard pilot signals used in channel sounding (e.g., channel sounding for beamforming according to the IEEE 802.11ac-2013 standard). In some cases, the motion probe signals include reference signals known to all devices in the network. In some instances, one or more of the wireless communication devices may process motion detection signals, which are signals received based on motion probe signals transmitted through the space. For example, the motion detection signals may be analyzed to detect motion of an object in a space, lack of motion in the space, or the presence or absence of an object in the space when lack of motion is detected, based on changes (or lack thereof) detected in the communication channel.
  • The wireless communication devices transmitting motion probe signals, e.g. 102A, 102B, may be referred to as source devices. In some cases, wireless communication devices 102A, 102B may broadcast the wireless motion probe signals (e.g., described above). In other cases, the wireless communication devices 102A, 102B may send wireless signals addressed to another wireless communication device 102C and other devices (e.g., a user equipment, a client device, a server, etc.). The wireless communication device 102C as well as the other devices (not shown) may receive the wireless signals transmitted by the wireless communication devices 102A, 102B. In some cases, the wireless signals transmitted by the wireless communication devices 102A, 102B are repeated periodically, for example, according to a wireless communication standard or otherwise.
  • In some examples, the wireless communication device 102C, which may be referred to as a sensor device, processes the wireless signals received from the wireless communication devices 102A, 102B to detect motion, or lack of motion, of an object in a space accessed by the wireless signals. In some examples, another device or computing system processes the wireless signals received by the wireless communication device 102C from the wireless communication devices 102A, 102B to detect motion, or lack of motion, of an object in a space accessed by the wireless signals. In some cases, the wireless communication device 102C (or another system or device) processes the wireless signals to detect the presence or absence of an object in a space when lack of motion is detected. In some instances, the wireless communication device 102C (or another system or device) may perform one or more operations as described in relation to FIG. 6 or in the example method described method to FIG. 8, or another type of process for detecting motion, detecting lack of motion, or detecting the presence or absence of an object when lack of motion is detected. In other examples, the wireless communication system 100 may be modified, for instance, such that the wireless communication device 102C can transmit wireless signals, e.g. as a source device, and the wireless communication devices 102A, 102B may process the wireless signals, e.g. as sensor devices, from the wireless communication device 102C, to detect motion, lack of motion, or presence when no motion is detected. That is, each of the wireless communication devices 102A, 102B, 102C, may be configured, in some cases, as a source device, a sensor device, or both.
  • The wireless signals used for motion and/or presence detection can include, for example, a beacon signal (e.g., Bluetooth Beacons, Wi-Fi Beacons, other wireless beacon signals), pilot signals (e.g., pilot signals used for channel sounding, such as in beamforming applications, according to the IEEE 802.11ac-2013 standard), or another standard signal generated for other purposes according to a wireless network standard, or non-standard signals (e.g., random signals, reference signals, etc.) generated for motion and/or presence detection or other purposes. In some cases, the wireless signals for motion and/or presence detection are known to all devices in the network.
  • In some examples, the wireless signals may propagate through an object (e.g., a wall) before or after interacting with a moving object, which may allow the moving object's movement to be detected without an optical line-of-sight between the moving object and the transmission or receiving hardware. In some cases, the wireless signals, when received by a wireless communication device, e.g. 102C, may indicate lack of motion in a space, for example, that an object is not moving, or no longer moving, in the space. In some cases, the wireless signals, when received by a wireless communication device, e.g. 102C, may indicate the presence of an object in the space when lack of motion is detected. Conversely, the wireless signals may indicate the absence of an object in the space when lack of motion is detected. For example, based on the received wireless signals, the third wireless communication device 102C may generate motion data, presence data, or both. In some instances, the third wireless communication device 102C may communicate the motion detection and/or presence data, to another device or system, such as a security system, that may include a control center for monitoring movement within a space, such as a room, building, outdoor area, etc.
  • In some implementations, the wireless communication devices 102A, 102B may be configured to transmit motion probe signals (e.g., as described above) on a wireless communication channel separate from wireless network traffic signals (e.g., a frequency channel or coded channel). For example, the modulation applied to the payload of a motion probe signal and the type of data or data structure in the payload may be known by the third wireless communication device 102C, which may reduce the amount of processing that the third wireless communication device 102C performs for motion and presence detection. The header may include additional information such as, for example, an indication of whether motion or lack of motion was detected by another device in the communication system 100, whether a presence of an object was detected by another device in the communication system 100, an indication of the modulation type, an identification of the device transmitting the signal, and so forth.
  • In the example shown in FIG. 1, the wireless communication system 100 is illustrated as a wireless mesh network, with wireless communication links between each of the respective wireless communication devices 102. In the example shown, the wireless communication links between the third wireless communication device 102C and the first wireless communication device 102A can be used to probe a first motion detection zone 110A, the wireless communication links between the third wireless communication device 102C and the second wireless communication device 102B can be used to probe a second motion detection zone 110B, and the wireless communication links between the first wireless communication device 102A and the second wireless communication device 102B can be used to probe a third motion detection zone 110C. In some instances, each wireless communication device 102 may be configured to detect motion, lack of motion, and/or the presence or absence of an object when no motion is detected, in each of the motion detection zones 110 accessed by that device by processing received signals that are based on wireless signals transmitted by the wireless communication devices 102 through the motion detection zones 110. For example, when a person 106 moves in the first motion detection zone 110A and the third motion detection zone 110C, the wireless communication devices 102 may detect the motion based on signals they receive that are based on wireless signals transmitted through the respective motion detection zones 110. For instance, the first wireless communication device 102A can detect motion of the person in both the first and third motion detection zones 110A, 110C, the second wireless communication device 102B can detect motion of the person 106 in the third motion detection zone 110C, and the third wireless communication device 102C can detect motion of the person 106 in the first motion detection zone 110A. In some cases, lack of motion by the person 106 and, in other cases, the presence of the person 106 when the person 106 is not detected to be moving, may be detected in each of the motion detection zones 110A, 110B, 110C.
  • In some instances, the motion detection zones 110 can include, for example, air, solid materials, liquids, or another medium through which wireless electromagnetic signals may propagate. In the example shown in FIG. 1, the first motion detection zone 110A provides a wireless communication channel between the first wireless communication device 102A and the third wireless communication device 102C, the second motion detection zone 110B provides a wireless communication channel between the second wireless communication device 102B and the third wireless communication device 102C, and the third motion detection zone 110C provides a wireless communication channel between the first wireless communication device 102A and the second wireless communication device 102B. In some aspects of operation, wireless signals transmitted on a wireless communication channel (separate from or shared with the wireless communication channel for network traffic) are used to detect movement or lack of movement of an object in a space, and may be used to detect the presence (or absence) of an object in the space when there is a lack of movement detected. The objects can be any type of static or moveable object, and can be living or inanimate. For example, the object can be a human (e.g., the person 106 shown in FIG. 1), an animal, an inorganic object, or another device, apparatus, or assembly, an object that defines all or part of the boundary of a space (e.g., a wall, door, window, etc.), or another type of object. In some implementations, motion information from the wireless communication devices may trigger further analysis to determine the presence or absence of an object when motion of the object is not detected.
  • In some implementations, the wireless communication system 100 may be, or may include, a motion detection system. The motion detection system may include one or more of the wireless communication devices 102A, 102B, 102C and possibly other components. One or more wireless communication devices 102A, 102B, 102C in the motion detection system may be configured for motion detection, presence detection, or both. The motion detection system may include a database that stores signals. One of the wireless communication devices 102A, 102B, 102C of the motion detection system may operate as a central hub or server for processing received signals and other information to detect motion and/or presence. The storage of data—e.g., in the database, and/or the determination of motion, lack of motion (e.g., a steady state), or presence detection—may be performed by a wireless communication device 102, or in some cases, may be performed by another device in the wireless communication network or in the cloud (e.g., by one or more remote devices).
  • FIGS. 2A and 2B are diagrams showing example wireless signals communicated between wireless communication devices 204A, 204B, 204C in a motion detection system. The wireless communication devices 204A, 204B, 204C may be, for example, the wireless communication devices 102A, 102B, 102C shown in FIG. 1, or may be other types of wireless communication devices. Examples of wireless communication devices include wireless mesh devices, stationary wireless client devices, mobile wireless client devices, and so forth.
  • In some cases, a combination of one or more of the wireless communication devices 204A, 204B, 204C can form, or may be part of, a dedicated motion detection system. For example, as part of the dedicated motion detection system, one or more of the wireless communication devices 204A, 204B, 204C may be configured for motion detection, presence detection, or both, in the motion detection system. In some cases, a combination of one or more of the wireless communication devices 204A, 204B, 204C may be, or may be part of, an ad hoc motion detection system that also performs other types of functions.
  • The example wireless communication devices 204A, 204B, 204C may transmit and/or receive wireless signals through a space 200. The example space 200 may be completely or partially enclosed or open at one or more boundaries of the space 200. The space 200 may be or may include an interior of a room, multiple rooms, a building, an indoor area, outdoor area, or the like. A first wall 202A, a second wall 202B, and a third wall 202C at least partially enclose the space 200 in the example shown.
  • In the example shown in FIGS. 2A and 2B, the first wireless communication device 204A is operable to transmit wireless motion probe signals repeatedly (e.g., periodically, intermittently, at scheduled, unscheduled or random intervals, etc.), e.g., as a source device. The second and third wireless communication devices 204B, 204C are operable to receive signals based on the motion probe signals transmitted by the wireless communication device 204A, e.g., as a sensor device. The motion probe signals may be formatted as described above. For example, in some implementations, the motion probe signals include standard signaling or communication frames that include standard pilot signals used in channel sounding (e.g., channel sounding for beamforming according to the IEEE 802.11ac-2013 standard). The wireless communication devices 204B, 204C each have an interface, modem, processor, or other component that is configured to process received motion detection signals to detect motion or lack of motion, of an object in the space 200. In some instances, the wireless communication devices 204B, 204C may each have an interface, modem, processor, or other component that is configured to detect the presence or absence of an object in the space 200 when lack of motion is detected, for example, whether the space is occupied or non-occupied.
  • As shown, an object is in a first position 214A at an initial time t=0 in FIG. 2A, and the object has moved to a second position 214B at subsequent time t=1 in FIG. 2B. In FIGS. 2A and 2B, the moving object in the space 200 is represented as a human, but the moving object can be another type of object. For example, the moving object can be an animal, an inorganic object (e.g., a system, device, apparatus, or assembly), an object that defines all or part of the boundary of the space 200 (e.g., a wall, door, window, etc.), or another type of object. For this example, the representation of the object's 214 movement is merely indicative that the object's location changed within the space 200 between time t=0 and time t=1.
  • As shown in FIGS. 2A and 2B, multiple example paths of the wireless signals transmitted from the first wireless communication device 204A are illustrated by dashed lines. Along a first signal path 216, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the first wall 202A toward the second wireless communication device 204B. Along a second signal path 218, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the second wall 202B and the first wall 202A toward the third wireless communication device 204C. Along a third signal path 220, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the second wall 202B toward the third wireless communication device 204C. Along a fourth signal path 222, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the third wall 202C toward the second wireless communication device 204B.
  • In FIG. 2A, along a fifth signal path 224A, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the object at the first position 214A toward the third wireless communication device 204C. Between time t=0 in FIG. 2A and time t=1 in FIG. 2B, a surface of the object moves from the first position 214A to a second position 214B in the space 200 (e.g., some distance away from the first position 214A). In FIG. 2B, along a sixth signal path 224B, the wireless signal is transmitted from the first wireless communication device 204A and reflected off the object at the second position 214B toward the third wireless communication device 204C. The sixth signal path 224B depicted in FIG. 2B is longer than the fifth signal path 224A depicted in FIG. 2A due to the movement of the object from the first position 214A to the second position 214B. In some examples, a signal path can be added, removed, or otherwise modified due to movement of an object in a space.
  • The example wireless signals shown in FIGS. 2A and 2B may experience attenuation, frequency shifts, phase shifts, or other effects through their respective paths and may have portions that propagate in another direction, for example, through the walls 202A, 202B, and 202C. In some examples, the wireless signals are radio frequency (RF) signals. The wireless signals may include other types of signals.
  • In the example shown in FIGS. 2A and 2B, the first wireless communication device 204A may be configured as a source device and may repeatedly transmit a wireless signal. For example, FIG. 2A shows the wireless signal being transmitted from the first wireless communication device 204A during a first time t=0. The transmitted signal may be transmitted continuously, periodically, at random or intermittent times or the like, or a combination thereof. For example, the transmitted signal may be transmitted one or more times between time t=0 and a subsequent time t=1 illustrated in FIG. 2B, or any other subsequent time. The transmitted signal may have a number of frequency components in a frequency bandwidth. The transmitted signal may be transmitted from the first wireless communication device 204A in an omnidirectional manner, in a directional manner or otherwise. In the example shown, the wireless signals traverse multiple respective paths in the space 200, and the signal along each path may become attenuated due to path losses, scattering, reflection, or the like and may have a phase or frequency offset.
  • As shown in FIGS. 2A and 2B, the signals from various paths 216, 218, 220, 222, 224A, and 224B combine at the third wireless communication device 204C and the second wireless communication device 204B to form received signals. Because of the effects of the multiple paths in the space 200 on the transmitted signal, the space 200 may be represented as a transfer function (e.g., a filter) in which the transmitted signal is input and the received signal is output. When an object moves in the space 200, the attenuation or phase offset affected upon a signal in a signal path can change, and hence, the transfer function of the space 200 can change. Assuming the same wireless signal is transmitted from the first wireless communication device 204A, if the transfer function of the space 200 changes, the output of that transfer function, e.g. the received signal, will also change. A change in the received signal can be used to detect movement of an object. Conversely, in some cases, if the transfer function of the space does not change, the output of the transfer function—the received signal—does not change. Lack of change in the received signal (e.g., a steady state) may indicate lack of movement in the space 200.
  • Mathematically, a transmitted signal f(t) transmitted from the first wireless communication device 204A may be described according to Equation (1):
  • f ( t ) = n = - c n e j ω n t ( 1 )
  • where ωn represents the frequency of nth frequency component of the transmitted signal, cn represents the complex coefficient of the nth frequency component, and t represents time. With the transmitted signal f(t) being transmitted from the first wireless communication device 204A, an output signal rk(t) from a path k may be described according to Equation (2):
  • r k ( t ) = n = - α n , k c n e j ( ω n t + φ n , k ) ( 2 )
  • where αn,k represents an attenuation factor (or channel response; e.g., due to scattering, reflection, and path losses) for the nth frequency component along path k, and ϕn,k represents the phase of the signal for nth frequency component along path k. Then, the received signal R at a wireless communication device can be described as the summation of all output signals rk(t) from all paths to the wireless communication device, which is shown in Equation (3):
  • R = k r k ( t ) ( 3 )
  • Substituting Equation (2) into Equation (3) renders the following Equation (4):
  • R = k n = - ( α n , k e j φ n , k ) ) c n e j ω n t ( 4 )
  • The received signal R at a wireless communication device can then be analyzed. The received signal R at a wireless communication device can be transformed to the frequency domain, for example, using a Fast Fourier Transform (FFT) or another type of algorithm. The transformed signal can represent the received signal R as a series of n complex values, one for each of the respective frequency components (at the n frequencies ωn). For a frequency component at frequency ωn, a complex value Yn may be represented as follows in Equation (5):
  • Y n = k c n α n , k e j φ n , k ( 5 )
  • The complex value Yn for a given frequency component ωn indicates a relative magnitude and phase offset of the received signal at that frequency component ωn. When an object moves in the space, the complex value Yn changes due to the channel response αn,k of the space changing. Accordingly, a change detected in the channel response (and thus, the complex value Yn) can be indicative of movement of an object within the communication channel. Conversely, a stable channel response (or “steady state”), for example, when no change or only small changes are detected in the channel response (or the complex value Yn), indicates lack of movement. Thus, in some implementations, the complex value Yn for each of multiple devices in a wireless mesh network can be analyzed to detect whether motion has occurred, or whether there is lack of motion, in a space traversed by the transmitted signals f(t). In some cases, when lack of movement is detected, further analysis may be performed on the channel response to determine if an object is present in the space, but not moving.
  • In another aspect of FIGS. 2A and 2B, beamforming may be performed between devices based on some knowledge of the communication channel (e.g., through feedback properties generated by a receiver), which can be used to generate one or more steering properties (e.g., a steering matrix) that are applied by a transmitter device to shape the transmitted beam/signal in a particular direction or directions. Thus, changes to the steering or feedback properties used in the beamforming process indicate changes, which may be caused by moving objects, in the space accessed by the wireless communication system. For example, motion may be detected by substantial changes in the communication channel, e.g., as indicated by a channel response, or steering or feedback properties, or any combination thereof, over a period of time.
  • In some implementations, for example, a steering matrix may be generated at a transmitter device (beamformer) based on a feedback matrix provided by a receiver device (beamformee) based on channel sounding. Because the steering and feedback matrices are related to the propagation characteristics of a channel, these matrices change as objects move within the channel. Changes in the channel characteristics are accordingly reflected in these matrices, and by analyzing the matrices, motion can be detected, and different characteristics of the detected motion can be determined. In some implementations, a spatial map may be generated based on one or more beamforming matrices. The spatial map may indicate a general direction of an object in a space relative to a wireless communication device. In some cases, “modes” of a beamforming matrix (e.g., a feedback matrix or steering matrix) can be used to generate the spatial map. The spatial map may be used to detect the presence of motion in the space or to detect a location of the detected motion.
  • In some instances, the channel information (e.g., channel response information or beamforming state information, as described above) derived from wireless signals can be used to compute motion indicator values. For example, a set of motion indicator values for a given time frame may represent the levels of disturbance detected on the respective wireless links that communicated the wireless signals during the time frame. In some cases, the channel information can be filtered or otherwise modified, for instance, to reduce the effects of noise and interference on the motion indicator values. In some contexts, a higher magnitude motion indicator value may represent a higher level of disturbance, while a lower magnitude motion indicator value may represent a relatively lower level of disturbance. For instance, each motion indicator value can be an individual scalar quantity, and the motion indicator values can be normalized (e.g., to unity or otherwise).
  • In some cases, the motion indicator values associated with a time frame can be used collectively to make an overall determination, for example, whether motion occurred in the space during the time frame, where motion occurred in the space during the time frame, etc. For instance, a motion consensus value for a time frame may indicate the overall determination of whether motion occurred in the space based on all (or a subset) of motion indicator values for the time frame. In some cases, a more accurate, reliable or robust determination can be made by analyzing multiple motion indicator values for a time frame collectively. And in some cases, data sets can be updated recursively to further improve the accuracy, for example, of location determinations. For instance, the motion indicator values for each sequential time frame can be used to recursively update data sets representing the conditional probability of detecting motion at distinct locations in the space, and the recursively updated data sets can be used to make an overall determination of where motion occurred during a subsequent time frame.
  • FIG. 3 is a schematic diagram of an example wireless communication network 300 that includes a plurality of wireless nodes 302. The plurality of wireless nodes 302 may be analogous to the wireless communication devices 102, 204 of FIGS. 1 and 2A-2B, respectively. In FIG. 3, three wireless nodes 302 are depicted, labeled N0, N1, and N2. However, other numbers of wireless nodes 302 are possible in the wireless communication network 300. Moreover, other types of nodes are possible. For example, the wireless communication network 300 may include one or more network servers, network routers, network switches, network repeaters, or other type of networking or computing equipment.
  • The wireless communication network 300 includes wireless communication channels 304 communicatively coupling respective pairs of wireless nodes 302. Such communicative coupling may allow an exchange of wireless signals between wireless nodes 302 over a time frame. In particular, the wireless communication channels 304 allow bi-directional communication between the respective pairs of wireless nodes 302. Such communication may occur along two directions simultaneously (e.g., full duplex) or along only one direction at a time (e.g., half duplex). In some instances, such as shown in FIG. 3, the wireless communication channels 304 communicatively couple every pair of the plurality of wireless nodes 302. In other instances, one or more pairs of wireless nodes 302 may lack a corresponding wireless communication channel 304.
  • Each wireless communication channel 304 includes two or more wireless links, including at least one for each direction in the bi-directional communication. In FIG. 3, an arrow represents each individual wireless link. The arrow is labeled Lij where a first subscript, i, indicates a transmitting wireless node and a second subscript, j, indicates a receiving wireless node. For example, wireless nodes N0 and N1 are communicatively coupled by two wireless links that are indicated in FIG. 3 by two arrows, L01 and L10. Wireless link L01 corresponds to wireless communication along a first direction from N0 to N1 and wireless link L10 corresponds wireless communication along a second, opposing direction from N1 to N0.
  • In some implementations, the wireless communication network 300 obtains motion data associated with a first time frame, which may include the processes of motion detection described in relation to FIGS. 2A-2B. The motion data includes a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame. The motion may be detected on a plurality of wireless links (e.g., the wireless links L01, L10, L02, L20, L12, and L21 of FIG. 3) in a wireless communication network (e.g., the wireless communication network 300). Each of the wireless links can be defined between a respective pair of wireless communication devices in the wireless communication network (e.g., pair combinations of wireless nodes N0, N1, and N2). Moreover, each of the motion indicator values is associated with a respective wireless link.
  • In some variations, the wireless communication network 300 may include a data processing apparatus that executes program instructions (e.g., a network server, a wireless communication device, a network router, etc.). The program instructions may cause the data processing apparatus to assign a unique node identifier to each of the wireless nodes 302 in the wireless communication network 300. The unique node identifier may be mapped to a media access control (MAC) address value, which corresponds to a MAC address (or portion thereof) associated with a wireless node. For example, the wireless nodes N0, N1, and N2 of FIG. 3 may be associated with a six-character portion of their respective MAC addresses, which is then mapped to a unique node identifier:

  • {N0, N1, N2}→{e565c0, e56783, e57349}→{0,1, 2}
  • Here, the MAC address values of e565c0, e56783, and e57349 are mapped to respective unique node identifiers 0, 1, and 2. The program instructions may also cause the data processing apparatus to associate the wireless links with their respective pairs of wireless nodes via corresponding pairs of MAC address values. The MAC address values may then be mapped to a unique link identifier to form a link table. For example, the wireless links L01, L10, L02, L20, L12, and L21 of FIG. 3 may be mapped to unique link identifiers according to:
  • { L 01 L 02 L 10 L 12 L 20 L 21 } { e 565 c 0 - e 56783 e 565 c 0 - e 57349 e 56783 - e 567 c 0 e 56783 - e 57349 e 57349 - e 565 c 0 e 57349 - e 56783 } { 0 1 2 3 4 5 }
  • The MAC address values may be ordered, from left to right, to indicate respective pairs of transmitting and receiving wireless nodes in a wireless link. In particular, the left MAC address value may correspond to a transmitting wireless node and the right MAC address value may correspond to a receiving wireless node. Such mappings of unique node and link identifiers may aid the data processing apparatus in performing operations, such as searching, sorting, and matrix manipulation, during processes of motion detection.
  • The program instructions may additionally cause the data processing apparatus to poll the wireless links (or wireless nodes 302) to obtain motion indicator values for each wireless link in the plurality of wireless links. For example, the wireless links of the wireless communication network 300 of FIG. 3 may report motion indicator values according to a data structure, such as shown below:
  • { 0 0.000000 1 0.022051 2 0.000000 3 0.000000 4 0.000000 5 0.000000 }
  • In the data structure, the first column corresponds to the unique link identifiers of the wireless links and the second column of the data structure corresponds to their respective motion indicator values. The data structure may be an array, as shown above, or some other type of data structure (e.g., a vector). Although data structure is presented as having six significant digits for each motion indicator value, other numbers of significant digits are possible for the motion indicator values (e.g., 3, 5, 9, etc.).
  • The program instructions may further cause the data processing apparatus to identify a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values. To do so, the data processing apparatus may sort or filter through the motion indicator values to identify the first wireless link. For example, the data processing apparatus may sort the data structure according to magnitude, thereby determining a highest motion indicator value. In the data structure, the highest motion indicator value (i.e., 0.022051) corresponds to unique link identifier 1, which maps to wireless link e565c0-e57349 (or L02 in FIG. 3). The data processing apparatus may then identify wireless link 1 as the first wireless link.
  • In some implementations, a node in the wireless communication network 300 generates a first probability vector based on a predetermined map and the first wireless link. The first probability vector includes first values assigned to the respective wireless communication devices in the wireless communication network 300. The first values represent first probabilities of motion at the respective wireless communication devices during the first time frame.
  • In some variations, the first probability vector is represented by a probability vector, P(Lj|Ni) that includes probability values (or first values) generated from the probability map. The probability values correspond to probabilities that a wireless link, Lj, exhibits link activity given motion at a wireless node, Ni. For example, the data processing apparatus may identify wireless link 1 as the first wireless link. As such, P(Lj|Ni)=P(1|Ni)={P(1|0), P(1|1), P(1|2)}. Here, P(1|0) corresponds to the probability that motion at wireless node 0 induces link activity along wireless link 1, P(1|1) corresponds to the probability that motion at wireless node 1 induces link activity along wireless link 1, and P(1|2) corresponds to the probability that motion at wireless node 2 induces link activity along wireless link 1. These probability values can be generated using map values from the probability map. The probability map may include map values that are based on a characteristic of a wireless communication device.
  • FIG. 4 is a schematic graph of an example probability map 400 having map values 402 that are based on a wireless node's status as a transmitting wireless node (Tx), a receiving wireless node (Rx), or other wireless node. In FIG. 4, the map values 402 are highest for the transmitting wireless node (Tx) in a wireless link, second-highest for the receiving wireless node (Rx) in the wireless link, and lowest for wireless nodes not associated with the wireless link. In view of these map values 402, the example probability map 400 may reflect a multi-path propagation environment that is richer around a transmitting wireless node than a receiving wireless node.
  • FIG. 5 is a schematic diagram of an example multi-path propagation environment between a transmitting wireless node 502 and a receiving wireless node 504. Wireless communication between the nodes 502, 504 is represented by arrows 506, which are denser around the transmitting wireless node 502 than the receiving wireless node 504. The arrows 506 indicate a plurality of possible propagation paths for electromagnetic radiation traveling from the transmitting wireless node 502 to the receiving wireless node 504. During propagation, the electromagnetic radiation may encounter objects, such as a wall 508 and a moving body 510. Such encounters may include interactions with the objects, including absorption, reflection, scattering, and so forth.
  • If the moving body 510 enters a region proximate the transmitting wireless node 502, the moving body 510 may have an increased interaction with the electromagnetic radiation due to a denser distribution of propagation paths. Conversely, if the moving body 510 enters a region proximate the receiving wireless node 504, the moving body 510 may have a decreased interaction with the electromagnetic radiation due to a less-dense distribution of propagation paths. As such, motion proximate the transmitting wireless node 502 may have a greater probability to induce link activity along a wireless link communicatively coupling the nodes 502, 504 than motion proximate the receiving wireless node 504. A probability map—such as the probability map 400 of FIG. 4—can reflect this bias by using map values that favor the transmitting wireless node 502.
  • Although FIGS. 4 and 5 present the probability map in the context of transmitting and receiving wireless nodes, map values may be based on other characteristics of the wireless communication devices. Such characteristics include a location of a wireless node, a wireless signal frequency of a wireless link, a distance between wireless nodes, a time of day, and so forth. In some instances, the probability map may be constructed using a priori information about a wireless node's locality. For example, a received signal strength indicator (RSSI) of a wireless link can be used as a proxy for how far apart two wireless nodes of interest are. If a wireless node is very from both the transmitting and receiving node of the wireless link far—as represented by a weak RSSI—the wireless node can be assigned a very low probability based on the static channel conditions.
  • In some cases, the first probability vector is generated based on the predetermined map and the identified first wireless link. For example, if the map values 402 of FIG. 4 are 1.0, 0.9, and 0.2 the transmitting wireless node (Tx), the receiving wireless node (Rx), and all other wireless nodes, respectively, the data processing apparatus may output P(1|Ni)={1.0, 0.2, 0.9}. In doing so, the data processing apparatus identifies wireless node 0 as the transmitting wireless node and assigns P(1|0) a value of 1.0 based on a corresponding map value in the probability map 400. Analogous mapping considerations result in the data processing apparatus assigning P(1|2) a value of 0.2 and P(1|2) a value of 0.9. Other values may be used.
  • In some implementations, the node in the wireless communication network 300 obtains a second probability vector generated from motion data associated with a prior time frame. The second probability vector includes second values assigned to the respective wireless communication devices. The second values represent prior probabilities of motion at the respective wireless communication devices during the prior time frame.
  • In some variations, the second probability vector is represented by a probability vector, P(Ni), that includes probability values (or second values) representing a probability of motion at a wireless node, Ni. The probability of motion at wireless node, Ni, for P(Ni) is independent of link activity along any of wireless links, Lj, and may also be independent of other factors. For example, the program instructions may cause the data processing apparatus to define P(Ni) according to P(Ni)={P(0), P(1), P(2)}. Here, P(Ni) has probability values of P(0), P(1), and P(2), which correspond to the probability of motion at (or proximate to) wireless nodes 0, 1, and 2, respectively.
  • During operation, the program instructions may also cause the data processing apparatus to obtain P(Ni) from the prior time frame. However, under certain conditions, the data processing apparatus may be unable to do so or lack sufficient data for completing such instructions (e.g., as a result of a component malfunction, during first power-up, etc.). Under such conditions, the data processing apparatus may set the probability values to one or more predetermined values (e.g., to initial values, reset values, etc.). For example, during first power-up, the program instructions may cause the data processing apparatus to initialize P(0), P(1), and P(2) to equal probability values, e.g., P(Ni)={0.333, 0.333, 0.333}. Although P(Ni) is presented as having three significant digits for each probability value, other numbers of significant digits are possible for the probability values (e.g., 2, 4, 6, 9 etc.).
  • In some implementations, a node in the wireless communication network 300 may determine a location of the motion detected from the wireless signals exchanged during the first time frame. The location of the motion can be determined based on the second probability vector and the first probability vector.
  • In further implementations, a node in the wireless communication network 300 may generate a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector. The third probability vector may include third values assigned to the respective wireless communication devices. The third values represent current probabilities of motion at the respective wireless communication devices during the first time frame. In these implementations, the node in the wireless communication network 300 identifies a first wireless communication device associated with the highest of the third values. Moreover, determining the location of the motion includes identifying a location (e.g., a room, zone, floor, quadrant, etc.) associated with the wireless communication device as the location of the motion detected during the first time frame.
  • In some variations, the third probability vector is represented by P(Ni|Lj), where Ni corresponds to the unique node identifier and Lj corresponds to the unique link identifier. The third probability vector, P(Ni|Lj), includes third values that represent a probability of motion at wireless node, Ni, given link activity along wireless link, Lj. For example, if wireless link 1 in the wireless communication network 300 of FIG. 3 is identified as the first wireless link, the respective third values may then be represented by P(0|1), P(1|1), and P(2|1), where P(Ni|1)={P(0|1), P(1|1), P(2|1)}. Here, P(0|1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 0, P(1|1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 1, and P(2|1) corresponds to a probability that link activity along wireless link 1 results from motion at wireless node 2.
  • The third probability vector, P(Ni|Lj), may be determined according to Eq. (1):
  • P ( N i | L j ) = P ( L j | N i ) · P ( N i ) i P ( L j | N i ) P ( N i ) ( 1 )
  • where P(Lj|Ni) and P(Ni) are as described above. Eq. (1) may allow the wireless communication network 300 (or data processing apparatus) to determine the location of detected motion using Bayesian statistics. For example, if in the wireless communication network 300 of FIG. 3, wireless link 1 is the first wireless link and P(1|Ni)={1, 0.2, 0.9}, the program instructions may then cause the data processing apparatus to calculate the third probability vector, P(Ni|1), according to:
  • P ( N i | 1 ) = P ( 1 | N i ) · P ( N i ) i P ( 1 | N i ) P ( N i ) = { 1.0 · 0.333 , 0.2 · 0.333 , 0.9 · 0.333 } ( 1.0 · 0.333 ) + ( 0.2 · 0.333 ) + ( 0.9 · 0.333 )
  • Such calculation results in P(Ni|1)={0.476, 0.095, 0.429}, with the third values summing to unity, i.e., 0.476+0.095+0.429=1. P(Ni|1) may therefore represent a probability distribution normalized to unity. In P(Ni|1), P(0|1) corresponds to the largest of the third values, indicating that motion detected by the wireless communication network 300 along wireless link 1 has the highest probability of being located at (or proximate to) wireless node 0. Based on this value of P(0|1), the program instructions may cause the data processing apparatus to look up the MAC address value of wireless node 0, and when found, output the result (e.g., output e565c0).
  • In some implementations, a node in the wireless communication network 300 performs an iterative process for sequential time frames. For example, the node may repeat the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion for each sequential time frame. In these implementations, the third probability vector of a previous iteration serves as the second probably vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
  • For example, in variations where the third probability vector is represented by P(Ni|Lj) and the second probability vector is represented by P(Ni), the third probability vector from the prior time frame may serve as the second probability vector from the first time frame to generate the first probability vector, e.g., P(Ni|Lj) from the prior time frame substitutes for P(Ni) in the first time frame in Eq. (1). As such, the data processing apparatus may nest the calculation of P(Ni|Lj) from a prior time frame within a calculation of P(Ni|Lj) of a present timeframe to recursively update the probabilities of motion at each wireless node 302 over multiple calculation cycles. The probabilities for motion at (or proximate to) each wireless communication device (or wireless node 302) may therefore be recursively updated each cycle using Bayesian statistics.
  • Although the examples presented thus far describe the wireless communication network 300 operating in the context of a single identified wireless link (e.g., the first wireless link), the wireless communication network 300 may determine a location of motion using multiple wireless links. In some implementations, identifying the first wireless link includes identifying a plurality of wireless links based on a magnitude of motion indicator values associated with each wireless link. The magnitude of motion may be relative to the other motion indicator values in the set of motion indicator values (or link table). In these implementations, generating the first probability vector includes generating a first probability vector for each of the plurality of identified wireless links based on the predetermined map and each respective wireless link
  • In some implementations, the plurality of identified wireless links includes the first wireless link and a second wireless link. The magnitude of the motion indicator associated with the first wireless link may be a highest motion indicator value, and a magnitude of the motion indicator value associated with the second wireless link may be a second-highest motion indicator value.
  • For example, in the wireless communication network of FIG. 3, a node in the wireless communication network 300 may poll the wireless links (or wireless nodes 302) to obtain motion indicator values for each wireless link. The motion indicator values may correspond to the first time frame or another time frame (e.g., subsequent to the first time frame of the previous example). The wireless links of the wireless communication network 300 of FIG. 3 may report motion indicator values in a data structure, as shown below:
  • { 0 0.000000 1 0.184735 2 0.207263 3 0.000000 4 0.094783 5 0.000000 }
  • The program instructions may also cause the data processing apparatus to sort the data structure according to magnitude to determine the two highest motion indicator values. In the data structure, the two highest motion indicator values correspond to wireless links 1 and 2 (or L02 and L10 in FIG. 3). The data processing apparatus may normalize the two highest motion indicator values to unity, thereby producing a second data structure:
  • { 1 0184735 2 0.202763 } { 1 0184735 / ( 0.184735 + 0.202763 ) 2 0.202763 / ( 0.184735 + 0.202763 ) } { 1 0.477 2 0.523 }
  • In such normalization, each of the motion indicator values is divided by a sum of all motion indicator values. The motion indicator values so-normalized sum to unity, e.g., 0.477+0.523=1. The normalized motion indicator values may be used to generate scaled third probability vectors of each of the plurality of identified wireless links, as will be described below. Although the second data structure is presented as having three significant digits for each normalized motion indicator value, other numbers of significant digits are possible for the motion indicator values (e.g., 2, 4, 6, 9, etc.).
  • In some implementations, a node in the wireless communication network 300 generates a third probability vector by combining the second values from the second probability vector with the first values from each generated first probability vector. The third probability vector may include third values assigned to the respective wireless communication devices. The third values represent current probabilities of motion at the respective wireless communication devices during the first time frame. In executing the program instructions, the wireless communication network 300 may also identify a first wireless communication device associated with the highest of the third values. Moreover, the wireless communication network 300 may determine the location the motion by identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
  • In some variations, the third probability vector is represented by P(Ni|Lj) and Eq. (1). Program instructions may then cause the data processing apparatus to generate a third probability vector for each identified wireless link. The third probability vectors may then be scaled and summed to generate an effective third probability vector, Pe(Ni|Lj), which serves as the third probability vector for the first time frame. The effective third probability vector may be determined according to Eq. (2):
  • P e ( N i | L j ) = j = id . c ( L j ) P ( N i | L j ) ( 2 )
  • Here, c(Lj) corresponds to a scaling constant for an identified wireless link, Lj, and the summation over j corresponds to all identified wireless links (id.). The scaling constant, c(Lj), is generated from the normalized motion indicator value of a respective identified wireless link, Lj, such as that stored in the second data structure.
  • For example, the second data structure described above includes a normalized motion indicator value for each of identified wireless links 1 and 2. The corresponding scaling constants are thus c(1)=0.477 for identified wireless link 1 and c(2)=0.523 for identified wireless link 2. Moreover, if the probability map described in the previous example is applicable to the time frame of the second data structure, P(1|Ni)={1.0, 0.2, 0.9} for identified wireless link 1 and P(2|Ni)={0.9, 1.0, 0.2} for identified wireless link 2. Furthermore, if the present example corresponds to a time frame after the previous example, P(Ni|1) from the previous example may serve as P(Ni) of the present example, e.g., P(Ni)=P(Ni|1)={0.476, 0.095, 0.429}.
  • In view of these example parameters, the program instructions may cause the data processing apparatus to generate the third probability vector, P(Ni|1), according to:
  • P ( N i | 1 ) = c ( L j ) P ( 1 | N i ) · P ( N i ) i P ( 1 | N i ) P ( N i ) = ( 0.477 ) { 1.0 · 0.476 , 0.2 · 0.095 , 0.9 · 0.429 } ( 1.0 · 0.476 ) + ( 0.2 · 0.095 ) + ( 0.9 · 0.429 )
  • which results in P(Ni|1)={0.540, 0.022, 0.438}. Similarly, the program instructions may also cause the data processing apparatus to generate the third probability vector, P(Ni|2), according to:
  • P ( N i | 2 ) = c ( L j ) P ( 2 | N i ) · P ( N i ) i P ( 2 | N i ) P ( N i ) = ( 0.523 ) { 0.9 · 0.476 , 1.0 · 0.095 , 0.2 · 0.429 } ( 0.9 · 0.476 ) + ( 1.0 · 0.095 ) + ( 0.2 · 0.429 )
  • which results in P(Ni|2)={0.703, 0.156, 0.141}. In each of P(Ni|1) and P(Ni|2), the probability value (or third value) for wireless node 0 is highest. Moreover, relative to P(Ni|1) from the previous example, the probability values of wireless node 0 are higher. Such increases are consistent with the predetermined map continuing to favor wireless node 0 in present time frame.
  • The program instructions may additionally cause the data processing apparatus to generate an effective third probability vector by summing the third probability vectors for wireless node 1 and wireless node 2. As such, the data processing apparatus may generate Pe(Ni|1, 2) according to P(Ni|1)+P(Ni|2)={0.626, 0.092, 0.282}. In generating the effective third probability vector, the data processing apparatus distributes the third probability vectors for each identified wireless link more finely in the final output. The effective third probability vector, Pe(Ni|1, 2), indicates that motion detected by the wireless communication network 300 has the highest probability of being located at (or proximate to) wireless node 0, as shown by Pe(0|1, 2)=0.626. Moreover, relative to the third probability vector from the previous time frame, the distribution of effective third values is more uneven and strongly favors wireless node 0, e.g., compare the newly-generated {0.626, 0.092, 0.282} to the previously-generated {0.476, 0.095, 0.429}.
  • FIG. 6 is a flowchart showing an example process 600 for determining a location of motion detected by wireless communication devices in a wireless communication network. Operations in the example process 600 may be performed by a data processing apparatus (e.g., a processor in a wireless communication device 102 in FIG. 1A) to detect a location of motion based on signals received at wireless communication devices. The example process 600 may be performed by another type of device. For instance, operations of the process 600 may be performed by a system other than a wireless communication device (e.g., a computer system connected to the wireless communication system 100 of FIG. 1A that aggregates and analyzes signals received by the wireless communication devices 102).
  • The example process 600 may include additional or different operations, and the operations may be performed in the order shown or in another order. In some cases, one or more of the operations shown in FIG. 6 are implemented as processes that include multiple operations, sub-processes or other types of routines. In some cases, operations can be combined, performed in another order, performed in parallel, iterated, or otherwise repeated or performed another manner.
  • The example process 600 includes obtaining motion data associated with a first time frame, as shown by operation 602. The motion data includes a set of motion indicator values that indicate motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in the wireless communication network. Each of the wireless links is defined between a respective pair of wireless communication devices in the wireless communication network, and each of the motion indicator values is associated with a respective wireless link.
  • The example process 600 also includes identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link, as shown by operation 604. The magnitude is analyzed relative to the other motion indicator values in the set of motion indicator values. The example process 600 additionally includes generating a first probability vector based on a predetermined map and the identified first wireless link, as shown by operation 606. The first probability vector includes first values assigned to the respective wireless communication devices. The first values represent first probabilities of motion at the respective wireless communication devices during the first time frame.
  • The example process 600 yet also includes obtaining a second probability vector generated from motion data associated with a prior time frame, as shown by operation 608. The second probability vector includes second values assigned to the respective wireless communication devices. The second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame. The example process 600 additionally includes determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, as shown by operation 610. The location of the detected motion is determined based on combining the prior probabilities from the second probability vector with the first probabilities from the first probability vector.
  • Now referring back to FIG. 3, the wireless communication network 300 may determine a location of motion detected by the wireless links by accounting for potential transitions of the motion from one wireless node 302 to another. The potential transitions of the motion may also include those remaining at, or in the immediate vicinity of, a wireless node 302. For example, the wireless communication network 300 may detect motion at or near a first wireless node disposed in a bedroom of a house. The wireless communication network 300 may account for a transition towards a second wireless node in a kitchen of the house if a corresponding time period of detection is during an eating time (e.g., breakfast, lunch, etc.). In another example, if the wireless communication network 300 detects motion at or near the second wireless node during the eating time, wireless communication network 300 may account for the detected motion remaining at or near the second wireless nodes for a future time period within the eating time. Other criteria for the potential transitions are possible.
  • In some instances, potential transitions of detected motion include criteria of time, location, or both. For example, if a time period of detection occurs during night time, a probability of detected motion transitioning from a bedroom to a washroom may be high. In contrast, a probability of the detected motion transitioning to a front door may be low. A transition probability matrix may be used to represent these differences, which are based predominantly on time: The transition probability matrix may assign a high transition probability to the detected motion transitioning from the bedroom to the washroom while assigning a low transition probability to the detection motion transitioning from the bedroom to the front door. The transition probability matrix may also account for a location of the detected motion. For example, motion detected in a living room may have a similar probability of transitioning to any another wireless node. This similar probability may incorporate considerations of time (e.g., night time, day time, etc.).
  • FIG. 7 is a schematic diagram of a wireless communication network 700 in which dashed arrows indicate potential transitions of detected motion between wireless nodes 702. The wireless communication network 700 of FIG. 7 may be analogous to the wireless communication network of FIG. 3. Features common to FIG. 3 and FIG. 7 are related via coordinated numerals that differ in increment by four hundred.
  • In FIG. 7, dashed arrows represent each potential transition for detected motion between wireless nodes 702 of the wireless communication network 700. The dashed arrows are labeled Tij where a first subscript, i, indicates an originating location and a second subscript, j, indicates a destination location. For example, wireless nodes N0 and N1 may each serve as an originating location and a destination location depending on a particular transition. Transition T01 corresponds to the detected motion transitioning from N0 to N1 and transition T10 to the detected motion transitioning from N1 to N0.
  • In some implementations, a node in the wireless communication network 700 obtains a transition probability matrix that includes transition values and non-transition values. The transition values may represent probabilities of motion transitioning between locations associated with distinct wireless communication devices, and the non-transition values representing probabilities of motion remaining within locations associated with the respective wireless communication devices.
  • In some variations, the transition probability matrix is represented by T(Ni t|Mi t−1) where Mi t−1 corresponds to the unique node identifier at which motion was detected during a prior time frame (t−1) and Ni t corresponds to the unique node identifier to which the detected motion has moved in a present time frame (t). The present time frame may be equivalent to a first time frame. The transition probability matrix, T(Ni t|Mi t−1), includes probability values, T(Ni t|Mi t−1), that can represent either a transition probability value or a non-transition probability value. For example, the transition probability matrix, T(Ni t|Mi t−1), may be expanded according to Eq. (3):
  • T ( N i t | M i t - 1 ) = { T ( 0 t | 0 t - 1 ) T ( 0 t | M i t - 1 ) T ( N i t | 0 t - 1 ) T ( N i t | M i t - 1 ) } ( 3 )
  • Here, the diagonal terms of transition probability matrix, T(Ni t|Mi t−1), correspond to Ni t=Mi t−1 and the non-diagonal terms correspond to Ni t≠Mi t−1. The diagonal terms may represent probabilities of transitioning between (or remaining at) the same wireless communication device during the present (or first) time period, e.g., T(0t|0t−1), T(1t|1t−1), T(2t|2t−1), and so forth. As such, the diagonal terms may represent non-transition probability values (or non-transition values). Similarly, the off-diagonal terms represent probabilities of transitioning from one wireless communication device to another during the present (or first) time period, e.g., T(0t|2t−1), T(3t|0t−1), T(1t|8t−1), and so forth. As such, the off-diagonal terms may correspond to transition probability values (or transition values).
  • For the wireless communication network 700 of FIG. 7, potential transitions T00, T11, and T22 may be represented by respective non-transition probability values T(0t|0t−1), T(1t|1t−1), and T(2t|2t−1). Similarly, potential transitions T01, T10, T02, T20, T12, and T21 may be represented by respective transition probability values T(1t|0t−1), T(0t|1t−1), T(2t|0t−1), T(0t|2t−1), T(2t|1t−1), and T(1t|2t−1). A full matrix, T(Ni t|Mi t−1), may then be constructed according to Eq. (3):
  • T ( N i t | M i t - 1 ) = { T ( 0 t | 0 t - 1 ) T ( 0 t | 1 t - 1 ) T ( 0 t | 2 t - 1 ) T ( 1 t | 0 t - 1 ) T ( 1 t | 1 t - 1 ) T ( 1 t | 2 t - 1 ) T ( 2 t | 0 t - 1 ) T ( 2 t | 2 t - 1 ) T ( 2 t | 2 t - 1 ) }
  • In some instances, the probability values, T(Ni t|Mi t−1), are assigned values based on a stickiness factor. The stickiness factor may be a probability of remaining at a wireless communication device divided by a probability of transitioning away from the wireless communication device (e.g., a probability ratio). For example, for the wireless communication network 700 of FIG. 7, the detected motion may be known to remain, five times out of eight, proximate any given wireless node 702. The stickiness factor may then be determined to be 0.625. As such, the non-transition probability values T(0t|0t−1), T(1t|1t−1), and T(2t|2t−1) may be assigned a value of 0.625. If the probability of transitioning to any one of the other two wireless nodes 702 is the same, the remaining transition probability values may be determined by (1−0.625)/2=0.1875. The transition probability matrix, T(Ni t|Mi t−1), may be constructed as follows:
  • T ( N i t | M i t - 1 ) = { 0.625 0.1875 0.1875 0.1875 0.625 0.1875 0.1875 0.1875 0.625 }
  • In some implementations, a node in the wireless communication network 700 determines a location of the motion detected from the wireless signals exchanged during the first time frame. The location determined is based on the first probability vector, the second probability vector, and the transition probability matrix. In further implementations, the wireless communication network 700 generates a third probability vector by combining the first probability vector, the second probability vector and the transition probability matrix. Generating the third probability vector may result from the data processing apparatus executing program instructions. The third probability vector includes the third values representing third probabilities of motion at the respective wireless communication devices during the first time frame. In executing the program instructions, the wireless communication network 300 may also identify a first wireless communication device associated with the highest of the third values. Moreover, the wireless communication network 300 may determine the location of the motion by identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
  • In some variations, the third probability vector is represented by P(Ni t|Lj t), where Ni t corresponds to the unique node identifier at a first time frame (t) and Lj t corresponds to the unique link identifier at the first time frame (t). The third probability vector, P(Ni t|Lj t), includes third values that represent, at the first time frame, a probability of motion at wireless node, Ni, given link activity along wireless link, Lj. The third probability vector, P(Ni t|Lj t), may be determined according to Eq. (4):
  • P ( N i t | L j t ) = [ P ( L j t | N i t ) · T ( N i t | M i t - 1 ) ] · P ( N i t ) i P ( L j t | N i t ) P ( N i t ) ( 4 )
  • where T(Ni t|Mi t−1), P(Lj t|Ni t), and P(Ni t) are as described above in relation to Eqs. (1) and (3). Here, the subscript, t, indicates unique node or link identifier from the first time frame (t). During recursive updating of the third probability vector, the third probability vector of a prior time, P(Ni t−1|Lj t−1), may serve as the second probability vector, P(Ni t), of the first time frame. As such, P(Ni t)=P(Ni t−1|Lj t−1) in Eq. (4), producing Eq. (5):
  • P ( N i t | L j t ) = [ P ( L j t | N i t ) · T ( N i t | M i t - 1 ) ] · P ( N i t - 1 | L j t - 1 ) i P ( L j t | N i t ) P ( N i t - 1 | L j t - 1 ) ( 5 )
  • Eqs. (4) and (5) may allow the wireless communication network 700 (or data processing apparatus) to determine the location of detected motion using Bayesian statistics while accounting for potential transitions between wireless nodes 702.
  • In some implementations, a node in the wireless communication network 700 performs an iterative process for sequential time frames. For example, the node may repeat the operations, over multiple iterations of respective time frames, of obtaining motion data, generating the first probability vector, obtaining the second probability vector, obtaining the transition probability matrix, generating the third probability vector, identifying the first wireless communication device, and determining the location of the motion. In these implementations, the third probability vector of a previous iteration serves as the second probably vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
  • In some implementations, a node in the wireless communication network 700 obtains the transition probability matrix by selecting between a first transition probability matrix and a second, distinct probability matrix. In some instances, such selections are based on a time of day. For example, program instructions may cause a data processing apparatus to select the first transition probability matrix when the first time frame corresponds to day time and the second transition probability matrix when the first time frame corresponds to night time. Other time periods are possible.
  • In some implementations, the wireless communication network 700 obtains a consensus value of motion based on the set of motion indicator values. In these implementations, obtaining the transition probability matrix includes selecting between a first transition probability matrix and a second transition probability matrix. The first transition probability matrix can be selected when the consensus value of motion has a first value (e.g., zero), and the second transition probability matrix can be selected when the consensus value of motion has another value (e.g., unity).
  • In some implementations, the first transition probability matrix is associated with no motion being detected during the first time frame. In some implementations, the second transition probability matrix is associated with motion being detected during the first time frame. In some implementations, the non-transition values of the first transition probability matrix are greater than the transition values of the first transition probability matrix. In some implementations, the transition values of the second transition probability matrix are greater than the non-transition values of the second transition probability matrix.
  • In some variations, the transition probability matrix is represented by T(Ni t|Mi t−1, C) where C corresponds to the consensus value of motion. Based on the consensus value of motion, C, one or more probability values T(Ni t|Mi t−1) of the transition probability matrix may be changed or selected, such as through the execution of program instructions by the data processing apparatus. For example, if C=0, the wireless communication network 700 may indicate no detected motion during the first time frame. In response, the data processing apparatus may change or select the probability values T(Ni t|Mi t−1) of the transition probability to define a first transition probability matrix in which the non-transition probability values are greater than the transition probability values. Conversely, if C=1, the wireless communication network 700 may indicate detected motion during the first time frame. In response, the data processing apparatus may change or select the probability values T(Ni t|Mi t−1) to define a second transition probability matrix in which the transition probability values are greater than the non-transition probability values. The second transition probability matrix may reflect a state in which the detected motion has a heightened probability of re-locating to another wireless node 702. Although the consensus value of motion, C, has been presented in the context of binary values, other values are possible for C. For example, the consensus value of motion may correspond to a plurality of values, each have a respective transition probability matrix.
  • FIG. 8 is a flowchart showing another example process 800 for determining a location of motion detected by wireless communication devices in a wireless communication network. Operations in the example process 800 may be performed by a data processing apparatus (e.g., a processor in a wireless communication device 102 in FIG. 1A) to detect a location of motion based on signals received at wireless communication devices. The example process 800 may be performed by another type of device. For instance, operations of the process 800 may be performed by a system other than a wireless communication device (e.g., a computer system connected to the wireless communication system 100 of FIG. 1A that aggregates and analyzes signals received by the wireless communication devices 102).
  • The example process 800 may include additional or different operations, and the operations may be performed in the order shown or in another order. In some cases, one or more of the operations shown in FIG. 8 are implemented as processes that include multiple operations, sub-processes or other types of routines. In some cases, operations can be combined, performed in another order, performed in parallel, iterated, or otherwise repeated or performed another manner.
  • The process 800 includes obtaining motion data associated with a first time frame, as shown by operation 802. The motion data includes a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network. Each of the wireless links can be defined between a respective pair of wireless communication devices in the wireless communication network, and each of the motion indicator values is associated with a respective wireless link.
  • The example process 800 also includes generating a first probability vector based on the set of motion indicator values, as shown by operation 804. The first probability vector includes first values assigned to the respective wireless communication devices. The first values represent first probabilities of motion at the respective wireless communication devices during the first time frame. The example process 800 additionally includes obtaining a second probability vector generated from motion data associated with a prior time frame, as shown by operation 806. The second probability vector includes second values assigned to the respective wireless communication devices. The second values represent prior probabilities of motion at the respective wireless communication devices during the prior time frame.
  • The example process 800 also includes obtaining a transition probability matrix that includes transition values and non-transition values, as shown by operation 808. The transition values represent probabilities of motion transitioning between locations associated with distinct wireless communication devices, and the non-transition values representing probabilities of motion remaining within locations associated with the respective wireless communication devices. The example process 800 yet additionally includes determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, as shown by operation 810. The location determined is based on the first probability vector, the second probability vector, and the transition matrix.
  • Some of the subject matter and operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Some of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on a computer storage medium for execution by, or to control the operation of, data-processing apparatus. A computer storage medium can be, or can be included in, a computer-readable storage device, a computer-readable storage substrate, a random or serial access memory array or device, or a combination of one or more of them. Moreover, while a computer storage medium is not a propagated signal, a computer storage medium can be a source or destination of computer program instructions encoded in an artificially generated propagated signal. The computer storage medium can also be, or be included in, one or more separate physical components or media (e.g., multiple CDs, disks, or other storage devices).
  • Some of the operations described in this specification can be implemented as operations performed by a data processing apparatus on data stored on one or more computer-readable storage devices or received from other sources.
  • The term “data-processing apparatus” encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing. The apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit). The apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them.
  • A computer program (also known as a program, program instructions, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment. A computer program may, but need not, correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
  • Some of the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
  • Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random-access memory or both. Elements of a computer can include a processor that performs actions in accordance with instructions, and one or more memory devices that store the instructions and data. A computer may also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic disks, magneto optical disks, or optical disks. However, a computer need not have such devices. Moreover, a computer can be embedded in another device, e.g., a phone, an electronic appliance, a mobile audio or video player, a game console, a Global Positioning System (GPS) receiver, or a portable storage device (e.g., a universal serial bus (USB) flash drive). Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices (e.g., EPROM, EEPROM, flash memory devices, and others), magnetic disks (e.g., internal hard disks, removable disks, and others), magneto optical disks, and CD ROM and DVD-ROM disks. In some cases, the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
  • To provide for interaction with a user, operations can be implemented on a computer having a display device (e.g., a monitor, or another type of display device) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse, a trackball, a tablet, a touch sensitive screen, or another type of pointing device) by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input. In addition, a computer can interact with a user by sending documents to and receiving documents from a device that is used by the user; for example, by sending web pages to a web browser on a user's client device in response to requests received from the web browser.
  • A computer system may include a single computing device, or multiple computers that operate in proximity or generally remote from each other and typically interact through a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), an inter-network (e.g., the Internet), a network comprising a satellite link, and peer-to-peer networks (e.g., ad hoc peer-to-peer networks). A relationship of client and server may arise by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
  • In some aspects of what is described, motion may be detected by exchanging wireless signals between wireless communication devices in a wireless communication network. In some cases, location of the detected motion may also be determined, as described by the following examples:
  • EXAMPLE 1
  • A method comprising:
      • obtaining motion data associated with a first time frame, the motion data comprising a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network, each of the wireless links defined between a respective pair of wireless communication devices in the wireless communication network, each of the motion indicator values associated with a respective wireless link;
      • identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values;
      • generating a first probability vector based on a predetermined map and the first wireless link, the first probability vector comprising first values assigned to the respective wireless communication devices, the first values representing first probabilities of motion at the respective wireless communication devices during the first time frame;
      • obtaining a second probability vector generated from motion data associated with a prior time frame, the second probability vector comprising second values assigned to the respective wireless communication devices, the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame; and
      • determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, the location determined based on the second probability vector and the first probability vector.
    EXAMPLE 2
  • The method of example 1, comprising:
      • generating a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
      • identifying a first wireless communication device associated with the highest of the third values; and
      • wherein determining the location comprises identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
    EXAMPLE 3
  • The method of example 2, comprising:
      • repeating the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion; and
      • wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
    EXAMPLE 4
  • The method of example 1 or any one of examples 2-3, wherein the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
  • EXAMPLE 5
  • The method of example 1 or any one of examples 2-4, wherein the magnitude of the motion indicator value associated with the first wireless link is a highest motion indicator value in the set of motion indicator values.
  • EXAMPLE 6
  • The method of example 1 or any one of examples 2-5, wherein the predetermined map comprises:
      • a first map value assigned to a transmitting wireless communication device of the first wireless link; and
      • a second map value assigned to a receiving wireless communication device of the first wireless link.
    EXAMPLE 7
  • The method of example 6, wherein the first map value corresponds to a highest first value of the first probability vector and the second map value correspond to a second-highest first value of the first probability vector.
  • EXAMPLE 8
  • The method of example 6 or 7, wherein the predetermined map comprises a third map value assigned to one or more wireless communication devices not associated with the first wireless link.
  • EXAMPLE 9
  • The method of example 1,
      • wherein identifying a first wireless link comprises identifying a first subset of the plurality of wireless links based on magnitudes of a motion indicator values associated with the respective wireless links; and
      • wherein generating a first probability vector comprises generating a first probability vector for each of the first subset of wireless links based on the predetermined map and each respective wireless link in the first subset.
    EXAMPLE 10
  • The method of example 9,
      • wherein the first subset of wireless links comprises the first wireless link and a second wireless link;
      • wherein the magnitude of the motion indicator associated with the first wireless link is a highest motion indicator value; and
      • wherein the magnitude of the motion indicator associated with the second wireless link is a second-highest motion indicator value.
    EXAMPLE 11
  • The method of example 9 or 10, comprising:
      • generating a third probability vector by combining the second values from the second probability vector with the first values from each respective first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
      • identifying a first wireless communication device associated with the highest of the third values; and
      • wherein determining the location comprises identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
    EXAMPLE 12
  • The method of example 11, comprising:
      • repeating the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion; and
      • wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
    EXAMPLE 13
  • A motion detection system comprising:
      • a plurality of wireless communication devices configured to exchange wireless signals on a plurality of wireless links, each of the wireless links defined between a respective pair of the wireless communication devices; and
      • a data processing apparatus configured to perform one or more operations of any one of Examples 1 through 12.
    EXAMPLE 14
  • A non-transitory computer-readable medium comprising instructions that, when executed, cause data processing apparatus to perform one or more operations of any one of Examples 1 through 12.
  • In some cases, the location of the detected motion may be determined using a transition probability matrix, as shown by the following examples:
  • EXAMPLE 15
  • A method comprising:
      • obtaining motion data associated with a first time frame, the motion data comprising a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network, each of the wireless links defined between a respective pair of wireless communication devices in the wireless communication network, each of the motion indicator values associated with a respective wireless link;
      • generating a first probability vector based on the set of motion indicator values, the first probability vector comprising first values assigned to the respective wireless communication devices, the first values representing first probabilities of motion at the respective wireless communication devices during the first time frame;
      • obtaining a second probability vector generated from motion data associated with a prior time frame, the second probability vector comprising second values assigned to the respective wireless communication devices, the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame;
      • obtaining a transition probability matrix comprising:
        • transition values representing probabilities of motion transitioning between locations associated with distinct wireless communication devices, and
        • non-transition values representing probabilities of motion remaining within locations associated with the respective wireless communication devices; and
      • determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, the location determined based on the first probability vector, the second probability vector, and the transition probability matrix.
    EXAMPLE 16
  • The method of example 15, comprising:
      • generating a third probability vector by combining the first probability vector, the second probability vector and the transition probability matrix, the third probability vector comprising the third values representing third probabilities of motion at the respective wireless communication devices during the first time frame;
      • identifying a first wireless communication device associated with the highest of the third values; and
      • wherein determining the location comprises identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
    EXAMPLE 17
  • The method of example 16, comprising:
      • repeating the operations, over multiple iterations of respective time frames, of obtaining motion data, generating the first probability vector, obtaining the second probability vector, obtaining the transition probability matrix, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion; and
      • wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
    EXAMPLE 18
  • The method of example 15 or any one of examples 16-17, wherein the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
  • EXAMPLE 19
  • The method of example 15 or any one of examples 16-18, comprising:
      • identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values.
    EXAMPLE 20
  • The method of example 19, wherein the magnitude of the motion indicator value associated with the first wireless link is a highest motion indicator value in the set of motion indicator values.
  • EXAMPLE 21
  • The method of example 15 or any one of examples 16-20, wherein generating the first probability vector comprises:
      • generating the first probability vector based on the set of motion indicator values and a predetermined map.
    EXAMPLE 22
  • The method of example 21, wherein the predetermined map comprises:
      • a first map value assigned to a transmitting wireless communication device of the identified first wireless link; and
      • a second map value assigned to a receiving wireless communication device of the identified first wireless link.
    EXAMPLE 23
  • The method of example 22, wherein the first map value corresponds to a highest first value of the first probability vector and the second map value corresponds to a second-highest first value of the first probability vector.
  • EXAMPLE 24
  • The method of example 15 or any one of examples 16-23, wherein obtaining the transition probability matrix comprises selecting between a first transition probability matrix and a second, distinct transition probability matrix.
  • EXAMPLE 25
  • The method of example 24, wherein the first transition probability matrix is selected when the first time frame corresponds to day time and the second transition probability matrix is selected when the first time frame corresponds to night time.
  • EXAMPLE 26
  • The method of example 15 or any one of examples 16-23, comprising:
      • obtaining a consensus value of motion based on the set of motion indicator values; and
      • wherein obtaining the transition probability matrix comprises selecting between a first transition probability matrix and a second transition probability matrix, the first transition probability matrix selected when the consensus value of motion has a first value, the second transition probability matrix selected when the consensus value of motion has a second value.
    EXAMPLE 27
  • The method of example 26, wherein the first transition probability matrix is associated with no motion being detected during the first time frame.
  • EXAMPLE 28
  • The method of example 26 or 27, wherein the second transition probability matrix is associated with motion being detected during the first time frame
  • EXAMPLE 29
  • The method of example 26 or any one of examples 27-28, wherein the non-transition values of the first transition probability matrix are greater than the transition values of the first probability transition matrix.
  • EXAMPLE 30
  • The method of example 26 or or any one of examples 27-29, wherein the transition values of the second transition probability matrix are greater than the non-transition values of the second transition probability matrix.
  • EXAMPLE 31
  • The method of example 26 or any one of examples 27-30, wherein the transition values and the non-transition values of the first transition probability matrix vary based on a time of day.
  • EXAMPLE 32
  • The method of example 26 or any one of examples 27-31, wherein the transition values and the non-transition values of the second transition probability matrix vary based on a time of day.
  • EXAMPLE 33
  • A motion detection system comprising:
      • a plurality of wireless communication devices configured to exchange wireless signals on a plurality of wireless links, each of the wireless links defined between a respective pair of the wireless communication devices; and
      • a data processing apparatus configured to perform one or more of the operations of any one of Examples 15 through 32.
    EXAMPLE 34
  • A non-transitory computer-readable medium comprising instructions that, when executed, cause the data processing apparatus to perform one or more of the operations of any one of Examples 15 through 32.
  • While this specification contains many details, these should not be understood as limitations on the scope of what may be claimed, but rather as descriptions of features specific to particular examples. Certain features that are described in this specification or shown in the drawings in the context of separate implementations can also be combined. Conversely, various features that are described or shown in the context of a single implementation can also be implemented in multiple embodiments separately or in any suitable sub-combination.
  • Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the implementations described above should not be understood as requiring such separation in all implementations, and it should be understood that the described program components and systems can generally be integrated together in a single product or packaged into multiple products.
  • A number of embodiments have been described. Nevertheless, it will be understood that various modifications can be made. Accordingly, other embodiments are within the scope of the following claims.

Claims (30)

1. A method comprising:
obtaining motion data associated with a first time frame, the motion data comprising a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network, each of the wireless links defined between a respective pair of wireless communication devices in the wireless communication network, each of the motion indicator values associated with a respective wireless link;
identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values;
generating a first probability vector based on a predetermined map and the first wireless link, the first probability vector comprising first values assigned to the respective wireless communication devices, the first values representing first probabilities of motion at the respective wireless communication devices during the first time frame;
obtaining a second probability vector generated from motion data associated with a prior time frame, the second probability vector comprising second values assigned to the respective wireless communication devices, the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame; and
determining, by operation of a data processing apparatus, a location of the motion detected from the wireless signals exchanged during the first time frame, the location determined based on the second probability vector and the first probability vector.
2. The method of claim 1, comprising:
generating a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
3. The method of claim 2, comprising:
repeating the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the wireless communication device, and determining the location of the motion; and
wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
4. The method of claim 1, wherein the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
5. The method of claim 1, wherein the magnitude of the motion indicator value associated with the first wireless link is a highest motion indicator value in the set of motion indicator values.
6. The method of claim 1, wherein the predetermined map comprises:
a first map value assigned to a transmitting wireless communication device of the identified first wireless link; and
a second map value assigned to a receiving wireless communication device of the identified first wireless link.
7. The method of claim 6, wherein the first map value corresponds to a highest first value of the first probability vector and the second map value correspond to a second-highest first value of the first probability vector.
8. The method of claim 6, wherein the predetermined map comprises a third map value assigned to one or more wireless communication devices not associated with the first wireless link.
9. The method of claim 1,
wherein identifying a first wireless link comprises identifying a first subset of the plurality of wireless links based on magnitudes of motion indicator values associated with the respective wireless links; and
wherein generating a first probability vector comprises generating a first probability vector for each of the the first subset of wireless links based on the predetermined map and each respective wireless link in the first subset.
10. The method of claim 9,
wherein the first subset of wireless links comprises the first wireless link and a second wireless link;
wherein the magnitude of the motion indicator associated with the first wireless link is a highest motion indicator value; and
wherein the magnitude of the motion indicator associated with the second wireless link is a second-highest motion indicator value.
11. The method of claim 9, comprising:
generating a third probability vector by combining the second values from the second probability vector with the first values from each respective first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
12. A motion detection system comprising:
a plurality of wireless communication devices configured to exchange wireless signals on a plurality of wireless links, each of the wireless links defined between a respective pair of the wireless communication devices; and
a data processing apparatus configured to perform operations comprising:
obtaining motion data associated with a first time frame, the motion data comprising a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on the plurality of wireless links, each of the motion indicator values associated with a respective wireless link;
identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values;
generating a first probability vector based on a predetermined map and the first wireless link, the first probability vector comprising first values assigned to the respective wireless communication devices, the first values representing first probabilities of motion at the respective wireless communication devices during the first time frame;
obtaining a second probability vector generated from motion data associated with a prior time frame, the second probability vector comprising second values assigned to the respective wireless communication devices, the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame; and
determining a location of the motion detected from the wireless signals exchanged during the first time frame, the location determined based on the second probability vector and the first probability vector.
13. The motion detection system of claim 12, wherein the operations comprise:
generating a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
14. The motion detection system of claim 13, wherein the operations comprise:
repeating the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the first wireless communication device, and determining the location of the motion; and
wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
15. The motion detection system of claim 12, wherein the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
16. The motion detection system of claim 12, wherein the magnitude of the motion indicator value associated with the first wireless link is a highest motion indicator value in the set of motion indicator values.
17. The motion detection system of claim 12, wherein a wireless communication device comprises the data processing apparatus.
18. The motion detection system of claim 12, wherein the predetermined map comprises:
a first map value assigned to a transmitting wireless communication device of the identified first wireless link; and
a second map value assigned to a receiving wireless communication device of the identified first wireless link.
19. The motion detection system of claim 12,
wherein identifying a first wireless link comprises identifying a first subset of the plurality of wireless links based on magnitudes of motion indicator values associated with the respective wireless links; and
wherein generating a first probability vector comprises generating a first probability vector for each of the first subset of wireless links based on the predetermined map and each respective wireless link in the first subset.
20. The motion detection system of claim 19, wherein the operations comprise:
generating a third probability vector by combining the second values from the second probability vector with the first values from each first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
21. A non-transitory computer-readable medium containing program instructions for causing a data processing apparatus to perform operations comprising:
obtaining motion data associated with a first time frame, the motion data comprising a set of motion indicator values indicating motion detected from wireless signals exchanged during the first time frame on a plurality of wireless links in a wireless communication network, each of the wireless links defined between a respective pair of wireless communication devices in the wireless communication network, each of the motion indicator values associated with a respective wireless link;
identifying a first wireless link, of the plurality of wireless links, based on a magnitude of a motion indicator value associated with the first wireless link relative to the other motion indicator values in the set of motion indicator values;
generating a first probability vector based on a predetermined map and the first wireless link, the first probability vector comprising first values assigned to the respective wireless communication devices, the first values representing first probabilities of motion at the respective wireless communication devices during the first time frame;
obtaining a second probability vector generated from motion data associated with a prior time frame, the second probability vector comprising second values assigned to the respective wireless communication devices, the second values representing prior probabilities of motion at the respective wireless communication devices during the prior time frame; and
determining a location of the motion detected from the wireless signals exchanged during the first time frame, the location determined based on the second probability vector and the first probability vector.
22. The non-transitory computer-readable medium of claim 21, wherein the operations comprise:
generating a third probability vector by combining the second values from the second probability vector with the first values from the first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the wireless communication device as the location of the motion detected during the first time frame.
23. The non-transitory computer-readable medium of claim 22, wherein the operations comprise:
repeating the operations, over multiple iterations for respective time frames, of obtaining motion data, identifying the first wireless link, generating the first probability vector, obtaining the second probability vector, generating the third probability vector, identifying the first wireless communication device, and determining the location of the motion; and
wherein the third probability vector of a previous iteration serves as the second probability vector of a present iteration, thereby allowing the third probability vector to be recursively updated.
24. The non-transitory computer-readable medium of claim 21, wherein the plurality of wireless links comprises sets of wireless links that allow bi-directional communication between a respective pair of wireless devices, each set of wireless links having at least one wireless link per direction in the bi-directional communication.
25. The non-transitory computer-readable medium of claim 21, wherein the magnitude of the motion indicator value associated with the first wireless link is a highest motion indicator value in the set of motion indicator values.
26. The non-transitory computer-readable medium of claim 21, wherein a wireless communication device comprises the data processing apparatus.
27. The non-transitory computer-readable medium of claim 21, wherein the predetermined map comprises:
a first map value assigned to a transmitting wireless communication device of the identified first wireless link; and
a second map value assigned to a receiving wireless communication device of the identified first wireless link.
28. The non-transitory computer-readable medium of claim 27, wherein the first map value corresponds to a highest first value of the first probability vector and the second map value correspond to a second-highest first value of the first probability vector.
29. The non-transitory computer-readable medium of claim 21,
wherein identifying a first wireless link comprises identifying a first subset of wireless links based on magnitudes of motion indicator values associated with the respective wireless links; and
wherein generating a first probability vector comprises generating a first probability vector for each of the first subset of wireless links based on the predetermined map and each respective wireless link in the first subset.
30. The non-transitory computer-readable medium of claim 29, wherein the operations comprise:
generating a third probability vector by combining the second values from the second probability vector with the first values from each respective first probability vector, the third probability vector comprising third values assigned to the respective wireless communication devices, the third values representing current probabilities of motion at the respective wireless communication devices during the first time frame;
identifying a first wireless communication device associated with the highest of the third values; and
wherein determining the location comprises identifying a location associated with the first wireless communication device as the location of the motion detected during the first time frame.
US16/669,177 2018-12-03 2019-10-30 Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability Abandoned US20200178033A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/669,177 US20200178033A1 (en) 2018-12-03 2019-10-30 Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US16/207,649 US10506384B1 (en) 2018-12-03 2018-12-03 Determining a location of motion detected from wireless signals based on prior probability
US16/669,177 US20200178033A1 (en) 2018-12-03 2019-10-30 Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/207,649 Continuation US10506384B1 (en) 2018-12-03 2018-12-03 Determining a location of motion detected from wireless signals based on prior probability

Publications (1)

Publication Number Publication Date
US20200178033A1 true US20200178033A1 (en) 2020-06-04

Family

ID=68766434

Family Applications (2)

Application Number Title Priority Date Filing Date
US16/207,649 Active US10506384B1 (en) 2018-12-03 2018-12-03 Determining a location of motion detected from wireless signals based on prior probability
US16/669,177 Abandoned US20200178033A1 (en) 2018-12-03 2019-10-30 Determining a Location of Motion Detected from Wireless Signals Based on Prior Probability

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US16/207,649 Active US10506384B1 (en) 2018-12-03 2018-12-03 Determining a location of motion detected from wireless signals based on prior probability

Country Status (7)

Country Link
US (2) US10506384B1 (en)
EP (1) EP3891522B1 (en)
JP (1) JP7465874B2 (en)
KR (1) KR20210096112A (en)
CN (1) CN113366331A (en)
CA (1) CA3120387A1 (en)
WO (1) WO2020113312A1 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11012122B1 (en) 2019-10-31 2021-05-18 Cognitive Systems Corp. Using MIMO training fields for motion detection
US11018734B1 (en) 2019-10-31 2021-05-25 Cognitive Systems Corp. Eliciting MIMO transmissions from wireless communication devices
US11070399B1 (en) 2020-11-30 2021-07-20 Cognitive Systems Corp. Filtering channel responses for motion detection
US11304254B2 (en) 2020-08-31 2022-04-12 Cognitive Systems Corp. Controlling motion topology in a standardized wireless communication network
US11363417B2 (en) 2019-05-15 2022-06-14 Cognitive Systems Corp. Determining a motion zone for a location of motion detected by wireless signals
US11403543B2 (en) 2018-12-03 2022-08-02 Cognitive Systems Corp. Determining a location of motion detected from wireless signals
US11570712B2 (en) 2019-10-31 2023-01-31 Cognitive Systems Corp. Varying a rate of eliciting MIMO transmissions from wireless communication devices
US11576141B2 (en) 2021-05-28 2023-02-07 Cognitive Systems Corp. Analyzing Wi-Fi motion coverage in an environment
US11740346B2 (en) 2017-12-06 2023-08-29 Cognitive Systems Corp. Motion detection and localization based on bi-directional channel sounding
US11823543B2 (en) 2019-04-30 2023-11-21 Cognitive Systems Corp. Controlling device participation in wireless sensing systems

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10567914B1 (en) 2019-04-30 2020-02-18 Cognitive Systems Corp. Initializing probability vectors for determining a location of motion detected from wireless signals
US10924889B1 (en) 2019-09-30 2021-02-16 Cognitive Systems Corp. Detecting a location of motion using wireless signals and differences between topologies of wireless connectivity
US11989965B2 (en) 2020-06-24 2024-05-21 AR & NS Investment, LLC Cross-correlation system and method for spatial detection using a network of RF repeaters
US11177872B1 (en) * 2020-06-24 2021-11-16 AR & NS Investment, LLC Managing a network of radio frequency (RF) repeater devices

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110090081A1 (en) * 2009-10-21 2011-04-21 Qualcomm Incorporated Mapping wireless signals with motion sensors

Family Cites Families (150)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4054879A (en) 1976-11-19 1977-10-18 The United States Of America As Represented By The Secretary Of The Navy Dual-frequency, remote ocean-wave spectrometer
US4649388A (en) 1985-11-08 1987-03-10 David Atlas Radar detection of hazardous small scale weather disturbances
US4740045A (en) 1986-07-02 1988-04-26 Goodson & Associates, Inc. Multiple parameter doppler radar
GB2322986B (en) 1987-10-28 1998-12-16 Licentia Gmbh Method of type classification of a target
US5613039A (en) 1991-01-31 1997-03-18 Ail Systems, Inc. Apparatus and method for motion detection and tracking of objects in a region for collision avoidance utilizing a real-time adaptive probabilistic neural network
GB9112838D0 (en) 1991-06-14 1991-10-16 Philips Electronic Associated Fmcw radar range calibration
US5696514A (en) 1996-02-28 1997-12-09 Northrop Grumman Corporation Location and velocity measurement system using atomic clocks in moving objects and receivers
US6075797A (en) 1997-10-17 2000-06-13 3Com Corporation Method and system for detecting mobility of a wireless-capable modem to minimize data transfer rate renegotiations
EP1067397B1 (en) 1999-07-03 2006-01-25 Siemens Schweiz AG Motion detector based on the Doppler principle
US7484008B1 (en) 1999-10-06 2009-01-27 Borgia/Cummins, Llc Apparatus for vehicle internetworks
US6975941B1 (en) * 2002-04-24 2005-12-13 Chung Lau Method and apparatus for intelligent acquisition of position information
ATE455330T1 (en) 2001-09-17 2010-01-15 Finlasin Technology Llc DSP ARCHITECTURE FOR BASEBAND WIRELESS APPLICATIONS
US7773614B1 (en) 2001-12-05 2010-08-10 Adaptix, Inc. Wireless communication subsystem with a digital interface
WO2012125726A1 (en) 2011-03-14 2012-09-20 Intelligent Technologies International, Inc. Cargo theft prevention system and method
US6914854B1 (en) 2002-10-29 2005-07-05 The United States Of America As Represented By The Secretary Of The Army Method for detecting extended range motion and counting moving objects using an acoustics microphone array
US6839027B2 (en) 2002-11-15 2005-01-04 Microsoft Corporation Location measurement process for radio-frequency badges employing path constraints
US7869822B2 (en) 2003-02-24 2011-01-11 Autocell Laboratories, Inc. Wireless network apparatus and system field of the invention
JP2004286567A (en) 2003-03-20 2004-10-14 Mitsubishi Electric Corp Detector and method for detecting intrusion object
US7250907B2 (en) * 2003-06-30 2007-07-31 Microsoft Corporation System and methods for determining the location dynamics of a portable computing device
US7307575B2 (en) 2004-09-14 2007-12-11 Bae Systems Information And Electronic Systems Integration Inc. Through-the-wall frequency stepped imaging system utilizing near field multiple antenna positions, clutter rejection and corrections for frequency dependent wall effects
US7256727B2 (en) 2005-01-07 2007-08-14 Time Domain Corporation System and method for radiating RF waveforms using discontinues associated with a utility transmission line
US7342493B2 (en) 2005-04-22 2008-03-11 Ultravision Security Systems, Inc. Motion detector
US9036028B2 (en) 2005-09-02 2015-05-19 Sensormatic Electronics, LLC Object tracking and alerts
CN101313233B (en) 2005-11-21 2011-10-05 日本电气株式会社 Position estimating system and position estimating method
US7904097B2 (en) 2005-12-07 2011-03-08 Ekahau Oy Location determination techniques
EP2025178A2 (en) * 2006-05-31 2009-02-18 TRX Systems, Inc. Method and system for locating and monitoring first responders
US7652617B2 (en) 2006-06-01 2010-01-26 University Of Florida Research Foundation, Inc. Radar microsensor for detection, tracking, and classification
WO2007147012A2 (en) 2006-06-13 2007-12-21 Magneto Inertial Sensing Technology, Inc. Motion sensing in a wireless rf network
US8427979B1 (en) 2006-07-27 2013-04-23 Mobitrum Corporation Method and system for dynamic information exchange on location aware mesh network devices
US8305935B2 (en) 2006-07-27 2012-11-06 Mobitrum Corporation Method and system for dynamic information exchange on location aware mesh network devices
WO2008016679A2 (en) 2006-08-02 2008-02-07 24Eight Llc Wireless detection and alarm system for monitoring human falls and entries into swimming pools by using three dimensional acceleration and wireless link energy data method and apparatus
US7783300B2 (en) 2006-11-22 2010-08-24 Airdefense, Inc. Systems and methods for proactively enforcing a wireless free zone
US8075499B2 (en) 2007-05-18 2011-12-13 Vaidhi Nathan Abnormal motion detector and monitor
US9319956B2 (en) 2008-01-15 2016-04-19 International Business Machines Corporation Method and apparatus for maintaining communications connections over a distributed wireless network
US10168414B2 (en) 2014-07-17 2019-01-01 Origin Wireless, Inc. Wireless signals and techniques for determining locations of objects in multi-path environments
US9086499B2 (en) 2008-09-23 2015-07-21 Purdue Research Foundation Clustering protocol for directional sensor networks
US8892127B2 (en) 2008-11-21 2014-11-18 Qualcomm Incorporated Wireless-based positioning adjustments using a motion sensor
US20100127853A1 (en) 2008-11-24 2010-05-27 Freeport-Mcmoran Copper & Gold Inc. Method and apparatus for locating and tracking objects in a mining environment
US8671069B2 (en) 2008-12-22 2014-03-11 The Trustees Of Columbia University, In The City Of New York Rapid image annotation via brain state decoding and visual pattern mining
US8463191B2 (en) 2009-04-02 2013-06-11 Qualcomm Incorporated Beamforming options with partial channel knowledge
US8255469B2 (en) 2009-05-29 2012-08-28 Nokia Corporation Method and apparatus for locating communities over an ad-hoc mesh network
US8305257B2 (en) 2009-09-02 2012-11-06 Trizna Dennis B Method and apparatus for coherent marine radar measurements of properties of ocean waves and currents
JP5515647B2 (en) 2009-11-05 2014-06-11 独立行政法人産業技術総合研究所 Positioning device
EP2513666B1 (en) 2009-12-18 2015-02-18 L-3 Communications Cyterra Corporation Moving entity detection
US8923424B2 (en) * 2010-02-23 2014-12-30 Qualcomm Incorporated Multi-term demapping for multi-channel wireless communication
EP2599063A2 (en) 2010-07-27 2013-06-05 Raytheon Company An intrusion detection and tracking system
US9219985B2 (en) 2010-07-27 2015-12-22 University Of Regina Method and system for cooperative stochastic positioning in a mobile environment
US8396485B2 (en) 2010-11-09 2013-03-12 Apple Inc. Beacon-based geofencing
CA2820947A1 (en) 2010-12-13 2012-06-21 Xandem Technology, Llc Systems and methods of device-free motion detection and presence detection
US20120230305A1 (en) 2011-03-08 2012-09-13 Research In Motion Limited Wi-fi network access and a mobile terminal configured for the same
JP2012190161A (en) 2011-03-09 2012-10-04 Panasonic Corp Event detection device, event detection system, event detection method, and event detection program
US10411775B2 (en) 2011-07-15 2019-09-10 Samsung Electronics Co., Ltd. Apparatus and method for beam locking in a wireless communication system
KR101764261B1 (en) 2011-07-15 2017-08-04 삼성전자주식회사 Apparatus and method for beam locking in wireless communication system
JP2013072865A (en) 2011-09-29 2013-04-22 Oki Electric Ind Co Ltd Detection device, detection method and program
US20130090117A1 (en) 2011-10-06 2013-04-11 Qualcomm Incorporated Method and apparatus for optimized reacquisition of wireless communications systems
RU2586063C2 (en) 2011-10-19 2016-06-10 Телефонактиеболагет Л М Эрикссон (Пабл) Motion detector device
WO2013089765A1 (en) 2011-12-16 2013-06-20 Intel Corporation Use of motion language for network commands in 60ghz networks
US8866663B2 (en) 2011-12-27 2014-10-21 Massachusetts Institute Of Technology Methods and apparatus for sensing organic tissue
CN102545988A (en) 2012-02-06 2012-07-04 北京新岸线无线技术有限公司 Method and device for transmitting and receiving wave beam formed matrix
JP6050008B2 (en) 2012-03-08 2016-12-21 ソニー株式会社 Discriminating apparatus, discriminating method, and discriminating system
US9185528B2 (en) 2012-06-28 2015-11-10 Northrop Grumman Systems Corporation WiFi mapping and motion detection
GB201211994D0 (en) * 2012-07-05 2012-08-22 Sensewhere Ltd Method of estimating position of user device
WO2014021574A1 (en) 2012-08-02 2014-02-06 트라텍정보통신 주식회사 Usb memory device connected with smart phone
US9551784B2 (en) 2012-09-04 2017-01-24 Honeywell International Inc. Intrusion detection
US8660578B1 (en) 2012-09-07 2014-02-25 Intel Corporation Proximity human motion detection using wireless signals
JP5998777B2 (en) * 2012-09-12 2016-09-28 ソニー株式会社 Information processing apparatus, information processing method, program, and information processing system
US9208676B2 (en) 2013-03-14 2015-12-08 Google Inc. Devices, methods, and associated information processing for security in a smart-sensored home
US9584642B2 (en) 2013-03-12 2017-02-28 Google Technology Holdings LLC Apparatus with adaptive acoustic echo control for speakerphone mode
US8847754B2 (en) 2012-11-15 2014-09-30 James Buchheim Locator beacon and radar application for mobile device
US20140351560A1 (en) 2013-05-24 2014-11-27 Motorola Mobility Llc Low Power Management of Multiple Sensor Integrated Chip Architecture
WO2014078948A1 (en) 2012-11-22 2014-05-30 Perch Communications Inc. System and method for automatically triggered synchronous and asynchronous video and audio communications between users at different endpoints
US20140145881A1 (en) 2012-11-25 2014-05-29 Amir Bassan-Eskenazi Distance measurements using a single wireless reader
US9692459B2 (en) 2012-11-28 2017-06-27 Intel Corporation Using multiple frequency bands with beamforming assistance in a wireless network
US9286693B2 (en) * 2013-02-25 2016-03-15 Hanwha Techwin Co., Ltd. Method and apparatus for detecting abnormal movement
US9438044B2 (en) 2013-03-04 2016-09-06 Hello Inc. Method using wearable device with unique user ID and telemetry system in communication with one or more social networks
WO2014155602A1 (en) 2013-03-28 2014-10-02 富士通株式会社 Terminal device, position estimation method, position estimation system, and program
JP6045747B2 (en) 2013-05-02 2016-12-14 コンソーシアム・ピー・インコーポレーテッドConsortium P Incorporated Scalable real-time position detection based on overlapping neural networks
US9395436B2 (en) 2013-06-10 2016-07-19 Honeywell International Inc. Cooperative intrusion detection
CA2820568A1 (en) 2013-06-21 2014-12-21 Ninve Jr. Inc. Dual differential doppler motion detection
KR20160039571A (en) 2013-07-26 2016-04-11 엘지전자 주식회사 Method for measuring mobility of ue for multi-antenna beamforming in wireless communication system and apparatus therefor
US9451381B2 (en) 2013-08-06 2016-09-20 Time Warner Cable Enterprises Llc Automated provisioning of managed services in a Wi-Fi capable client device
US10979203B2 (en) 2013-09-04 2021-04-13 Qualcomm Incorporated Channel selection to reduce interference to a wireless local area network from a cellular network
US9467480B2 (en) 2013-09-16 2016-10-11 Qualcomm Incorporated Selectively multiplexing incoming WebRTC traffic and/or de-multiplexing outgoing WebRTC traffic by a client-based WebRTC proxy on behalf of a WebRTC multimedia client application
JP6241177B2 (en) 2013-09-27 2017-12-06 富士通株式会社 LOCATION MODEL UPDATE DEVICE, LOCATION ESTIMATION METHOD, AND PROGRAM
US20150097653A1 (en) * 2013-10-04 2015-04-09 Cambridge Silicon Radio Limited Determination of proximity using a plurality of transponders
US9204385B2 (en) 2013-10-09 2015-12-01 Netgear, Inc. Wireless router or residential gateway capable of distinguishing power-sensitive wireless sensors and providing separate treatment thereto
JP2015087356A (en) 2013-11-01 2015-05-07 株式会社日立製作所 Position information acquisition system, position information acquisition terminal, and position information acquisition method
US10246657B2 (en) 2013-12-11 2019-04-02 Phillips 66 Company Fuel blends for homogeneous charge compression ignition engines
US9549290B2 (en) 2013-12-19 2017-01-17 Google Technology Holdings LLC Method and apparatus for determining direction information for a wireless device
US10129383B2 (en) 2014-01-06 2018-11-13 Samsung Electronics Co., Ltd. Home management system and method
WO2015114466A2 (en) 2014-01-28 2015-08-06 King Abdullah University Of Science And Technology Buffer sizing for multi-hop networks
US20150245164A1 (en) 2014-02-26 2015-08-27 Aliphcom Interaction between wearable devices via broadcasted sensor-related data
US9794355B2 (en) 2014-04-08 2017-10-17 Samsung Electronics Co., Ltd. Systems and methods for adaptive notification networks
US9867083B2 (en) 2014-04-17 2018-01-09 Cisco Technology, Inc. Wireless network controller load balancing
US10136262B2 (en) 2014-04-28 2018-11-20 Hewlett Packard Enterprise Development Lp Detecting movement in a physical environment
US11209536B2 (en) 2014-05-02 2021-12-28 The Board Of Trustees Of The Leland Stanford Junior University Method and apparatus for tracking motion using radio frequency signals
KR20150134126A (en) 2014-05-21 2015-12-01 재단법인대구경북과학기술원 Method and apparatus for processing radar signal
US9491585B2 (en) 2014-05-31 2016-11-08 Apple Inc. Location determination using dual statistical filters
US9253592B1 (en) 2014-06-19 2016-02-02 Amazon Technologies, Inc. Inter-device bearing estimation based on beamforming and motion data
WO2016005977A1 (en) 2014-07-08 2016-01-14 Trekeye Systems Ltd. A method and system for detection of changes in a defined surveyed area
EP3174835A1 (en) 2014-07-31 2017-06-07 Corning Incorporated Thermally tempered glass and methods and apparatuses for thermal tempering of glass
US11436544B2 (en) 2014-09-03 2022-09-06 CloudLeaf, Inc. System for managing an industrial workflow
US9686688B2 (en) 2014-09-24 2017-06-20 Cisco Technology, Inc. Frequency channel selection by an LTE-U wireless access point operating in the presence of other LTE-U and Wi-Fi access points
US10631123B2 (en) 2014-09-24 2020-04-21 James Thomas O'Keeffe System and method for user profile enabled smart building control
US9196432B1 (en) 2014-09-24 2015-11-24 James Thomas O'Keeffe Smart electrical switch with audio capability
US10460596B2 (en) 2014-10-31 2019-10-29 Siemens Schweiz Ag Method, digital tool, device and system for detecting movements of objects and/or living beings in a radio range, in particular of an indoor area
US9648462B2 (en) 2014-11-28 2017-05-09 Szegedi Tudományegyetem Method for tracking of motion of objects associated with wireless communication devices within a predefined area
TWI514193B (en) 2014-12-25 2015-12-21 Univ Nat Sun Yat Sen Motion detection apparatus
EP3243195A4 (en) 2015-01-06 2018-08-22 Cmoo Systems Itd. A method and apparatus for power extraction in a pre-existing ac wiring infrastructure
WO2016110844A1 (en) 2015-01-07 2016-07-14 Trekeye Systems Ltd. Improved method and system for detection of changes in a defined area
US10347108B2 (en) 2015-01-16 2019-07-09 City University Of Hong Kong Monitoring user activity using wearable motion sensing device
US9282531B1 (en) 2015-03-02 2016-03-08 Mitsubishi Electric Research Laboratories, Inc. Method and system for localization of a device in an enclosed environment based on received signal strength levels
US9706756B2 (en) 2015-03-13 2017-07-18 Michael W. Swan Animal movement mapping and movement prediction method and device
US20170311574A1 (en) 2015-03-13 2017-11-02 Michael W. Swan Animal movement mapping and movement prediction method and device
JP6644812B2 (en) 2015-05-13 2020-02-12 テレフオンアクチーボラゲット エルエム エリクソン(パブル) Beam forming
EP3314927B1 (en) 2015-06-26 2021-09-08 EntIT Software LLC Mobile device locator
US10991135B2 (en) 2015-08-11 2021-04-27 Masimo Corporation Medical monitoring analysis and replay including indicia responsive to light attenuated by body tissue
US9846220B2 (en) 2015-08-19 2017-12-19 Locix, Inc. Systems and methods for determining locations of wireless sensor nodes in a network architecture having mesh-based features for localization
US9763054B2 (en) 2015-08-19 2017-09-12 Locix Inc. Systems and methods for determining locations of wireless sensor nodes in a tree network architecture having mesh-based features
US10209688B2 (en) 2015-08-26 2019-02-19 Google Llc Smart thermostat robust against adverse effects from internal heat-generating components
EP3367883B1 (en) 2015-10-28 2019-03-13 Koninklijke Philips N.V. Monitoring activities of daily living of a person
US10564285B2 (en) 2015-11-19 2020-02-18 DSCG Solutions, Inc. Estimation of motion in six degrees of freedom (6DOF) using LIDAR
CN105424030B (en) 2015-11-24 2018-11-09 东南大学 Fusion navigation device and method based on wireless fingerprint and MEMS sensor
EP3395119A4 (en) 2015-12-23 2019-07-31 Aerial Technologies System, method and apparatus for sensing changes in an environment using wireless communication signals
US10433184B2 (en) 2015-12-31 2019-10-01 Motorola Mobility Llc Method and apparatus for directing an antenna beam based on a location of a communication device
US9980220B2 (en) 2016-02-01 2018-05-22 Cisco Technology, Inc. Low power wireless communication device and remote management techniques
ES2899403T3 (en) 2016-02-04 2022-03-11 Aerial Tech Inc Systems and methods for detecting an environment with wireless communication signals
WO2017165011A1 (en) 2016-03-23 2017-09-28 Fedex Corporate Services, Inc. Systems, apparatus, and methods for self-adjusting a broadcast setting of a node in a wireless node network
US9523760B1 (en) 2016-04-15 2016-12-20 Cognitive Systems Corp. Detecting motion based on repeated wireless transmissions
US10705179B2 (en) 2016-04-22 2020-07-07 Tandemlaunch Device-free subject localization methods and systems using wireless signals
US9584974B1 (en) 2016-05-11 2017-02-28 Cognitive Systems Corp. Detecting motion based on reference signal transmissions
US10129853B2 (en) 2016-06-08 2018-11-13 Cognitive Systems Corp. Operating a motion detection channel in a wireless communication network
US11043094B2 (en) 2016-06-08 2021-06-22 Aerial Technologies Inc. System and methods for smart intrusion detection using wireless signals and artificial intelligence
JP6792365B2 (en) 2016-07-22 2020-11-25 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカPanasonic Intellectual Property Corporation of America Content distribution system and method
US9524628B1 (en) 2016-08-04 2016-12-20 Cognitive Systems Corp. Detecting signal modulation for motion detection
JP6696377B2 (en) 2016-09-14 2020-05-20 株式会社デンソーウェーブ Radio wave source position estimation system
US9919648B1 (en) 2016-09-27 2018-03-20 Robert D. Pedersen Motor vehicle artificial intelligence expert system dangerous driving warning and control system and method
US10386792B2 (en) 2016-10-19 2019-08-20 Ants Technology (Hk) Limited Sensory systems for autonomous devices
CA3044480C (en) 2016-11-22 2024-01-02 Aerial Technologies Device-free localization methods within smart indoor environments
US10495727B2 (en) 2017-02-07 2019-12-03 Raytheon Company Phase difference estimator and method for estimating a phase difference between signals
US9989622B1 (en) 2017-03-16 2018-06-05 Cognitive Systems Corp. Controlling radio states for motion detection
US9927519B1 (en) 2017-03-16 2018-03-27 Cognitive Systems Corp. Categorizing motion detected using wireless signals
US10111228B2 (en) 2017-03-16 2018-10-23 Cognitive Systems Corp. Selecting wireless communication channels based on signal quality metrics
US9743294B1 (en) 2017-03-16 2017-08-22 Cognitive Systems Corp. Storing modem parameters for motion detection
US10051414B1 (en) 2017-08-30 2018-08-14 Cognitive Systems Corp. Detecting motion based on decompositions of channel response variations
US10109167B1 (en) 2017-10-20 2018-10-23 Cognitive Systems Corp. Motion localization in a wireless mesh network based on motion indicator values
US10048350B1 (en) 2017-10-31 2018-08-14 Cognitive Systems Corp. Motion detection based on groupings of statistical parameters of wireless signals
US9933517B1 (en) 2017-11-03 2018-04-03 Cognitive Systems Corp. Time-alignment of motion detection signals using buffers
US10109168B1 (en) 2017-11-16 2018-10-23 Cognitive Systems Corp. Motion localization based on channel response characteristics
US10108903B1 (en) 2017-12-08 2018-10-23 Cognitive Systems Corp. Motion detection based on machine learning of wireless signal properties

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110090081A1 (en) * 2009-10-21 2011-04-21 Qualcomm Incorporated Mapping wireless signals with motion sensors

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11740346B2 (en) 2017-12-06 2023-08-29 Cognitive Systems Corp. Motion detection and localization based on bi-directional channel sounding
US11403543B2 (en) 2018-12-03 2022-08-02 Cognitive Systems Corp. Determining a location of motion detected from wireless signals
US11893515B2 (en) 2018-12-03 2024-02-06 Cognitive Systems Corp. Determining a location of motion detected from wireless signals
US11823543B2 (en) 2019-04-30 2023-11-21 Cognitive Systems Corp. Controlling device participation in wireless sensing systems
US11363417B2 (en) 2019-05-15 2022-06-14 Cognitive Systems Corp. Determining a motion zone for a location of motion detected by wireless signals
US11184063B2 (en) 2019-10-31 2021-11-23 Cognitive Systems Corp. Eliciting MIMO transmissions from wireless communication devices
US11012122B1 (en) 2019-10-31 2021-05-18 Cognitive Systems Corp. Using MIMO training fields for motion detection
US11570712B2 (en) 2019-10-31 2023-01-31 Cognitive Systems Corp. Varying a rate of eliciting MIMO transmissions from wireless communication devices
US11018734B1 (en) 2019-10-31 2021-05-25 Cognitive Systems Corp. Eliciting MIMO transmissions from wireless communication devices
US11304254B2 (en) 2020-08-31 2022-04-12 Cognitive Systems Corp. Controlling motion topology in a standardized wireless communication network
US11070399B1 (en) 2020-11-30 2021-07-20 Cognitive Systems Corp. Filtering channel responses for motion detection
US11962437B2 (en) 2020-11-30 2024-04-16 Cognitive Systems Corp. Filtering channel responses for motion detection
US11576141B2 (en) 2021-05-28 2023-02-07 Cognitive Systems Corp. Analyzing Wi-Fi motion coverage in an environment

Also Published As

Publication number Publication date
CN113366331A (en) 2021-09-07
JP7465874B2 (en) 2024-04-11
KR20210096112A (en) 2021-08-04
EP3891522B1 (en) 2023-03-01
JP2022509682A (en) 2022-01-21
US10506384B1 (en) 2019-12-10
WO2020113312A1 (en) 2020-06-11
EP3891522A4 (en) 2022-01-26
CA3120387A1 (en) 2020-06-11
EP3891522A1 (en) 2021-10-13

Similar Documents

Publication Publication Date Title
US10506384B1 (en) Determining a location of motion detected from wireless signals based on prior probability
US11893515B2 (en) Determining a location of motion detected from wireless signals
US10459074B1 (en) Determining a location of motion detected from wireless signals based on wireless link counting
US10567914B1 (en) Initializing probability vectors for determining a location of motion detected from wireless signals
US11740346B2 (en) Motion detection and localization based on bi-directional channel sounding
US11006245B2 (en) Detecting a location of motion using wireless signals and topologies of wireless connectivity
US20190122514A1 (en) Motion Localization in a Wireless Mesh Network Based on Motion Indicator Values
US10264405B1 (en) Motion detection in mesh networks
CA3120197C (en) Determining a location of motion detected from wireless signals

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION