This disclosure relates to device navigation, including spacecraft navigation.
A spacecraft can be navigated via sightings to landmarks, sometimes known as optical navigation, using techniques similar to those used by mariners and aviators. Navigation using landmarks allows for spacecraft autonomy from ground command, control, and tracking stations.
A direction measurement to a known landmark constrains the vehicle to lie on a line. Repeated direction measurements to unknown landmarks during a pass can also be used to update the spacecraft's position and velocity. Using known landmarks provides better sensitivity for precise orbit determination and better tie to the Earth fixed frame. On the other hand, using unknown landmarks does not require landmarks to be identified in various lighting conditions and it does not require a map or database of landmarks as it can use any visually distinctive feature.
Autonomous landmark navigation is especially important to deep space missions that need to navigate near another body, such as for rendezvous with an asteroid. Conventional techniques require assumptions that the central body's orientation is perfectly modeled, that corrections are obtains from an external source, or that the spacecraft clock used to time tag the measurements has no errors. High-accuracy long duration autonomous flight requires accounting for errors in the orientation of the central body and measurement of the independent variable: time.
The accompanying drawings, which are incorporated in and constitute part of the specification, illustrate embodiments of the disclosure and, together with the general description given above and the detailed descriptions of embodiments given below, serve to explain the principles of the present disclosure. In the drawings:
Features and advantages of the present disclosure will become more apparent from the detailed description set forth below when taken in conjunction with the drawings, in which like reference characters identify corresponding elements throughout. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. The drawing in which an element first appears is indicated by the leftmost digit(s) in the corresponding reference number.
In the following description, numerous specific details are set forth to provide a thorough understanding of the disclosure. However, it will be apparent to those skilled in the art that the disclosure, including structures, systems, and methods, may be practiced without these specific details. The description and representation herein are the common means used by those experienced or skilled in the art to most effectively convey the substance of their work to others skilled in the art. In other instances, well-known methods, procedures, components, and circuitry have not been described in detail to avoid unnecessarily obscuring aspects of the disclosure.
References in the specification to “one embodiment,” “an embodiment,” “an exemplary embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to understand that such description(s) can affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
Embodiments of the present disclosure enable high fidelity long-duration autonomous spacecraft navigation relative to a planet's surface and measuring the dynamics of the planet. For a planet like Earth, embodiments of the present disclosure can be used to estimate the unpredictable components of Earth's orientation with respect to the inertial frame. Embodiments of the present disclosure further enable autonomous landmark navigation by providing systems and methods for satellites to autonomously recognize landmarks, using, for example, multiple computer vision approaches to recognize multiple types of landmarks
Embodiments of the present disclosure improve reliability and enable new missions for military and civil space. For spacecraft orbiting Earth, embodiments of the present disclosure can provide systems and methods for long-term autonomous navigation without a requirement for global positioning satellite (GPS) or regular ground contacts for ephemeris updates. For spacecraft orbiting other planets, embodiments of the present disclosure can enable a way to “bootstrap” navigation in an environment without GPS, with limited contacts, and with incomplete or even no prior knowledge of available landmarks. Navigation using landmarks allows for spacecraft autonomy from ground command, control, and tracking stations. This enables navigation to be immune to disruptions of the ground infrastructure, whether caused by equipment malfunctions, natural disasters, jamming, or sabotage. Landmarks can include any object, useful for navigation, which can be observed by a spacecraft. Autonomous landmark navigation can be especially important for deep space missions that need to navigate near another body, such as for rendezvous with an asteroid.
Convolutional neural networks can be used to classify objects in images, and segmentation routines such as U-net can be used to label each pixel in an image according to a “class.” Algorithms, such as the Scale Invariant Feature Transform (SIFT) algorithm can provide key point detection based on difference of Gaussians. Speeded Up Robust Features (SURF) is another algorithm that can be used for key point detection and matching. Features form Accelerated Segment Test (FAST) is an algorithm that can perform corner detection, while Rotated Binary Robust Independent Elementary Features (BRIEF) is a feature detector. Oriented FAST & BRIEF (ORB) combines FAST and BRIEF and can be used to perform key point detection and matching in a manner similar to SIFT and SURF, but faster.
Conventional navigation techniques have drawbacks, including requiring assumptions that the central body's orientation is perfectly modeled, that corrections are obtained from an external source, or that the spacecraft clock used to time tag the measurements has no errors. These assumptions can be especially problematic for high-accuracy long duration autonomous flight, which can require accounting for errors in the orientation of the central body and measurement of the independent variable time. Embodiments of the present disclosure can use Earth landmarks in changing seasons and weather and can include explicit estimation of Earth's orientation in space. Embodiments of the present disclosure provide systems and methods that can adapt and train for specific landmarks, can use machine learning techniques to identify specific airports, and can associate individual pixels over large perspective changes.
In step 204, the observations can be reduced. For example, in an embodiment, the observations can be reduced (e.g., using controller 108 and/or processor 110) such that each observation of a landmark includes the direction from navigational device 102 to the landmark in the inertial frame. This can be accomplished, for example, by using a machine learning model to locate a mountain peak in an image and a star tracker to determine the spacecraft's orientation in the inertial frame. Optionally, autonomous measurements of range to the landmark may be included (e.g., radio detection and ranging (RADAR) or light detection and ranging (LIDAR)).
In step 206, the observations can be combined (e.g., using controller 108 and/or processor 110) to estimate the trajectory, clock, and central body orientation of navigational device 102 (e.g., in an embodiment, using weighted lease squares or an extended Kalman filter). In step 208, the estimate from step 206 can be used (e.g., using controller 108 and/or processor 110) to conduct operations and to plan further landmark observations. The process can then optionally return to step 202.
In step 304, the landmark can be identified (e.g., using controller 108 and/or processor 110) in an image using, for example, an object detection algorithm, such as a convolutional neural net (CNN). In an embodiment, the algorithm can be used to detect landmarks and label an image chip as a particular landmark. In step 306, the image can be segmented into pixels identifying them as part of or not part of the landmark. For example, in an embodiment, an image segmentation algorithm, such as a U-Net, can be used to segment the individual pixels of the image as those part and not part of the landmark (e.g., road or not road).
In step 308, the landmark location is used (e.g., using controller 108 and/or processor 110) for estimation. For example, in an embodiment, through a series of affine transformations, the image segmentation can be matched against the landmark database to associate known central body fixed coordinates with particular locations in the image. In step 310, the estimate can be used (e.g., using controller 108 and/or processor 110) to add one or more additional landmarks. For example, in an embodiment, the association between image pixel locations and central body fixed coordinates can be used as input to step 206 in the method of
As discussed above, embodiments of the present disclosure provide systems and methods for reducing observations and estimating navigational data in a more efficient and comprehensive way than that of conventional techniques. For example, to reduce observations, embodiments of the present disclosure can convert an image to landmark directions by combining computer vision and machine learning algorithms in parallel. In an embodiment, this includes training a convolutional neural network to find the landmarks of interest and passing the result along to an image segmentation model that can extract navigational information on a pixel-based level. To estimate navigational data, embodiments of the present disclosure can calculate the trajectory, clock, and central body orientation (e.g., estimating Earth Orientation Parameters (EOP)) of navigational device 102 from landmark observations.
Embodiments of the present disclosure provide several advantages, including autonomy from large ground station networks maintained by the International Earth Rotation Service (IERS), US Naval Observatory (USNO), and others to measure Earth's orientation in space. Conventional techniques required these Earth Orientation Parameters (EOP) to be uplinked to a spacecraft. Embodiments of the present disclosure enable a spacecraft to be able to determine EOP autonomously. Further, the measured EOP may be useful science data. For example, a deep space mission to a comet could estimate some physical parameters of its central body autonomously. As mentioned earlier, autonomy provides opportunities for increased resiliency, reliability, and capability while using fewer ground resources.
Exemplary systems and methods for landmark identification with respect to embodiments of the present disclosure will now be discussed in greater detail. The Oriented Features from Accelerated Segment Test (FAST) and Rotated Binary Robust Independent Elementar Features (BRIEF) (ORB) detector is an algorithm that computes features in images called key points that are used as references into a database to perform object recognition. This algorithm shares similarities with the Scale Invariant Feature Transform (SIFT) and will be used to facilitate the detection of Tiepoints on airport runways and the unique road networks nearby that service the detected airport.
In an embodiment, SIFT looks at features in an image that are invariant to rotation, translation, and local geometric distortions. The algorithm creates features from the image called key points, which is the result of a difference of Gaussians in scale-space. These key points can be used to create a database of feature vectors which allows it to match previously seen images to the one that is currently being presented to the system.
The SIFT algorithm has been successfully used for object recognition, robotic vision, gesture recognition, and 3D modeling and other computer vision related domains; however, SIFT has significant problems with repeating patterns (e.g., a Hawaiian shirt) as it finds key points everywhere that are similar, and it cannot accurately match them in the database. It also has problems with specular reflections. The ORB algorithm is two orders of magnitude faster that SIFT, enables near real-time matching of images, and uses FAST to find key points and BRIEF to describe the relationship between the key points for matching.
In an embodiment, for Scale Invariant Feature Transform (SIFT) to detect the key points, the first step is to perform a Gaussian convolution across the different scales in scale-space for the entire octave. The points of interest can given by calculating the Difference of Gaussians (DoG). The DoG D(x, y, σ) can given by:
D(x,y,σ)=L(x,y,kiσ)−L(x,y,kjσ) (1)
where L(x, y, ki, σ) is the convolution of the original image I(x, y) with the Gaussian blur G(x, y, kσ) at scale kσ, i.e.:
L(x,y,kσ)=G(x,y,kσ)*I(x,y) (2)
Hence, in an embodiment, a DoG image between scales is the difference of Gaussian-blurred images at different scales kiσ and kjσ. These images are grouped by octaves, where an octave is a doubling of σ, and the value ki is chosen to obtain a fixed number of convolved images per octave. Once these DoG images have been obtained, the key points can be calculated on a pixel-wise basis by comparing the 8 neighbor pixels across all scales. If this calculation is a minimum or a maximum, then it can be considered as a candidate key point. These candidate key points can be further refined through key point localization. In an embodiment, the first step is to perform an interpolation of nearby data to accurately determine its position. This interpolation is performed by using the quadratic Taylor series expansion of D(x, y, σ) with the candidate key point as the origin. This expansion is given by:
where D and its derivatives are evaluated at the candidate key point and {right arrow over (x)}=(x, y, σ)T is the offset from the point. The location of the extremum, {circumflex over ({right arrow over (x)})} can be determined by taking the derivative and setting it to zero. If the offset {circumflex over ({right arrow over (x)})} is greater than 0.5 in any dimension, it indicates that the extremum lies closer to another key point. Note that SIFT uses several heuristics/rules of thumb that have been determined empirically for general scene matching (e.g., {circumflex over ({right arrow over (x)})}≤0:5).
In an embodiment, the final steps for candidate key point localization are discarding low-contrast key points and the elimination of sharp edge responses (to make the final key points robust in dealing with small amounts of noise). To discard the low-contrast key points, the second-order Taylor expansion D({right arrow over (x)}) can be computed at the offset {circumflex over ({right arrow over (x)})}. In an embodiment, if this value is less than 0.03, the candidate key point is discarded. Otherwise, it can be kept for further processing, with the final scale-space location {right arrow over (y)}+{circumflex over ({right arrow over (x)})}, where {right arrow over (y)} is the original location of the candidate key point.
In general, DoG functions have strong edge responses. In an embodiment, to make the key points resilient to small amounts of noise, candidate key points that are potential noise need to be eliminated. This can be done by solving for the Eigenvalues of the second-order Hessian matrix {right arrow over (H)}:
The ratio r of the larger eigenvalue α to the smaller one β is sufficient for use in the filtering process of SIFT, i.e. r=α/β. For ease of calculation, the trace of {right arrow over (H)}, Dxx+Dyy, yields the sum of the two eigenvalues, and the determinant, DxxDyy−Dxy2, yields the product. The ratio
To detect poorly localized key points, SIFT can use a threshold
then that key point can be rejected.
In an embodiment, to determine the orientation of the image, each key point is assigned one or more orientations based on the direction of the local image gradient. This step allows SIFT to be invariant to rotations as the key point descriptor that will be created is relative to this orientation. In an embodiment, the first step is to take the Gaussian-smoothed image L(x, y, σ) at the key point's scale σ to make it invariant to scale. Therefore, for an image sample L(x, y) at scale σ, the gradient magnitude m(x, y) and orientation θ(x, y) can be precomputed using pixel differences, i.e.:
Next, in an embodiment, an orientation histogram is formed with 36 bins (one bin for every 10 degrees). Each sample in the neighboring window can be added to the appropriate histogram bin and weighted by their gradient magnitude as well as by a Gaussian-weighted circular window with a σ that is 1.5 times the scale of the key point. Once the histogram has been computed, the orientations that are within 80% can be assigned to the key point.
In an embodiment, to create a Key Point Descriptor from these key points that are invariant to location, scale and rotation, a 128 dimensional vector is created through the following process. First, a set of orientation histograms can be created on 4×4 pixel neighborhoods with 8 bins each. These histogram can be created from the magnitude and orientation values of samples in a 16×16 region around the key point such that each histogram contains samples from a 4×4 subregion of the original region. The scale 6 for the key point can be used to generate a Gaussian-blurred image and can be further weighted by another Gaussian function with a 6=0.2 (empirically chosen). The final vector can be created from the 4×4 subregions (16 histograms), and each histogram can have 8 bins which yields the 128 dimensional vector for the key point descriptor. This vector can then be normalized for invariance to scale and can be used to match the key points that make up an object in a test image.
SIFT's can be used in the field of object recognition and can detect multiple images in satellite imagery. It can be used to detect, place, and describe 3D objects using an affine transformation with a single camera (as opposed to stereo cameras). Other uses include robot localization, image reconstruction, remote sensing, and panoramic image stitching (note that this is not an exhaustive list of applications).
Oriented FAST and Rotated BRIEF (ORB) can be used as an efficient and alternative to SIFT. In an embodiment, at a high-level, FAST is an efficient corner detector, BRIEF is a feature detector, and ORB builds on both of these to find key points in a given image for matching in a similar fashion as SIFT. In an embodiment, ORB is faster than SIFT and Speeded Up Robust Features (SURF) for most applications.
2.4 FAST: Features from Accelerated Segment Test
In an embodiment, FAST can be used to detect corners in digital images. In an embodiment, FAST can use the following process. 1. Select a pixel p that is a candidate corner point. Its intensity can be defined as Ip. 2. Select an appropriate threshold value t. 3. Calculate a circle of 16 pixels around p (Bresenham circle r=3). 4. p is a corner if there exists a set of n contiguous pixels in the circle which are all brighter than Ip+t, or all darker than Ip−t. 5. To speed up the process, the intensity of pixels of 1, 5, 9, and 13 can be compared with Ip. If at least 3 of the 4 pixels satisfy this condition, then p as a corner exists. 6. If at least three of the four pixel values of 1, 5, 9, and 13 are not above or below Ip+t, then check all pixels on the circle and see if 12 pixels fall within the criterion. 7. Repeat for all pixels in the image. In an embodiment, there are a couple of limitations to this process. First, if n<12, it has a tendency to find false corners. This implies that n is most likely sensitive to the resolution of the images under consideration. Second, if the corner isn't oriented so that the first test catches it, the algorithm slows down.
To deal with these problems, a Machine Learning (ML) approach can be used. For example, the following process can be used: 1. Select a training set of images from the target domain. 2. Run FAST on every image to find the corner/feature points. 3. For every corner/feature point, store the 16 pixels around it as a vector. Perform this for all images to generate feature vector {circumflex over (p)}. 4. Each pixel x in these 16 pixels can have one of three states:
5. Depending on the states, the feature vector {circumflex over (p)} is placed into three subsets {circumflex over (p)}d, {circumflex over (p)}s, and {circumflex over (p)}b. 6. Define a variable Kp which is true if p is an interest point and false if it is not. 7. Use the ID3 algorithm to query each subset using the variable Kp to find the true class labels. 8. ID3 operates on the principle of reducing entropy; i.e. find the pixel x which has the most information about pixel p. 9. The entropy for the set P is represented by:
10. Recursively apply H(P) to all subsets until the entropy is zero. 11. The decision tree created is then used for FAST detection in other images. A problem with this ML approach is that there could be multiple points of interest that are shared in the circle. The solution to this is to apply Non-maximal Suppression: 1. Compute a score function V for all detected feature points. V is given by:
where Bi are points on the Bresenham circle around pixel p (n=16 in practice). 2. Consider two adjacent feature/key points and compute their V values. 3. Discard the point with the lower V value.
In an embodiment, a problem with FAST is that it expects crisp corners on an X-Y axis (i.e. a standard digital images). For use in ORB, this will be oriented to detect corners of an object even if it was rotated. One can also use a Gaussian blur to help alleviate this problem.
FAST can be used as a method to calculate a key point/feature. In an embodiment, the next problem is how to quickly match the key points to a known object in a manner that similar to SIFT. One major drawback to SIFT is that it uses a 128-dimensional feature vector to describe a key point, and as the number of key points grows, significant computational overhead is incurred. Some potential approaches to deal with this problem include (1) Principle Component Analysis (PCA) or Linear Discriminant Embedding (LDE); (2) Reduce the number of bits in the SIFT descriptor or change floating points to integers (use Hamming distance for matching); and (3) Convert the descriptor to binary and use Locally Sensitive Hashing (LSH) and Hamming distance to match.
While these methods help to give a speed increase with SIFT, it is still computationally expensive. SURF can be used to address this problem; however, as n, the number of points, increases it starts to have significant slow-downs as well. BRIEF can be used to address these problems. In an embodiment, to start, define a test τ on patch p of size S×S as:
where p(x) is the pixel intensity in a smoothed version of p at x=(u, v)T. Choosing a set of nd(x, y) location pairs uniquely defines a set of binary tests. This is the BRIEF descriptor and is a n-dimensional string:
In an embodiment, to perform the patch test, Uniform and Gaussian smoothing kernels can be used. In an embodiment, to address many of the shortcomings previously mentioned, ORB can be used to produce results similar but faster to SIFT. In an embodiment, the major contributions of BRIEF include: (1) the addition of a fast and accurate orientation component to FAST; (2) the efficient computation of oriented BRIEF Features; (3) analysis of variance and correlation of oriented BRIEF features; and (4) a learning model for de-correlating BRIEF features under rotational invariance, which boosts performance in nearest-neighbor applications. FAST features are computationally efficient; however, they are sensitive to rotation. In ORB, the corner orientation is given by calculating the intensity centroid of the patch. First, the moment of the patch under consideration is calculated:
which can be used to find the centroid:
Finally, a vector is constructed from the corner's center, O, to the centroid, {right arrow over (OC)}. This is used with the quadrant aware version of arctan, arctan 2, to find the orientation θ of the patch:
θ=arctan 2(m01,m10) (13)
In an embodiment, BRIEF uses equations 9 and 10, along with a 5×5 test patch in a 31×31 pixel window of a larger patch to generate the ORB feature vector. Note that, in an embodiment, these numbers (5×5 and 31×31) are determined empirically based on the data. Finally, to make brief invariant to in-plane rotation, a set of rotation and perspective warps can be used for each patch; however, these are computationally expensive. In an embodiment, ORB uses a more efficient steering method. In an embodiment, this works by taking a feature set of n binary tests at location (xi, yi) and using it to define a 2×n matrix:
Using the patch orientation θ and the corresponding rotation matrix Rθ, a steered version Sθ of S can be constructed as:
S
θ
=R
θ
S (15)
This can be used to yield the steered BRIEF operator:
g
n(p,θ)=fn(p)|(xi,yi)∈Sθ (16)
The methods used to create BRIEF allow for key points to be robustly matched in a manner similar to SIFT.
In an embodiment, object detection is a technique for locating and drawing bounding boxes around objects to the nearest degree possible and assigning class labels to those bounding boxes. In an embodiment, neural networks can be used to locate buildings in data-sets from around the world; however, the coarseness of the bounding box locations can result in a higher fidelity method for geolocating specific points on a map at the pixel level.
In an embodiment, data augmentation can be used when training the neural networks. In an embodiment, this is the practice of perturbing a smaller set by blurring, obscuring, zooming, flipping, rotating, etc., to create a larger set of training data. In an embodiment, not only does this create a larger data-set for training, but these distortions also attempt to teach the model how to handle a broader scope of images it may encounter in the field. The concept of adding in external information to the raw imagery data can be a very rich line of research that is useful for GeoINT applications. Previously data-sets have been very stagnate sets of images with head on perspective with ImageNet or at unknown angles for the MS-COCO data-set used for autonomous driving algorithms. The regimental nature of satellite orbits gives us in the Bayesian worldview a set of priors. To incorporate these priors there is typically either the tact of preprocessing input data to a network or post-processing results. Post-processing can be used to add geometric constraints that a specific object is between a minimum and maximum size in pixels.
In an embodiment, image (a.k.a. semantic) segmentation is the technique used to assign a class on a pixel-by-pixel basis. An example includes deciphering which pixels are part of a road and which are not a road. Using a U-Net architecture, a convolutional network used for fast and precise segmentation of images, pixels can be labeled as either a road or not-road, creating a topography of nodes and connections outlining where the model predicts a road is. Taking into account object detection and its ability to detect objects of interest at a lower level of precision, semantic segmentation can provide more precise information about where objects of interest are located in the image. This precise information can provide stronger information for localizing landmarks.
In an embodiment, the metric of performance used can be F1-Scores or a variation of Intersection-over-Union (IoU). In an embodiment, this performance attempts to score a models ability to identify, on a pixel-by-pixel basis, the pixel value predicted with the pixel value of the ground truth image. Other metrics also employ a technique to score how well the predicted graph matches up with the ground truth graph through graph theory based upon shortest path algorithms. In an embodiment, the two techniques of object detection and image segmentation can be combined, using object detection as a means of locating an object of interest and deploying image segmentation to decipher our area of interest to a more granulated precision.
This section describes the observability of additionally estimating an offset in the Earth Rotation Angle (ERA) from measurements of landmarks on Earth's surface in accordance with embodiments of the present disclosure. Though the term ERA will be used in this section, it is not limited to Earth—the analysis is general enough it applies to any similar bodies.
In an embodiment, for a measurement model, assume a simplified model of Earth's rotation where the ERA is
θ(t)=θ0+ω⊕t (17)
with
R
E→H
=R
{circumflex over (k)}(nt)Rî(i)R{circumflex over (k)}(Ω)R{circumflex over (k)}(−θ) (18)
where ω⊕ is the angular velocity of the Earth. The θ0 is an additional state to be estimated. The transformation from the Earth fixed to the Hill frame can be represented by:
r
H
=R
E→H
r
E
−αî (19)
with
R
E→H
=R
{circumflex over (k)}(nt)Rî(i)R{circumflex over (k)}(Ω)R{circumflex over (k)}(−θ) (20)
where Râ(b) is a frame rotation constructed from the given axis and angle, i is inclination, Ω is right ascension of the ascending node, and θ is true anomaly. The additional term in the measurement equation is
where [·]x is the cross product matrix. Now evaluated along the nominal trajectory rgH=d so the previous equation can be written in terms of d instead of rg.
The last simplification is possible because cross products commute with rotations if they are about the same axis. For easier notation the previous equation will be written as
and it is noted that E is skew symmetric and time dependent. The entries of E are
where cn=cos(nt), sn=sin(nt), ci=cos(i), and si=sin (i). The new measurement equation is
where the state vector has been augmented with θ0. Assuming {circumflex over (d)} is constant in the Hill frame, all landmarks are on Earth, and further assume a spherical Earth so that d does not vary. Then the only time varying component of the measurement equation is E.
For a process model, integrating and augmenting with θ0 gives the solution
where sn=sin(nt) and cn=cos(nt).
For observability, let (t)=H(t)X(t). The integral condition for observability is the linear independence of the columns of Ψ(t). The system is observable in the interval [t0, t1] iff there is no nonzero vector x such that Ψ(t)x=0 for almost all t∈[t0, t1]. The phrase “almost all” can be defined to mean everywhere except at a countable set of points. The system given by (25) and (26) is observable iff the following are true: (1) n>0; (2) d≠∞; (3) {circumflex over (d)}Tî≠0; (4) {circumflex over (d)}Tĵ≠0; (5) {circumflex over (d)}T{circumflex over (k)}≠0; and (6) i≠π/2.
Proof: First construct Ψ from (25) and 26).
Then solve Ψx=0.
where α(t) is any function of time. The above assumes d≠0 and d≠∞. Expanding the last equation and grouping in terms of orthogonal functions of time gives the system of equations
d
1α(t)=cnk1+snk2+k3
d
2α(t)=cnk4+snk5+tk6+k7
d
3α(t)=cnk8+snk9 (30)
with
where x=[r1 r2 r3 v1 v2 v3 θ0]T. Now each of the equations (30) can be satisfied either when dj=0 or when α(t) is the right hand side divided by the corresponding dj. From the assumptions deriving the measurement equation (the landmark is on the Earth) d1≠0. This leaves four possible cases to check: (1) d1≠0, d2=0, d3=0; (2) d1≠0, d2≠0, d3=0; (3) d1≠0, d2=0, d3≠0; and (4) d1≠0, d2≠0, d3≠0.
Case 1—
d
2=0⇒k4=0⇒v1=0
k
5=0⇒v2=−2nr1
k
6=0⇒r1=0⇒v2=0
k
7=0⇒r2=(a+d1)ciθ0
d
3=0⇒k8=0⇒r3=−(a+d1)siθ0
k
9=0⇒v3=0 (32)
Now (a+d1) 6=0 since the landmark is not at the center of the Earth. That leaves two possible solutions.
In the later case r3=−tan(i)r2 though in both cases θ0 is left as a free variable. Therefore case 1 is unobservable because there is a non-zero θ0 such that Ψx=0 for all t.
In the case r2, r3, and v3 are functions of the free variable θ0. Therefore case 2 is also unobservable.
The condition k3=0 implied no additional constraints. In this case r1, r3, and v2 are functions of the free variable θ0. Therefore case 3 is also unobservable.
The condition ⇒k3=0⇒ciθ0=0 has two solutions:
In the former case θ0 is a free variable so it is unobservable. In the later case r1 through v3 are zero since they are a scalar multiple of θ0. Therefore in that case, the system is observable because there is no nonzero x that satisfies Ψx=0. Since 0≤i≤π, ci≠0 implies i≠π/2.
Though the unobservable directions have zero area on the celestial sphere and the unobservable inclination is a single point they do have important implications for spacecraft operations. Namely that under the assumptions, the spacecraft looks both cross-track as well as in-track when collecting observations and that spacecraft in exactly polar orbits will not be able to estimate an ERA offset.
When the orbit is polar, a measured in-track or radial bias no longer contains any information about the ERA, as it would for other inclinations. In an embodiment, this leads to the remaining six state variables becoming inseparable for an ERA bias. The popular Sun-Synchronous Orbit (SSO) has an inclination near, but greater than π/2. So a SSO has at least theoretical observability.
This section describes the observability of additionally estimating the motion of Earth's pole with respect to its crust, extending the analysis of the previous section. Only cases where the spacecraft state and ERA are observable will be considered.
For a measurement model, a simplified model of polar motion is the rotation matrix
where xp and yp are the coordinates of the pole, which are assumed to be small angles. The pole coordinates (xp, yp) are appended to the state vector as two additional states to be estimated and, for simplicity, are assumed to be constant over the estimation interval. Let E* be the Earth fixed frame with polar motion. Then, as before, the transformation to the Hill frame can be written and derivatives of d computed to form the linearized measurement model.
The new measurement equation is
For a process model, augmenting the state vector with two additional constant states, (xp, yp), gives the integrated solution
and brings the dimension of the state vector to 9.
For observability, first construct Ψ from (42) and (43).
Then solve Ψx=0.
where α(t) is any function of time. The above assumes d≠0 and d≠∞. Expanding the last equation and grouping in terms of functions of time gives the system of equations:
d
1α(t)=cnk11+snk12+k13+k14cω
d
2α(t)=cnk21+snk22+k23+k24cω
d
3α(t)=cnk31+snk32+k36c++k37s++k38c−+k39s− (51)
where
c
ω
=cos(ω⊕t) (52)
s
ω
=sin(ω⊕t) (53)
c
+=cos((ω⊕+n)t) (54)
s
+=sin((ω⊕+n)t) (55)
c
−=cos((ω⊕−n)t) (56)
s
−=sin((ω⊕−n)t) (57)
The coefficients are:
where x=[r1 r2 r3 v1 v2 v3 θ0 xp yp]T. The functions of t are not orthogonal for all values of n. Specifically for n=ω⊕ or n=2 ω⊕ some of the functions are equivalent. For other values of n the functions are orthogonal.
There will be three cases considered for observability with polar motion. The first case assumes no special relationship between n and ω⊕ and utilizes the system of equations above (49)-(51). The cases where n=ω⊕ and n=2⊕ (the will be considered next. These cases will alter the system of equations and the constraints accordingly.
The system given by (42)-(44) is observable iff the following are true: (1) the system is observable; and (2) n≠ω⊕ or i≠0.
Proof: The system is observable if there is no nonzero x such that Ψ(t)x=0 for almost all t with Ψ given in (45). Three cases are considered with the general case first.
For Case 1, one of the conditions from (49) and (50) is
which after assuming ci≠1 and grouping the equation in terms of xp and yp gives:
0=(−cΩd2+sΩd1)xp+(cΩd1+sΩd2)yp (61)
Then repeating with (49) and (50) using the same assumption ci≠1 results in the following:
Adding (61) and (64) together after multiplying (61) by a factor of (s106 d2+cΩd1) and (64) by a factor of (−cΩd2−cΩd1) results in yp(d12+d22)=0. Since (d12+d22)≠0, therefore yp=0.
Furthermore, adding (61) and (64) together after multiplying (61) by a factor of (−cΩd2−cΩd1) results in xp(d12+d22)=0. Again, since d12+d22≠0, therefore xp=0.
However, it will be shown that the constraint ci≠1 can be removed by substituting the value ci=1 elsewhere in the system. Equations (49) and (50) imply the condition
d
2
k
18
=d
1
k
28 (65)
then expanding the coefficients gives
which after substituting ci=1 becomes
d
2(−cΩxp+sΩyp)=d1(sΩxp+cΩyp) (67)
Rearranging the equation in terms of xp and yp results in
(−cΩd2−sΩd1)xp+(sΩd2−cΩd1)yp=0 (68)
This process will be repeated for another condition from (49) and (50).
Adding (68) and (72) together after multiplying (68) by a factor of (−sΩd2+cΩd1) and (72) by a factor of (cΩd2−sΩd1) results in yp(d12+d22)=0. Since (d12+d22)≠0, therefore yp=0.
Furthermore, adding (68) and (72) together after multiplying (68) by a factor of (cΩd2+sΩd1) and (72) by a factor of (sΩd2−cΩd1) results in xp(d12+d22)=0. Therefore xp=0.
Therefore xp=yp=0 for all i. After substituting xp=yp=0 into the coefficients, the system reduces to the one in Case 4 with the equivalence k11=k1, k12=k2, k13=k3, k20=k6, k21=k4, k22=k5, k23=k7, k31=k8, and k32=k9. Therefore, the system is observable because there is no nonzero x that satisfies Ψx=0.
Case 2: n=Ω⊕—After substituting n=Ω⊕ into (49)-(51), the new system of equations that results is as follows,
d
1α(t)=(k11+k14)cω
d
2α(t)=(k21+k24)cω
d
3α(t)=k31cω
where
c
ω
=cos(ω|⊕t)
s
ω
=sin(ω⊕t)
c
2ω
=cos(2ω⊕t)
s
2ω
=sin(2ω⊕t) (76)
In this system of equations, d2k16=d1k26 and d2k17=d1k27 are still valid, implying xp=yp=0 with the constraint ci≠1.
The constraint ci≠1 cannot be removed in this case. When ci=1, then k16=k26=k36=k17=k27=k37=0. This leaves 7 linear equations with 9 unknowns. There will be a non-zero x such that Ψx=0 when ci=1.
Substituting xp=yp=0 into the coefficients reduces the system to the one considered in Case 4, so this system is observable with the added constraint ci≠1.
Case 3: n=2 ω⊕—After substituting in n=2 ω⊕ into (49)-(51), the new system of equations is as follows:
d
1α(t)=(k14+k18)cω
d
2α(t)=(k24+k28)cω
d
3α(t)=k38cω
where
c
3ω
=cos(3ω⊕t) (80)
s
3ω
=sin(3ω⊕t) (81)
The equations d2k16=d1k26 and d2k17=d1k27 are still valid in this system, so xp=yp=0 assuming ci≠1. Now it will be shown that the constraint ci≠1 can be removed by substituting the values ci=1 and i=0 elsewhere in the system. From (77) and (78):
d
2(k14+k18)=d1(k24+k28) (82)
which after expanding the coefficients and substituting becomes
d
2(−cΩxp+sΩyp)=d1(sΩxp+cΩyp) (83)
Then, rearranging the equation in terms of xp and yp results in
(−cΩd2−sΩd1)xp+(sΩd2−cΩd1)yp=0 (84)
Then repeating for another set of equations:
d
2(k15−k19)=d1(k25−k29) (85)
d
2(−sΩxp−cΩyp)=d1(cΩxp+sΩyp) (86)
(−sΩd2+cΩd1)xp+(−cΩd2−sΩd1)yp=0 (87)
Adding (84) and (87) together after multiplying (84) by a factor of (−s106 d2+cΩd1) and (87) by a factor of (cΩd2+sΩd1) results in yp(d12+d22)=0. Since (d12+d22)≠0, therefore yp=0.
Furthermore, adding (84) and (87) together after multiplying (84) by a factor of (cΩd2+sΩd1) and (87) by a factor of (sΩd2−cΩd1) results in xp(d12+d22)=0. Therefore xp=0.
Therefore xp=yp=0 for all i. After substituting xp=yp=0 into the coefficients, the system reduces to the one in Case 4, so the system is observable.
To summarize the results, the constraints on the selected orbit for each case are as follows: (1) general case: i≠π/2; (2) n=ω⊕: i≠π/2 and i≠0; and (3) n=2 Ω⊕: i≠π/2.
The third case with n=2 ω⊕ resulted in the same constraints as the general case. The only additional constraint is i≠0 when n=Ω⊕. This constraint means the satellite cannot be in a geostationary orbit in order for polar motion to be observable. While the geostationary orbit is only one in the set of all possible orbits it is used for many operational spacecraft because of its unique properties.
It is assumed that direction measurements are made with respect to the inertial frame, for example, by a star tracker. Without clock uncertainty, the measurement frame does not matter because the frame transformation is known a priori. But now that clock uncertainty is estimated, the frame used to measure directions becomes significant. The measurement equation becomes
d
1
=r
g
1
−r
s
1 (88)
where the superscript indicates the reference frame. The transformation from the Earth-centered inertial (ECI) frame to the Hill frame is
r
H
=R
z(v(t))r1−a0î (89)
v(t)=nt+vθ (90)
where v is the true anomaly of the nominal orbit at the given time. Therefore, the position in the inertial frame is
r
s
1
=R
z(−v)(rH+a0î) (91)
=Rz(−v)(Φrx0H+a0î) (92)
where x0H is the initial position and velocity in the Hill frame. Now, taking the derivative with respect to time in the inertial frame gives
taking only the first-order effects (assuming terms with x0H are negligible), and using
where [{circumflex over (k)}]x is the cross product matrix, results in
Transforming this result back to the Hill frame in order to be compatible with the process model and using the nominal trajectory (T=t) gives
which is the spacecraft's nominal velocity expressed in the Hill frame. Intuitively, the spacecraft would appear either behind or ahead in track due to a clock offset. Thus,
assuming {dot over (r)}gI=0, i.e., that the landmark is fixed in the inertial frame. This assumption of convenience with dubious physical interpretation is made so that this section may focus on the motion of the satellite.
Now assume that the spacecraft's clock time T is a linear function of true time t:
T=t−τ(t) (99)
τ(t)=τ0+{dot over (τ)}0t (100)
where τ is the clock error, τ0 is the initial clock error, and {dot over (τ)}0 is the initial clock drift. Taking derivatives,
Therefore, to account for linear clock errors, the measurement and process models are updated:
The input-output map of the system, Ψ(t), is used to determine observability:
In the above equations, α(t) is any function of time, and it is assumed d≠0 and d≠∞. Expanding Φr gives
from which it is clear that the second component of position, r2, and the clock bias, τ0, are inseparable since they both only appear in constant terms in the in-track direction. This renders τ0 unobservable.
Now assume that the clock bias, τ0, is no longer estimated, but the clock drift, {dot over (τ)}0, is estimated. This removes the second-to-last column from (110). This could be useful if the clock bias is known from another source or if it is not needed. Indeed, errors in the clock bias and the initial in-track position will cancel out to first order when computing the spacecraft's inertial position.
Grouping in terms of orthogonal functions of time gives the system of equations
where x=[r1 r2 r3 v1 v2 v3 {dot over (τ)}0]T. Now, each of the equations for d1α(t), d2α(t), and d3α(t) in (111) can be satisfied either when dj=0 or when α(t) is the right-hand side divided by the corresponding dj. This leaves five possible cases to check: (1) d1≠0, d2≠0, d3≠0; (2) d1≠0, d2≠0, d3≠0; (3) d1≠0, d2≠0, d3≠0; (4) d1≠0, d2≠0, d3≠0; and (5) d1≠0, d2≠0, d3≠0. For case (1), in this case, there are seven unknowns and six equations, so therefore, it is unobservable. For case (2), there are seven unknowns and six equations, so therefore, it is unobservable. For case (3), d2=0, therefore k4=k5=k6=k7=0. k4=0 implies v1=0, then combining that with k7=0 implies r2=0. From k5=0,
From d1α=d3α, which implies k3=0,
substituting
which implies r1=0 and v2=0. Then, using that with k6=0 gives
0=6nr1+3v2−na0{dot over (τ)}0 (118)
0=−na0{dot over (τ)}0 (119)
which implies to {dot over (τ)}0=0. Then, for the out-of-plane terms,
which implies r3=0 and v3=0. Therefore, Ψx=0 iff x=0, so the case is observable. This assumes finite nonzero values for n, d, and a0.
For case (4), as in the previous case, d2=0 implies v1=r2=0, 0=3v2+6nr1−na0{dot over (τ)}0, and
Then, from the first and third equations, k3=0, which implies v2=−2nr1. Combining the two expressions for v2 implies r1=v2=0. Substituting that into the earlier equation for {dot over (τ)}0 implies {dot over (τ)}0=0. Using the harmonic components of d1 and d3 leads to the expressions d3v1=d1v3 and
which imply r3=v3=0. Therefore, Ψx=0 iff x=0, so the case is observable.
For case (5), since there is no constant or linear term in the equation for d3α(t) in (44), the constant and linear terms in the other equations are zero, thus
Second, the harmonic terms from each pair of equations are equated.
From there, it can be shown r2=v1=v2=0 and then r3=v3=0. Therefore, Ψx=0 iff x=0, so the case is observable.
Landmarks fixed to a rotating central body, Earth, will now be examined. First, assume a simplified ERA model
θ(t)=θ0+(ω⊕+ω)t (124)
where ω⊕ is the angular velocity of the Earth and ω is a small adjustment, roughly equivalent to the length of day (LOD) EOP. The θ0 and ω are additional states that can be estimated. The transformation between the Earth fixed, inertial, and Hill frames are
r
H
=R
I→H
r
I
−aî
r
I
=R
E→I
r
E (125)
with
R
I→H
=R{circumflex over (k)}(nt) (126)
R
E→I
=Rî(i)R{circumflex over (k)}(Ω)R{circumflex over (k)}(−θ) (126)
where Râ(b) is a frame rotation constructed from the given axis and angle, i is inclination, Ω is right ascension of the ascending node, and θ is true anomaly.
As before, it is assumed the direction {circumflex over (d)} is measured in the inertial frame, e.g., using a star tracker to compute the camera's attitude. The sensitivity with respect to time is
For the landmark, the derivative with time is taken as
where the position of the landmark in the fixed frame, rgE, is assumed constant and [{circumflex over (k)}]x is the cross product matrix.
Now, with the sensitivities computed, they are converted to a frame and a form conducive to further analysis using the nominal trajectory. Using the fact that along the nominal trajectory, rqH=d, the derivative may be restated as
where the simplifications are possible because cross products and rotations about the same axis commute. Specifically, R{circumflex over (k)}(−θ) [{circumflex over (k)}]xR{circumflex over (k)}(θ)=R{circumflex over (k)}(−θ)R{circumflex over (k)}(θ) [{circumflex over (k)}]x=[{circumflex over (k)}]x. Then, the while derivative is transformed to the Hill frame,
where e is
Thus,
From this, it can be seen that the column for τ0 is a linear combination of the columns for r2 and θ0, which renders τ0 inseparable from the other two. Further analysis assumes TO is known by other means or is arbitrarily fixed. Then, splitting into orthogonal functions gives
The most difficult part will be separating {dot over (τ)}0 from ω, since they only differ in their linear effect in the in-track direction. Since the landmark is on Earth, this leaves four cases to examine: (1) d1≠0, d2=0, d3=0; (2) d1≠0, d2≠0, d3=0; (3) d1≠0, d2=0, d3≠0; and (4) d1≠0, d2≠0, d3≠0.
For case (1), if si=0, then there are seven equations for nine unknowns and the system is unobservable. If si≠0, then (ω+ω⊕{dot over (τ)}0)=0 and there are seven equations for the remaining eight unknowns, and the system is unobservable. If si≠0 and ω is not estimated, i.e., assumed to be zero, then {dot over (τ)}0=0, and the system reduces to that of only estimating r1 through θ0, which is shown to be unobservable in this case.
For case (2), if si=0, then there are six equations for nine unknowns and the system is unobservable. If si≠0, then (ω+ω⊕{dot over (τ)}0)=0, and there are six equations for the remaining eight unknowns and the system is unobservable. If si≠0, and ω is not estimated, then {dot over (τ)}0=0, and the system reduces to that of only estimating r1 through θ0, which is shown to be unobservable in this case.
For case (3), substituting d2=0 gives
If si=0, then there are eight equations for nine unknowns and the system is unobservable. If si≠0, then the tsn term implies (ω+ω⊕{dot over (τ)}0)=0, which, when substituted, gives the system
which has seven equations for the remaining eight unknowns, hence the system is unobservable. If si≠0 and ω is not estimated, then {dot over (τ)}0=0, and the system reduces to that of only estimating r1 through θ0, which is shown to be unobservable in this case.
For case (4), if si=0, then there are eight equations for nine unknowns and the system is unobservable. If si≠0, then (ω+ω⊕{dot over (τ)}0)=0, there are seven equations for the remaining eight unknowns, and the system is unobservable. If ω is not estimated, then the tcn term gives the condition
s
i
{dot over (r)}
0=0 (140)
and the radial component of the t term gives the condition
c
i{dot over (τ)}0=0 (141)
Since ci=si=0 is a contradiction, therefore {dot over (τ)}0=0. The system then reduces to the same case, which is observable iff
In summary, τ0 and ω are unobservable in all four cases. In the fourth case, when the observatory looks off nadir in both the in-track and cross-track directions and the orbit is not precisely polar, then the remaining states are observable (r1 through v3, θ0, and {dot over (τ)}0). Different combinations of states are possible as well. For example, since θ0 is linearly dependent on τ0, τ0 may be estimated instead of θ0, thus the spacecraft's clock errors can be estimated if the orientation of Earth is known. Conversely, ω may be estimated instead of {dot over (τ)}0, so Earth's orientation may be estimated if the spacecraft's clock is known. In any case, it is a time scale based on Earth's rotation, e.g., Universal Time 1 (UT1), that is actually estimated.
The spacecraft of
In an embodiment, estimator 720 estimator uses output from landmark matcher 718 and computes a direction to that identified landmark. In an embodiment, since a landmark is associated to known landmark in a database, estimator 720 knows a location on earth and can compare the distance observed from landmark matcher 720 to a computed distance from a current best estimate from the state of spacecraft 702 (e.g., rom state propagator 722). In an embodiment, the angular distance between these two distances can be referred to as a residual distance, and estimator 720 can minimize the residual distance by producing a new estimate (e.g., using least squares or a Kalman filter).
In an embodiment, state propagator 722 allows for the use of time series of measurements relative to a state at some time in the past so that measurements can inform where spacecraft was at that epoch in the past. In an embodiment, state propagator 722 predicts states (e.g., satellite position, velocity) from one epoch (arbitrarily chosen date) to another (e.g., the current time) to give a full time history.
Landmark matcher 718, estimator 720, and state propagator 722 can be implemented using a single device (e.g., integrated into navigation controller 716 and/or spacecraft 702) or multiple devices (e.g., as separate special purpose devices) in accordance with embodiments of the present disclosure. In an embodiment, navigation controller 716 is configured to perform methods for determining spacecraft state and Earth orientation from landmark measurements (e.g., such as the methods described in the flowcharts of
Embodiments of the present disclosure can be implemented using hardware, software, and/or a combination of hardware and software. Embodiments of the present disclosure can be implemented using one or more devices. In an embodiment, components of spacecraft 702 are implemented as a special purpose device. For example, in an embodiment, spacecraft 702 is a satellite, and components of spacecraft 702 are implemented as on-board components of spacecraft 702.
Embodiments of the present disclosure provide autonomy from large ground station networks maintained by the International Earth Rotation Service (IERS), US Naval Observatory (USNO), and others to measure Earth's orientation in space. Previously these Earth Orientation Parameters (EOP) would need to be uplinked to the spacecraft as it was unable to estimate the EOP autonomously. Embodiments of the present disclosure enable a spacecraft to be able to determine EOP autonomously.
The measured EOP enabled by embodiments of the present disclosure may be useful science data. For example, a deep space mission to a comet could estimate some physical parameters of its central body autonomously. As mentioned earlier, autonomy provides opportunities for increased resiliency, reliability, and capability while using fewer ground resources (e.g., mission controllers, and antennas).
Embodiments of the present disclosure use computer vision/machine learning algorithms in parallel and train a convolutional neural network to find landmarks of interest and pass the result to an image segmentation model that can extract navigational information on a pixel-based level.
It is to be appreciated that the Detailed Description, and not the Abstract, is intended to be used to interpret the claims. The Abstract may set forth one or more but not all exemplary embodiments of the present disclosure as contemplated by the inventor(s), and thus, is not intended to limit the present disclosure and the appended claims in any way.
The present disclosure has been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed.
The foregoing description of the specific embodiments will so fully reveal the general nature of the disclosure that others can, by applying knowledge within the skill of the art, readily modify and/or adapt for various applications such specific embodiments, without undue experimentation, without departing from the general concept of the present disclosure. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance.
Any representative signal processing functions described herein can be implemented using computer processors, computer logic, application specific integrated circuits (ASIC), digital signal processors, etc., as will be understood by those skilled in the art based on the discussion given herein. Accordingly, any processor that performs the signal processing functions described herein is within the scope and spirit of the present disclosure.
The above systems and methods may be implemented using a computer program executing on a machine, using a computer program product, or using a tangible and/or non-transitory computer-readable medium having stored instructions. For example, the functions described herein could be embodied by computer program instructions that are executed by a computer processor or any one of the hardware devices listed above. The computer program instructions cause the processor to perform the signal processing functions described herein. The computer program instructions (e.g., software) can be stored in a tangible non-transitory computer usable medium, computer program medium, or any storage medium that can be accessed by a computer or processor. Such media include a memory device such as a RAM or ROM, or other type of computer storage medium such as a computer disk or CD ROM. Accordingly, any tangible non-transitory computer storage medium having computer program code that cause a processor to perform the signal processing functions described herein are within the scope and spirit of the present disclosure.
While various embodiments of the present disclosure have been described above, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail can be made therein without departing from the spirit and scope of the disclosure. Thus, the breadth and scope of the present disclosure should not be limited by any of the above-described exemplary embodiments.
This application claims the benefit of U.S. Provisional Patent Application No. 63/317,151, filed on Mar. 7, 2022, which is incorporated by reference herein in its entirety.
The United States Government has ownership rights in this invention. Licensing inquiries may be directed to Office of Technology Transfer at US Naval Research Laboratory, Code 1004, Washington, DC 20375, USA; +1.202.767.7230; techtran@nrl.navy.mil, referencing Navy Case Number 210998-US2.
Number | Date | Country | |
---|---|---|---|
63317151 | Mar 2022 | US |