The present disclosure relates to motion detection based on at least one source audio signal.
Collaboration endpoints are generally used for multimedia meetings. These endpoints may include cameras, displays, microphones, speakers, and other equipment configured to facilitate multimedia meetings. Endpoint equipment often remains activated for long periods of time even when the equipment is only used intermittently for multimedia meetings.
A controller of a collaboration endpoint generates a primary audio signal for an ultrasonic source audio signal produced by a source audio speaker, a reference audio signal for the ultrasonic source audio signal, and, based on the reference audio signal, a predicted signal that is predictive of the primary audio signal. The controller produces a prediction error of the predicted signal by comparing the primary audio signal with the predicted signal and determines whether the prediction error is indicative of a motion of one or more persons near the collaboration endpoint.
When endpoint equipment (e.g., cameras, displays, microphones, speakers, etc.) remains activated during periods of nonuse during a multimedia conference session, the equipment wastes electricity and experiences decreases in life expectancy. Therefore, as described in greater detail below, endpoint equipment may enter a standby mode when the conference room in which the endpoint is located is empty. When a user enters the room, the endpoint equipment may detect motion in the room and, in response, activate (enter an active mode from a standby mode) in anticipation of a multimedia meeting.
With reference made to
When user 106 is participating in a multimedia conference, this equipment is active and facilitates user 106 participation in the multimedia conference. Camera 112 and microphones 116(a)/116(b) capture video and audio, respectively, for transmission to one or more of endpoints 104(a)-104(n). Display 114 and speaker 118 output video and audio, respectively, transmitted from one or more of endpoints 104(a) 104(n).
When the multimedia conference ends, the user 106 exits conference room 102. At this point, there are no people in conference room 102, and thus no movement in the conference room 102. In accordance with the motion detection logic 122, the endpoint controller 120 controls the components of the endpoint 104 to enter a standby mode in order to detect motion (e.g., the motion of one or more persons near the endpoint 102). As explained below, when motion is detected (e.g., when one or more persons are near the endpoint 102), the endpoint controller 120 controls the components of the endpoint 104 to activate (enter an active mode from the standby mode) in anticipation of a multimedia meeting.
During standby mode, camera 112 and display 114 may simply shut off/deactivate/power down/etc. However, speakers 118, 124 emit ultrasonic source audio signals. In an example, speaker 124 continuously emits its ultrasonic source audio signal, even when the components of the endpoint 104 are in standby mode, because the speaker 124 is not connected to the endpoint controller 120. Also during standby mode, microphones 116(a)/ 116(b) continuously sample the ultrasonic source audio signals from speakers 118 and 124.
In this example, the signals produced by microphones 116(a)/116(b) in response to the ultrasonic source audio signals serve as reference audio signals. Meanwhile, the ultrasonic source audio signal produced by speaker 118 is known to the endpoint controller 120 and serves as a primary audio signal. As explained in greater detail below, the endpoint controller executes the motion detection logic 122 to generate, based on the reference audio signals, a predicted signal that is predictive of the primary audio signal. The motion detection logic 122 compares the primary audio signal with the predicted signal to determine whether there is motion of one or more persons near the endpoint 104.
While in standby mode, the endpoint 104 may operate actively or passively. In active standby mode, the speaker 118 integrated with the endpoint 104 transmits an ultrasonic audio signal into an area/room/location (e.g., conference room). In passive standby mode, the endpoint 104 does not transmit an ultrasonic audio signal.
Speakers 224(1)-(I) produce respective source audio signals s1(t), s2(t), s1(t). Source audio signals s1(t), s2(t), s1(t) include ultrasonic frequencies (e.g., 20-24 kHz). Each microphone 216(1)-(J) captures the source audio signals s1(t), s2(t), s1(t) after the source audio signals have traversed the room and, in response, produces a respective signal x1, x2, x3, . . . , xJ. Each signal x1, x2, x3, . . . , xJ is a superposition of source audio signals convolved with impulse responses (e.g., h11, h12, etc.) and a noise signal (e.g., n1, n2, etc.). For purposes of viewability, only the impulse responses and the noise signals corresponding to the microphones 216(1) and 216(2) are shown. Signal x1 may be referred to as a primary audio signal and signals x2, x3, . . . , xJ may be referred to as reference audio signals.
The endpoint 104 detects motion by predicting the delayed time frequency representation of primary signal x1 of microphone 216(1) based on the reference signals x2, x3, . . . , xJ of microphones 216(2)-(J). An endpoint controller of endpoint 104 (not shown) feeds each signal x1, x2, x3, . . . , xJ through a respective filter bank 226(1)-(J). These filter banks 226(1)-(J) separate the primary audio signal and reference audio signal into sub-bands. For instance, the filter banks 226(1)-(J) respectively partition the signals x1, x2, x3, . . . , xJ into time-frequency domain signals X1(m,k), X2(m,k), X3(m,k), . . . , XJ(m,k), where m and k denote a frame index and a frequency bin index, respectively. As explained in greater detail below, the delay operator 230 delays the time-frequency representation of the primary signal, X1(m,k), by D frames, resulting in the time-frequency domain signal X1(m−D, k). The endpoint controller of endpoint 104 respectively feeds the time-frequency domain representations of the reference signals, X2(m,k), X3(m,k), . . . , XJ(m,k), through adaptive filters 228(2)-(J), respectively. In an example, the adaptive filters 228(2)-(J) are normalized least mean square filters. The endpoint controller of endpoint 104 sums the contributions of the filtered time-frequency domain representations of the reference signals, X2(m,k), X3(m,k), . . . , XJ(m,k), to generate a predicted signal {circumflex over (X)}1(m−D,k) that is predictive of the delayed time-frequency representation of the primary signal X1(m−D, k). The endpoint controller of endpoint 104 generates prediction error E(m−D,k)=X1(m−D,k)−{circumflex over (X)}1(m−D,k) by comparing the delayed time-frequency representation of the primary audio signal with the predicted signal.
The endpoint controller of endpoint 104 determines whether the prediction error is indicative of the motion of one or more persons near the endpoint 104. The endpoint controller of endpoint 104 updates the adaptive filter coefficients based on the prediction error and sends the prediction error to the detector 232. A relatively large prediction error may indicate motion more strongly than a relatively small prediction error. As discussed above, if the endpoint controller of endpoint 104 determines that there is motion of one or more persons near the collaboration endpoint 104, the endpoint controller of endpoint 104 may activate the components of endpoint 104 in anticipation of a multimedia meeting.
The following is a mathematical derivation of primary signal x1 expressed as a function of the reference signals x2, x3, . . . , xJ.
Signal x1 is the superposition of the contributions from the audio signals s1(t), s2(t), . . . , s1(t) and a noise signal n1. This can be written mathematically as
x
1(t)=(h11*s1(t)+(h12*s2)(t)+ . . . +(h1I*s1)(t)+n1(t), (1)
where * is the convolution operator and h1i, i ∈ {1, 2, . . . I}, denotes the impulse response from the ith audio speaker to the first microphone. Signal x1 is a digital signal (i.e., the sampled and quantized version of the analog signal captured at microphone 216(1)), and t denotes the sample index. The variables in (1) are functions of time. Assuming these signals are stationary, (1) may be re-written in the frequency domain as
X
1(f)=H11(f)S1(f)S1(f)+H12(f)S2(f)+ . . . +H1I(f)S1(f)+N1(f), (2)
where upper case variables are used to denote the discrete-time Fourier transform (DTFT) corresponding to the respective lower case variables, with f ∈ [0, 1] denoting digital frequency. Using vector notation, (2) can be written more compactly as
X
1(f)=H1T(f)S(f)+N1(f), (3)
where S(f)=[S1(f), S2(f), . . . , SI(f)]T and H1(f)=[H11(f), H12(f), . . . , H1I(f)]T are I-dimensional vectors. Similar equations can be written for the other microphone signals:
where Hj(f)=[Hj1(f), Hj2(f), . . . , HjI(f)]T for j ∈ [2, 3, . . . , J] are I-dimensional vectors. (4)-(6) can be written even more compactly using matrix notation as
X(f)=H(f)S(f)+N(f), (7)
where X(f)=[X2(f), X3(f), . . . , XJ(f)]T and N(f)=[N2(f), N3(f), . . . , NJ(f)]T are J−1-dimensional vectors and
is a J−1×I-dimensional matrix. From (7), if the columns of H(f) are linearly independent (this requires that J>1),
S(f)=(HT(f)H(f))−1HT(f)(X(f)−N(f)), (9)
Substituting S(f) into (3) yields
where Ĥ1(f)=H1T(f)(Ht(f)H(f))−1HT(f)=[{tilde over (H)}12(f), {tilde over (H)}13(f), . . . , Ĥ1.1(f)]T and Ñ1(f)=N1(f)−{tilde over (H)}1T(f)N(f).
Returning to scalar notation yields
X
1(f)={tilde over (H)}12(f)X2(f)+{tilde over (H)}13(f)X3(f)+ . . . +{tilde over (H)}1J(f)XJ(f)+Ñ1(f), (13)
and
x
1(t)=(ti12*x2)(t)+(h13*x3)(t)+ . . . +(h1,J*xj)(t)+h1(t), (14)
(14) is a formulation of the signal x1 of microphone 216(1) as a function of the signals x2, x3, . . . , xJ of microphones 216(2)-(J).
However, the impulse h̆12, h̆13, . . . h̆1,J are not causal. For example, in a case involving J=2 microphones and I=1 source, x1(t)=(h̆12(x2)(t)+ń1(t). If the single source is located closer to microphone 1 than to microphone 2, microphone 1 receives the sound before microphone 2 and {tilde over (h)}12 is thus necessarily non-causal. Because it is desired for the impulse responses to be causal, one or more of the impulse responses h̆12, h̆13, . . . h̆1,J may be delayed by T samples, where T may be equal to at least an amount of time between generating the primary audio signal and generating the reference audio signal. In the example of
x
1(t−T)=(g12*x2)(t)+(g13*x3(t)+ . . . +(g1,J*xJ)(t)+ñ1(t−T), (15)
where g1j, j ∈ {2, 3, . . . , J}, is a T-sample delayed version of {acute over (h)}1j. When the impulse responses are causal, the T-sample delayed microphone signal x1(t−T) may be predicted with multichannel adaptive filtering, as shown in (16) below:
{circumflex over (x)}
1(t−T)=(w2*x2(t)+(w3*x3)(t)+ . . . +(wJ*x1)(t), (16)
where w2, w3, . . . , wJ denote the J−1 vectors of adaptive filter coefficients. As long as the impulse responses g12, g13, . . . , g1J are approximately constant and the noise term ñ1(t) is approximately stationary and small compared to the reference signal terms in (15), the prediction error is expected to be small. This is typically the case when a person is not in the room. When one or more of the impulse responses changes or the noise term ñ1(t) suddenly increases (e.g., due to a person entering the conference room in which the endpoint 104 is located), the prediction error increases. Thus, as shown in (16), the endpoint 104 detects motion by predicting the T-sample delayed primary signal x1 of microphone 216(1) based on the reference signals x2, x3, . . . , xJ of microphones 216(2)-(J).
In an example, the detector 232 detects motion based on an estimate P(m,k) of the mean square error. The detector 232 may use exponential recursive weighting such as
P(m,k)=αP(m−1,k)+(1−α)|E(m,k)|2, (17)
where α is a forgetting factor in the range [0,1). For example, for some threshold P,
P(m,k)<P⇒No motion, (18)
P(m,k)≥P⇒Motion. (19)
Thus, in this example, the detector detects motion from an increase in P(m,k). If P(m,k) is less than a threshold P, the endpoint controller of endpoint 104 may conclude that there is no motion of one or more persons near the endpoint 104. If the P(m,k) is equal to or greater than the threshold P, the endpoint controller of endpoint 104 may conclude that there is motion of one or more persons near the endpoint 104.
The above derivation involves multichannel adaptive filtering in the digital time domain. Alternatively, the endpoint controller of endpoint 104 may perform multichannel adaptive filtering in the time-frequency domain. Time-frequency domain adaptive filtering is computationally cheaper and provides faster convergence than time domain adaptive filtering. In addition, time-frequency domain adaptive filtering allows the endpoint 104 to predict only the ultrasonic portion of the signal x1 while ignoring other frequencies.
In this example, signal x1 is the primary signal and signal x2 is the reference signal. As in
The following is a mathematical derivation of the discrete time Fourier transform of the primary signal X1(f) expressed as a function of the discrete time Fourier transform of the reference signal X2(f) in the example of
H(f)=H21(f), (20)
the channel vector in (12) reduces to the scalar
(13) thus simplifies to
Thus, filtering X2(m,k) with linear adaptive filter 228(2) may enable the endpoint controller of endpoint 104 to generate predicted signal {circumflex over (X)}1(m−D,k), and determine whether the prediction error is indicative of the motion of one or more persons near the endpoint 104.
Turning now to
In this example, signal x1 is the primary signal and signals x2, x3 are reference signals. As in
The following is a mathematical derivation of the discrete-time Fourier transform of the primary signal, X1(f), expressed as a function of the discrete-time Fourier transform of the reference signals, X2(1), X3(1), in the example of
This matrix has linearly independent columns, which means (13) can be re-written as
X
1(f)={tilde over (H)}12(f)X2(f)+{tilde over (H)}13(f)X3(f)+Ñ1(f). (25)
Thus, respectively filtering X2(m,k), X3(m,k) with linear adaptive filters 228(2)-(3) may enable the endpoint controller of endpoint 104 to generate predicted signal {circumflex over (X)}1(m−D,k), and determine whether the prediction error is indicative of the motion of one or more persons near the endpoint 104.
As mentioned above,
With reference first to
In this example, signal x1 is the primary signal and signals x2-xJ are reference audio signals. Speakers 224(1)-(I) produce respective source audio signals s1(t), s2(t), . . . , s1(t). Each microphone 216(1), 216(3)-(J) captures the source audio signals s1(t), s2(t), s1(t) after the source audio signals have traversed the room and, in response, produces a respective signal x1, x3, . . . , xJ. In addition, endpoint controller generates reference signal x2 for source audio signal s1 since the speaker 224(1) is integrated into the endpoint 104 and, as such, the endpoint controller of endpoint 104 knows the source audio signal s1. In other words, the speaker 224(1) serves as both a source audio device and a reference audio device. Each signal x1, x3, . . . , xJ is a superposition of source audio signals convolved with impulse responses (e.g., h11, h12, etc.) and a noise signal (e.g., n1, etc.). For purposes of viewability, only the impulse responses and noise signal corresponding to the primary microphone 216(1) are shown.
The endpoint 104 detects motion by predicting the delayed time-frequency representation of the primary signal x1 of microphone 216(1) based on the time-frequency representations of the reference signals x2, x3, . . . , xJ. In other words, X1(m−D,k) is predicted from X2(m,k), X3(m,k), . . . , XJ(m,k). An endpoint controller of endpoint 104 feeds each of the audio signals x1, x2, x3, . . . , xJ through a respective filter bank 226(1)-(J). These filter banks 226(1)-(J) respectively partition the audio signals x1, x2, x3, . . . , xJ into time-frequency domain signals X1(m,k), X2(m,k), X3(m,k), . . . , XJ(m,k), where m and k denote a frame index and a frequency bin index, respectively. The delay operator 230 delays the time-frequency representation of the primary signal, X1(m,k), by D frames, resulting in X1(m−D, k). The endpoint controller of endpoint 104 respectively feeds the time-frequency domain representations of the reference audio signals, X2(m,k), X3(m,k), . . . , XJ(m,k), through adaptive filters 228(2)-(J). The endpoint controller of endpoint 104 sums the contributions of the filtered time-frequency domain representations of the reference audio signals to generate a predicted signal {circumflex over (X)}1(m−D,k) that is predictive of the delayed time-frequency representation of the primary signal, X1(m−D, k). The endpoint controller of endpoint 104 generates prediction error E(m−D,k)=X1(m−D,k)−{circumflex over (X)}2(m−D,k) by comparing the delayed time-frequency representation of the primary audio signal with the predicted signal. As mentioned above, the endpoint controller of endpoint 104 determines whether the prediction error is indicative of the motion of one or more persons near the endpoint 104 and, if the endpoint controller determines that there is motion of one or more persons near the collaboration endpoint 104, the endpoint controller of endpoint 104 may activate endpoint components in anticipation of a multimedia meeting.
Much of the mathematical framework for passive mode motion detection described above applies to active mode motion detection. This is because the active mode can be viewed as a special case of passive mode in which one of the source audio speakers has been moved very close to one of the microphones, such that the relative contributions from the other source audio signals and any noise are so small that they can be neglected. As such, in the example of
and, since N2(f)=0,
N(f)=[0 N3(f) . . . NJ(f)]T. (27)
In this example, microphone signal x1 is the primary audio signal and loudspeaker signal x2 is the reference audio signal. As in
In this case, the matrix in (8) reduces to the scalar
H(f)=1, (28)
the channel vector in (12) reduces to the scalar
Ĥ
1(f)=H12(f), (29)
and
Ñ
1(f)=N1(f), (30)
(13) thus simplifies to
X
1(f)=H11(f)S1(f)+N1(f). (31)
Hence, the endpoint controller of the endpoint 104 may generate the predicted signal {acute over (X)}1(m−D,k) by filtering X2(m,k) through adaptive filter 228(2).
In this example, microphone signal x1 is the primary audio signal and audio signals x2, x3 are reference audio signals. As in
Mathematically the matrix in (8) reduces to
This matrix has linearly independent columns in general, which means that (13) can be rewritten as
X
1(f)={tilde over (H)}12(f)X2(f)+{tilde over (H)}12(f)X3(f)+Ñ1(f), (33)
where {tilde over (H)}12(f) and {tilde over (H)}13(f) are functions of H11(f), H12(f), H31(f), and H32(f). The noise Ñ1(f)=N1(f)−{tilde over (H)}13(f)N3(f). Hence, the endpoint controller of the endpoint 104 may generate the predicted signal {tilde over (X)}1(m−D,k) by filtering X2(m,k), X3(m,k) through adaptive filters 228(2)-(3).
As mentioned above,
In this example, audio signal x1 is the primary audio signal and microphone signals x2-xJ are reference audio signals. Speakers 224(1)-(I) produce respective source audio signals s1(t), s2(t), . . . , sI(t). Each microphone 216(1)-(J) captures the source audio signals s1(t), s2(t), . . . , sI(t) after the source audio signals have traversed the room and, in response, produces a respective signal x1, x3, . . . , xJ. In addition, the endpoint controller of the endpoint generates primary audio signal x1 for source audio signal s1 since the speaker 224(1) is integrated into the endpoint 104 and, as such, the endpoint controller knows the source audio signal s1. In other words, the speaker 224(1) serves as both an audio device and a primary audio device. Each signal x2, x3, . . . , xJ is a superposition of source audio signals convolved with impulse responses (e.g., h21, h22, etc.) and a noise signal (e.g., n2, etc.). For purposes of viewability, only the contributions and noise signal corresponding to the primary microphone 216(2) are shown.
The endpoint 104 detects motion by predicting the delayed time-frequency representation of the primary signal x1(t) from the time-frequency representations of the reference signals x2(t), x3(t), . . . , xJ(t). In other words, X1(m−D,k) is predicted from X2(m,k), X3(m,k), . . . , xJ(m,k).The endpoint controller of the endpoint 104 feeds each audio signal x1, x2, x3, . . . , xJ through a respective filter bank 226(1)-(J). These filter banks 226(1)-(J) respectively partition the audio signals x1, x2, x3, . . . , xJ into time-frequency domain signals X1(m,k), X2(m,k), X3(m,k), . . . , XJ(m,k), where m and k denote a frame index and a frequency bin index, respectively. The delay operator 230 delays the time-frequency representation of the primary signal, X1(m,k), by D frames, resulting in X1(m−D, k). The endpoint controller of the endpoint 104 respectively feeds the time-frequency domain representations of the reference audio signals, X2(m,k), X3(m,k), . . . , XJ(m,k), through adaptive filters 228(2)-(J). The endpoint controller sums the contributions of the filtered time-frequency domain representations of the reference audio signals to generate a predicted signal {circumflex over (X)}1(m−D,k) that is predictive of the delayed time-frequency representation of the primary signal X1(m−D, k). The endpoint controller generates prediction error E(m−D,k)=X1(m−D,k)−{circumflex over (X)}1(m−D,k) by comparing the delayed time-frequency representation of the primary audio signal with the predicted signal. As mentioned above, the endpoint controller determines whether the prediction error is indicative of the motion of one or more persons near the collaboration endpoint 104 and, if the endpoint controller determines that there is motion of one or more persons near the endpoint 104, the endpoint controller may activate endpoint components in anticipation of a multimedia meeting.
Like in the example of
In this example, audio signal x1 is the primary audio signal and audio signal x2 is the reference audio signal. As in
In this case the matrix in (8) reduces to the scalar
H(f)=H21(f), (34)
the channel vector in (12) reduces to the scalar
(13) then simplifies to
Hence, the endpoint controller of the endpoint 104 may generate the predicted signal {circumflex over (X)}1(m−D,k) by filtering X2(m,k) through adaptive filter 228(2).
More specifically,
In this example, the microphone signal x1 is the primary audio signal and audio signal x2 is the reference audio signal. As in
The memory 1142 may include read only memory (ROM), random access memory (RAM), magnetic disk storage media devices, optical storage media devices, flash memory devices, electrical, optical, or other physical/tangible memory storage devices. Thus, in general, the memory 1142 may include one or more tangible (non-transitory) computer readable storage media (e.g., a memory device) encoded with software comprising computer executable instructions and when the software is executed (by the processor 1146) it is operable to perform the operations described herein.
Using the techniques presented herein, collaboration endpoints may accurately detect motion in a conference room in which the endpoint is located. Upon detecting motion, a collaboration endpoint may enter active mode and, for example, display a friendly and informative greeting to the user. Endpoint motion detection may also be used to trigger burglar alarms, control lights/blinds, record and/or analyze the usage of the conference room, provide up-to-date information regarding the usage of the conference room, etc.
These techniques are power efficient because the endpoint may constantly monitor for motion while in standby mode. Moreover, these techniques may be deployed on existing and/or future (to be developed) endpoints. In addition, extra/additional hardware may not be required, thereby minimizing cost and complexity. Further, impulse responses may be non-linear and/or time-variant due to, for example, systems having poor quality amplifier cards, or when an ultrasonic pairing signal is played through a television with poor quality amplifiers and/or speakers.
The techniques described herein may also be desirable in situations involving multiple collaboration endpoints in the same room that each produce ultrasonic pairing signals. This is often the case in office spaces and classrooms where each user has a personal endpoint in the same room. These techniques may also be compatible with ultrasonic noise from other equipment, such as third party motion detectors in the ceiling. In addition, they are operable in large rooms that are not properly covered with an optimal number of microphones.
The number of signals used for motion detection by the endpoint is at least one more than the number of audio source signals. Thus, since one signal is used as the primary signal, the number of reference audio signals is equal to at least the number of audio source signals. In addition, it may be desirable to locate microphones far from speakers. In an example, microphones may be located throughout a conference room so as to provide accurate motion detection coverage for the entire room.
In one form, a method is provided. The method comprises: at a controller of a collaboration endpoint, generating a primary audio signal for an ultrasonic source audio signal produced by a source audio speaker; generating a reference audio signal for the ultrasonic source audio signal; generating, based on the reference audio signal, a predicted signal that is predictive of the primary audio signal; producing a prediction error of the predicted signal by comparing the primary audio signal with the predicted signal; and determining whether the prediction error is indicative of motion of one or more persons near the collaboration endpoint.
In another form, an apparatus is provided. The apparatus comprises: a source audio speaker; at least one microphone of a collaboration endpoint; and one or more processors coupled to a memory, wherein the one or more processors are configured to: generate a primary audio signal for an ultrasonic source audio signal produced by the source audio speaker; generate a reference audio signal for the ultrasonic source audio signal; generate, based on the reference audio signal, a predicted signal that is predictive of the primary audio signal; produce a prediction error of the predicted signal by comparing the primary audio signal with the predicted signal; and determine whether the prediction error is indicative of a motion of one or more persons near the collaboration endpoint.
In another form, one or more non-transitory computer readable storage media are provided. The non-transitory computer readable storage media are encoded with instructions that, when executed by a processor of a collaboration endpoint, cause the processor to: generate a primary audio signal for an ultrasonic source audio signal produced by a source audio speaker; generate a reference audio signal for the ultrasonic source audio signal; generate, based on the reference audio signal, a predicted signal that is predictive of the primary audio signal; produce a prediction error of the predicted signal by comparing the primary audio signal with the predicted signal; and determine whether the prediction error is indicative of a motion of one or more persons near the collaboration endpoint.
The above description is intended by way of example only. Although the techniques are illustrated and described herein as embodied in one or more specific examples, it is nevertheless not intended to be limited to the details shown, since various modifications and structural changes may be made within the scope and range of equivalents of the claims.
This application is a continuation of U.S. patent application Ser. No. 15/496,362, filed Apr. 25, 2017, the entirety of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 15496362 | Apr 2017 | US |
Child | 16655601 | US |