This invention introduces additional details regarding calibration and geolocation techniques first introduced in the prior referenced applications. This application focuses on simplified channel models and techniques that can exploit those models for geolocation and object classification.
In one embodiment, there is provided a method of parameter estimation in a multi-channel signal environment where a plurality of receive antennas and/or a plurality of transmitters transmit a signal that is known or estimated, that is processed over multiple frequencies or channels, by a digital receiver and one or more processors whose processing includes the following steps. First, an analytic or table driven channel model is used for comparing received voltages vs a calibrated template, without only relying on information lossy intermediate steps such as delay or angle measurements. A statistical likelihood function is used to model the receiver noise, channel parameters, or prior channel uncertainty. Then a Bayesian detection or other Statistical Signal Processing Techniques is used for the estimation of channel parameters such as location parameters, shape parameters, and reflector electromagnetic parameters. A saving target reflector/emitter parameters is reused for dynamic tracking. Finally, Bayesian particle filtering or Maximum Likelihood Methods is used to update mixture models for the unknown parameters.
Numerous other advantages and features of the invention will become readily apparent from the following detailed description of the invention and the embodiments thereof, from the claims, and from the accompanying drawings.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee. A fuller understanding of the foregoing may be had by reference to the accompanying drawings, wherein:
While the invention is susceptible to embodiments in many different forms, there are shown in the drawings and will be described in detail herein the preferred embodiments of the present invention. It should be understood, however, that the present disclosure is to be considered an exemplification of the principles of the invention and is not intended to limit the spirit or scope of the invention and/or claims of the embodiments illustrated.
Channel Model
Consider a radar configuration of the form shown in
where vmkq(pq) is the voltage seen by the m′th sensor, 1 . . . M, k′th frequency/channel, k=1 . . . K and the q′th calibration collect, q=1 . . . Q, where blmk(pq) is a channel model basis function for the m′th sensor and k′th frequency/channel, εmkq is an additive receiver thermal noise term, and where pq is the “position” and shape parameter vector, for the q′th calibration event. An unknown bulk complex scalar term βq is presumed to model any rapidly changing, highly sensitive phase dependency for each collect. It is often easier to maintain precise relative phases between antennas and frequencies, than bulk phases over time or position. The noise is assumed to be Gaussian, and can be assumed to be white, if pre-whitening is performed as needed.
The channel voltages vmkq(pq) will typically be observed after canceling a model of the stationary background data from the current, received data. The stationary background is collected over quiescent periods of the transceiver device, prior to target entering the field of view. The canceller will be preferably of the least squares type, or a simple subtraction, and can generally be written as,
v
mk
q
=x
mk
q−αqymk,
where xmkq is the raw receiver data, q is the collect index, ymk is the average background voltage for antenna m and frequency index k, and where αq are some cancellation constants. The operation is illustrated in
Note that the basis functions are typically chosen from geometric wave-functions, such as spheroidal wave functions, cylinder wave-functions and elliptical wave functions. These functions were previously described in the referenced applications. Some of the first few radial spheroidal wave functions are given by,
The actual basis functions used will be of the form hm
is the wavenumber, r1 is the distance from the transmitter to the target, and r2 is the distance from the target to a receiver. The terms containing
associated with the spherical Hankel functions of the 2nd kind represent outgoing waves and are to be preferred. Similarly we can write the first few radial cylindrical wave functions as linear combinations of the Hankel functions Hn1(κρ) and Hn2(κρ).
We can write Equation (1) in matrix form as,
v
q
=B
qαρq+εq,
where vq is a vector of length MK, whose m+(k−1)M′th element is vmkq, Bq is an MK×LMK matrix with the structure,
The log-likelihood function for the Q calibration collects can be written as,
Calibration
The calibration process for our transceiver hardware consists of setting objects to be calibrated at known positions in a calibration grid. Also measured are the transmit and receiver antenna positions all for the purpose of evaluating the blmk(pq) basis functions at position pq. The electromagnetic channel is sampled by the M receive antennas after transmitting a stepped frequency radar signal, for the radar application of this invention. The algorithm is illustrated in
Mathematically the calibration problem involves solving for target coefficients, collected in a channel gain vector α in Equation (3) either using Maximum Likelihood (ML) estimation or using Bayesian estimation with a prior distribution presumed for α. However the likelihood function can also be used to refine the otherwise known positions of the transmitter(s) and receivers. The likelihood function also serves as a starting point for the classification and localization problem itself during normal operation of the invention.
Suppose α is complex normally distributed with mean
From this, given knowledge of βq the Bayesian estimator for α is given by,
If however we need to remove the nuisance parameter βq, we can find it's maximum likelihood (ML) estimator and write it as,
βq=αHBqHvq/(αHBqHBqα). (5)
Using the ML estimator for βq in Equation (5) we obtain the likelihood function,
We can use this for Bayesian estimation presuming the empirical Bayes prior, wherein the prior for βq is the delta function centered on the Maximum Likelihood solution in Equation (5). Unfortunately Equation (6) can not be optimized in closed form over α except in very important special cases. Therefore for the general case we optimize using the following algorithm:
General Calibration Algorithm
1. Place target of desired type in known location pq and evaluate the basis functions blmk(pq).
2. Capture the complex channel values due to reflected waveform from the targets at position pq, vmkq(pq).
3. Initialize α to αmkl=0, l≠1, and αmkl=1 otherwise.
4. Compute the optimal βq using Equation (5),
5. Compute the optimal {circumflex over (α)} using Equation (4)
6. If the number of iterations is less than Nits go to General Calibration Algorithm Step otherwise stop.
When β=βq is Independent of q.
An important special case that admits a closed form solution occurs when we presume that the unknown receiver gain is actually independent of the q collect number. This situation models the case where the data collection over the q index has been performed within a short time period, or is automated and where the target environment is mostly stationary, or where gain and phase variations are adequately modeled by the blmk(pq) basis functions. It is often the appropriate model to use after calibration, but during the parameter estimation phase of the device, e.g. during geolocation or classification.
This model yields a solution for {circumflex over (β)} as,
If we ignore any priors for α, and ignoring superfluous constants, and substituting in Equation (7) we can write the likelihood function as,
This can be solved by finding the largest eigenvalue and associated vector of the generalized eigenvalue problem,
Collect Independent Algorithm
1. Place target of desired type in known location pq and evaluate the basis functions blmk(pq).
2. Capture the complex channel values due to reflected waveform from the targets at position pq, vmkq(pq).
3. Compute the optimal a by finding the eigenvector associated with the largest eigenvalue Equation (8).
Independent Basis Inner Product
This special case occurs when BqHBq≡RBB and is not dependent on q and thus independent of the parameter vector pq. The primary application for this is when we have a single phase only basis function, ie L=1. The ideal phase function for preferred use is given by,
where fk is the transmit frequency for index k, x0 is the position of the transmit antenna and xm is the position of the receive antenna for index m.
In this case βq is solved by Equation (5), and the likelihood function reduces to the Rayleigh quotient,
This allows us to write our calibration algorithm as,
Independent Basis Inner Product
1. Place target of desired type in known location pq and evaluate the basis functions blmk(pq).
2. Capture the complex channel values due to reflected waveform from the targets at position pq, vmkq(pq).
3. Compute the optimal {circumflex over (α)} by finding the eigenvector associated with the largest eigenvalue associated with the Rayleigh quotient
Blind Calibration Algorithm
For target classification, it may be necessary or desirable to perform the classification independently from any knowledge of the target position. We can support this by blindly estimating unknown basis function parameters pq or a sufficient statistic that depends on them. For the independent Basis inner product case of Independent Basis Inner Product Section we only require knowledge of the phase ramps for each antenna, or equivalently the round trip delay, rmq=(∥pq−x0∥+∥pq−xm∥)/c.
The blind algorithm is illustrated in
For the independent basis inner product algorithm we can write the likelihood from Equation (11) as,
If blmkq≡blmk(pq) is a unit phasor per Equation (9), then, ignoring superfluous constants, we can write this as,
We can thus choose optimal delays by hypothesis testing by taking the FFT over the k index of vmkqβq*αmkl*, for the case of linear frequency spacing fk.
Blind Calibration Algorithm
1. Initialize α to αmkl=0, l≠1, and αmkl=1 otherwise.
2. Capture the complex channel values vmkq due to reflected waveform from the targets target collect number q.
3. Evaluate the basis functions blmk(pq), optimizing blindly the unknown dependency on pq or equivalently rmq using Equation (3) or Equation (12) for each q.
4. Compute the optimal βq using Equation (5),
5. Compute the optimal {circumflex over (α)} using Equation (4)
6. If the number of iterations is less than Nits go to Blind Calibration Algorithm Step ( ) otherwise stop.
Classification and Localization
In order to support target classification we need to calibrate each target category and obtain the channel coefficients αc specific to category c, as shown in
Let αe be the channel coefficients for category c. From
Suppose we collect Q data vectors from our transceivers with vq the associated channel seen for collection q. Let the aggregate collection of the vq be written as V≡[v1, v2, . . . vQ]. Defining,
B(p)≡[δ(b1(p)),δ(b2(p)) . . . δ(bL((p))],
from 2 we can also define the likelihood function,
where {circumflex over (β)} is the optimal scalar dependent on the desired model chosen from the Calibration Section. If we choose the maximum likelihood solution for {circumflex over (β)}q, we can write the likelihood function as,
Prom Bayes theorem we can write,
where {circumflex over (p)}c is the optimal position parameter set for the category c. However it is possible to simply choose the phases blindly without proper array knowledge if you are primarily interested in classification instead of localization. The classification algorithm is shown graphically in
For the case where we don't have position or array information, we can classify blindly by learning the sufficient statistics for the unknown position parameter by optimizing Equation (14) over p. This can be done using FFT operations as suggested in the prior Section. The blind classification algorithm is illustrated in Blind-Classification Algorithm.
Hardware Implementation
One implementation of this invention is shown in the functional hardware block diagram in
The return signal is downconverted in the RF ASIC and then digitized by a bank of analog to digital converters, followed by a decimation filter where the data is buffered. The algorithms are implemented by DSP processors on board an ASIC device. A demonstration board containing 1 transmit antenna and 8 receive antennas is shown in
Digital Signal Processing (DSP) Architecture
In order to implement our geolocation algorithms, we need a processor architecture that, is able to compute multiple location hypotheses simultaneously. This could be implemented in a multi-processor layout, but it would be more efficient to use either a single instruction multiple data (SIMD) or single instruction multiple thread (SIMT) architecture, since the same code is executed for each hypothesis. The problem is known as “embarrassingly parallel”, since each likelihood computation can be performed without sharing much data between hypothesized positions.
In one embodiment, we implement a SIMD architecture, with some changes made from traditional approaches to make it closer to a SIMT (Single Instruction Multiple Thread) paradigm, used in heterogenous computational models such as CUDA or OpenCL. Consider the architecture shown in
Independently Addressable Local Memory Cache
For a variety of reasons we need to be able to use either the A or B registers to address a local cache of memory unique to each processor. We need this for example to support the parallel computation of transcendental functions, either using independent look up tables and multipliers or look up tables and shifts for CORDIC style algorithms.
We also need local per ALU memory to support something like a parallel FFT, which could be facilitated by distributing the FFT input, with the appropriate decimation, over each independent ALU.
Word Shuffle
We also implement some communication from one register to a neighboring ALUs dedicated register. For parallel reduction over an associative operator like addition or maximization, it suffices to simply be able to communicate with your neighboring ALU.
Consider for example the structure shown in
To support the FFT operation we may need some more complicated operations depending on the type of FFT algorithm. For the decimation in time FFT we have the basic relationship,
where q:Q:M is the Matlab notation for the sequence that starts at q, increases by Q and ends at M or before. For the case of Q=2, we have the standard power of 2 recursion,
FFT(x0:(N-1))=FFT(x0:2:(N-2))+e−2πjk/NFFT(x0:2:(N-1)).
To support a decimation in time FFT algorithm we need to be able to distribute the input, data to each local cache in a decimation order. Furthermore we need parallel reduction steps to combine the result of the FFT over each ALU section.
For full generality some standard shuffle operations such as register swapping or circular shifts should also be supported.
External IO
We also implement the ability to pass data to all the memory cache's and/or registers from an external source. Each register An must be accessible from an external source, both for reading and writing, though this operation does not require any sort of multi-port access.
Branching
While we don't need to support fully independent branching, it will be necessary to support branching by globally looping over all branches until they are exhausted over all the ALU/Register files. We also need an instruction that obtains an ALU number, so that we can index and select based on which ALU/Register pair is in consideration. Additionally having instructions that support a conditional move (similar to the C ? operator), would be helpful.
In accordance with various methods and embodiments outlined herein, there is provided in one embodiment a method of parameter estimation in a multi-channel signal environment system wherein a plurality of receiving antennas receives signals or waves from one or more targets due to one or more transmitters that transmit a predetermined signal that is reflected back from the targets or receives signals that are directly transmitted from one or more external transmitters to the receiving antennas and then processed over multiple frequencies or channels by a digital receiver connected to one or more processors. The method comprises steps including (a) comparing received voltages to an analytic or a table driven calibrated channel model without only relying on information from lossy intermediate steps such as time of arrival (“TOA”) or angle of arrival (“AOA”) measurements; and (b) mitigating channel model calibration errors, including multiplicative channel noise, phase noise, clutter or multipath modeling errors, by using a noise model to estimate away error nuisance parameters, either during a prior calibration process or during a real time calibration process concurrent with localization and parameter estimation during normal system operation.
The method may also use a Bayesian detection for the estimation of channel parameters such as location parameters, shape parameters and reflector electromagnetic parameters. A Bayesian particle filter may also be used to update mixture models for unknown parameters that might affect the reflected signal from the target. The Bayesian parameter update may also be constrained to place a lower bound on the variance in an effort to allow tracking changes in a parameter vector. It is further contemplated that wherein different shapes or reflector types are calibrated separately so that shape/type inference is possible in the Bayesian estimator.
The method may also save the reflector signal from the target parameters to be reused for dynamic tracking of the target. In other aspect of the method the predetermined transmitted signal is a frequency stepped radar. In yet another object of the invention the target is filtered by a delay range filter to minimize the clutter or focus in on known target parameter ranges. In yet other embodiments, a channel is presumed to have multiplicative Gaussian noise or additive noise not otherwise modeled by the calibration process.
In yet further embodiments, multiple targets and the clutter are separated using multi-user detection techniques such as successive interference cancellation or parallel interference cancellation. In yet other embodiments, one or more targets and the clutter are separated using multi-user detection techniques such as successive interference cancellation or parallel interference cancellation in order to compute constant modulus phase normalization gains.
The method may also track the target state by saving one or more aggregate channel estimates and their gains or whereby the channel itself is a statistical mixture or a state machine requiring multiple discrete channel vectors. The method may also trigger processing a statistic that detects changes in the environment. Other aspects of the embodiments may cause received voltages and calibration tables to be whitened by the Hermitian inverse Cholesky factor of the measured or estimated interference covariance.
In addition, the parameter model includes higher order dynamic parameters such as velocity or acceleration. The method may also use the progression of shapes or locations to infer gesture types. In yet further embodiments, the invention makes use of a higher order singular value decomposition to compress a neural network into a single layer of optimized sum of products form. The method may also decompose the gesture recognition problem, into a set of discrete states whose transitions can be estimated using Bayesian techniques.
The method may also interpolate a wave function using basis functions that are reflected through objects of predetermined shape and electrical properties. As outlined herein, the method may also use a reproducing kernel to generate a model of the reflected signal or a waveform at the receive antennas. The reproducing kernel may be used to dynamically learn the shape of the reflector and/or its electrical parameters. A series decomposition of the reproducing kernel may be used to obtain basis functions of the reflected wave. Alternatively, a higher order singular value decomposition may be used to decompose a tabulated version of the reproducing kernel using far fewer singular values.
In yet further embodiments, electromagnetic imaging techniques are used to find basis functions for the reflected signal or wave. The method may also use conformal mappings to find basis functions for the reflected wave. A Cauchy-Kovalevskaya extension may be used to predict the basis functions for the reflected wave. A Vekua transform may be used to transform a set of basis functions for the simpler Laplace equation into the basis function is used for the more general Helmholtz equation.
The method may factor out the phase centers of an array of antennas for either removal or to reduce the number of bits required for accurate phase representation of the array. As further contemplated a coupling matrix is applied to the output of the array to model mutual antenna coupling. A Bicomplex Clifford algebra, that tracks both the complex pseudoscalar and the unit phasor may be used as separate commuting complex units.
From the foregoing and as mentioned above, it is observed that numerous variations and modifications may be affected without departing from the spirit and scope of the novel concept of the invention. It is to be understood that no limitation with respect to the embodiments illustrated herein is intended or should be inferred. It is intended to cover, by the appended claims, all such modifications within the scope of the appended claims.
The present invention in a continuation in part of U.S. application Ser. No. 16/541,730, and this application and the parent application claim priority to U.S. Provisional Application Ser. No. 62/764,814 filed on Aug. 16, 2018, both of which are incorporated in their entirety by reference.
Number | Date | Country | |
---|---|---|---|
62764814 | Aug 2018 | US | |
62764814 | Aug 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16541730 | Aug 2019 | US |
Child | 16542342 | US |