The present invention concerns a method and a device for determining the attitude of a spacecraft by attitude determination using fast star identification using a so-called star tracker.
Accurate attitude determination has always been important for the success of space missions. Attitude information can be derived from a wide range of measurements, however it is generally recognized that star trackers represent the most accurate available solution to the problem.
Star trackers operate according to the following general principle: a camera, usually with a medium or narrow field of view (FOV), provides images of a portion of the celestial sphere. Such images are processed and compared with a star catalog stored on board, in order to match captured stars with the stars from the catalog (star identification problem). Knowledge of the position of stars both in the camera reference frame (as provided by the sensor) and in an inertial reference frame (as provided by the catalog) constitutes the input for the actual attitude determination problem, for which a number of solutions are available in the literature.
Depending on algorithm and mode of operation star tracker may work with or without a priori information about spacecraft's attitude: in tracking mode device captures the movement of star patterns in the field of view and updates the spacecraft attitude on each measurement; whereas in lost-in-space (LIS) mode device performs identification of star patterns in the field of view by matching extracted pattern features against onboard star database and calculates spacecraft attitude based on current image on the camera sensor.
Next, in a step 2.2, the algorithm determines spots representing potential stars present in the image. This steps comprises typically thresholding the image to get rid of background noise to get a black and white image. Next a clustering operation will aggregate neighboring white pixel to constitutes a single potential star and then to extract for each potential star an associated pattern.
Next, in a step 2.3, the matching process consists in, for each potential star in the image, database search and pattern matching. This leads typically to a set of candidates in the database for each potential star. These candidates are then verified in order to ensure a positive identification in the database for the potential star.
Next, in a step 2.4, assuming that a sufficient number of potential stars have been positively identified in step 2.3, the attitude is estimated.
An example of such algorithm, called POLESTAR, is described in “Star Identification Algorithms: Novel Approach & Comparison Study” by E. Silany and M. Lovera, IEEE TRANSACTIONS ON AREOSPACE AND ELECTRONIC SYSTEMS, vol. 42, No. 4, OCTOBER 2006.
Computation should occur in real time during the spacecraft operation. Especially for satellites, the size, weight and power consumption are critical aspects. For these reason optimizing this algorithm allows building smaller, lighter and less consuming star tracker devices.
The present invention has been devised to address one or more of the foregoing concerns. It is proposed an improved algorithm with pattern extraction based on rings having an equal area. In some embodiments a confidence value is attributed to the candidates of the matching process improving significantly the verification process.
According to a first aspect of the invention there is provided a method of determining the attitude of a spacecraft, the method comprising:
characterized in that:
In an embodiment, said polynomial circular grid is defined by rings delimitated by circles which radius are defined using the polynomial formula:
R
N+1
=R
N+ΔN, with:
ΔN=√{square root over (RN−12+4RN−1ΔN−1+2ΔN−12)}−RN−1−ΔN−1;
In an embodiment:
In an embodiment:
In an embodiment, said confidence threshold is recalculated during operational stage to take into account amount of sensor noise.
In an embodiment, said confidence threshold is recalculated at run time to take into account different lightning conditions.
In an embodiment, said steps of searching and verifying are done in parallel for each spot.
According to another aspect of the invention there is provided a device for determining the attitude of a spacecraft, the device comprising:
characterized in that:
According to another aspect of the invention there is provided a computer program product for a programmable apparatus, the computer program product comprising a sequence of instructions for implementing a method according to the invention, when loaded into and executed by the programmable apparatus.
According to another aspect of the invention there is provided a computer-readable storage medium storing instructions of a computer program for implementing a method according to the invention.
At least parts of the methods according to the invention may be computer implemented. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit”, “module” or “system”. Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
Since the present invention can be implemented in software, the present invention can be embodied as computer readable code for provision to a programmable apparatus on any suitable carrier medium. A tangible carrier medium may comprise a storage medium such as a floppy disk, a CD-ROM, a hard disk drive, a magnetic tape device or a solid state memory device and the like. A transient carrier medium may include a signal such as an electrical signal, an electronic signal, an optical signal, an acoustic signal, a magnetic signal or an electromagnetic signal, e.g. a microwave or RF signal.
Embodiments of the invention will now be described, by way of example only, and with reference to the following drawings in which:
The catalog of stars used for the star tracker algorithm is based on known catalogs of stars. The catalog is filtered in order to keep only stars with a magnitude matching the sensitivity of the camera. Advantageously, the binary stars and variable stars are also filtered out as they are not suitable for matching. Close stars that usually merge due to the Point-Spread-Function of the optical system of the camera are also filtered out. Then the visual magnitude of stars are converted to instrumental magnitude taking into account their B-V color index. Following these steps, a further filtering occurs to retain only those stars with an instrumental magnitude equal or smaller than a given threshold, namely the brightest ones. It is recalled here that a low magnitude corresponds to a high brightness. The catalog may be further adjusted in order to guarantee that for any possible orientation of the camera field of view a minimum number of reference stars is visible. All these operation are used to build the reference catalog used for the star tracking algorithm.
The computational load of the capture step 2.1 and the calculation step 2.4 is small compared to the extraction step and matching step. Typically, the capture step 2.1 takes 5% of the total computation time of the algorithm while the calculation step 2.4 takes 1% of the same. We will focus on extraction and matching in this document.
The star identification algorithm proposed herein involves generating a set of patterns for the selected group of reference stars in the reference catalog, whose position on celestial sphere are known in a Earth-centered inertial frame (ECI frame). This pattern set constitutes a database which is used to compare patterns derived in a similar way from the sensor image. As each star has its own signature, finding a suitably close match to a pattern is equivalent to pairing the two stars for the purpose of identification.
The extraction of pattern is based on a circular grid centered on the spot. The circular grid is defined by a set of adjacent rings centered on said spot. The pattern is constituted by a binary word. Each bit of the pattern corresponds to one ring of the circular grid. Each bit of the pattern is marked according to the neighboring of said spot in the area of the corresponding ring in the captured image.
A pattern is calculated for a given star or spot 3.1. A first circle 3.2 is calculated centered on the star 3.1 with a first radius Rmin. Next a number of circles with increasing radius are calculated also centered on the star 3.1 until the outer circle 3.3. These circles are equally spaced meaning that two successive circles have radius with the following relation: RN+1=RN+δ, where RN is the radius of the nth circle, RN+1 is the radius of the next circle and δ is the constant difference 3.4 between two successive circles.
These circles define rings around the central star 3.1. The central part between the central star 3.1 and the inner ring 3.2 is ignored. Each ring defines an area between two successive circles. These rings define a so-called circular grid.
The pattern 3.5 are encoded into binary code words, each pattern corresponds to a binary code word which number of bits is equal to the number of rings. Each bit is set to 0 if no star belongs to the area of the corresponding rings. The bit is set to 1 if at least one star belongs to the area of the corresponding ring.
While the figure illustrates a pattern based on 5 rings for the sake of clarity, the real number of rings used falls typically in the range from 50 to 300 rings, while not limited to these numbers. This pattern gives a signature to a star based on the disposition of its neighbors.
Patterns corresponding to reference stars in the catalog are computed during a preliminary step and stored in the database, typically in a lookup table.
The extraction process, step 2.2 on
The matching process, step 2.3 on
An exact match, meaning a mark score corresponding to the number of mark in the spot pattern, is rarely observed. Indeed, the number of stars in a typical view of the database depends on the filtering thresholds applied to filter the catalog. It also depends on filtered out binary and variable stars. For the captured image, the number of spots depends on the pixel brightness thresholds applied to filter the captured image, the level of illumination that may occur from the sun, the level of noise in the original image leading to spot being actual noise and not stars. Therefore, even for an spot representing an actual reference star, the observed neighborhood in the capture image rarely match perfectly the theoretical neighborhood observed in the database view.
Nevertheless reference stars which pattern when compared to the spot pattern leads to a high mark score are good candidates for an identification. The result of this phase is a list of best match candidates. In some cases, this list may be empty if no reference stars get a mark score greater than a predefined threshold.
Next the best candidates are subjected to a verification step in order to positively identify the spot to one of the best candidate reference star in the catalog. The verification steps may consist, for example, in constructing first pairs, then triangles and finally higher levels polygons based on the spot and its neighbors and matching them to the same computed based on reference stars.
An unambiguous identification arises when we find a unique match between a triangle obtained from the spots and a triangle generated from the candidates and no matches between polygons with a number n≥3 of edges, or when we find a unique match between a 4-edges polygon obtained from the sensor stars and 4-edges polygon generated from the candidates and no matches between polygons with a number of edges greater than 4, and so on. Any other possible situation is marked as ambiguous and no identification is provided.
A positive identification of two spots as reference stars are enough to compute the attitude of the spacecraft.
Regarding the extraction of patterns, inventors have noticed that using equally spaced circles as described above to define an evenly-spaced grid leads to rings having an increasing area from the inner ring to the outer one. It means that the probability of having a mark in the pattern also increases from the first position to the last position in the pattern. The drawback of this methods is that the probability of false positive identification increase for spots with no close neighbors.
According to one embodiment of the invention, the pattern extraction is based on a polynomial circular grid that normalizes the probability of having a mark across the whole pattern. This means that each ring should have a similar area. The different circles used to delimitate the rings are no longer evenly spaced. Their radius are defined using a polynomial equation. For example, radius of successive circles may be computed according to the following formula:
R
N+1
=R
N+ΔN, with:
ΔN=√{square root over (RN−12+4RN−1ΔN−1+2 ΔN−12)}−RN−1−ΔN−1;
where RN is the radius of the nth circle and ΔN is the difference between the radius of the nth circle and the radius of the next circle. R1 and Δ1 are parameters of the system.
Such polynomial circular grid, as illustrated on
Accordingly the quality of the match is improved.
According to another embodiment of the invention, the selection of best candidates no longer relies on the mark score alone but also on a confidence value based on this mark score. The confidence value is defined as:
Where Mark Score is the mark score, Star Marks and Spot Marks are respectively the number of marks in the star pattern and in the spot pattern.
A confidence threshold is also considered. This confidence threshold is computed based on an average number of marks in the pattern of reference stars in the database and the average number of marks of spot patterns. For example, the confidence threshold may be calculated using the following formula:
Where Max Score is the higher mark score, avg (Star Marks) is the average number of marks in the pattern of reference stars in the database, and avg (Spot Marks) is the average number of marks of spot patterns corresponding to current camera sensitivity setting.
Once the mark score is calculated, the confidence value is also calculated for all the reference stars. A list of best candidates is no longer calculated. A reliable match, meaning a positive identification of the spot as one of the reference star, is determined for a spot when the top candidate, meaning a unique candidate with the higher mark score, has a confidence value greater than the confidence threshold. No further verification step is needed.
Confidence-based match selection takes into account the fact that camera sensitivity and database magnitude cut-off value may be mismatched. In many cases it's done on purpose during development stage to reduce the size of the database. Confidence threshold may be recalculated during operational stage to take into account amount of sensor noise or even in runtime as a part of an adaptive mechanism for different lighting conditions. Correct choice of a confidence threshold gives up to 80% of true matches on non-adapted star database without verification step.
In classic approach after the database search is completed there will be a few spot having a potential match, and every such spot will have a list of best candidates. Classic polestar algorithm doesn't give information on which match with a candidate is reliable during database search phase, it only says which candidates are the best for one particular spot. And it's impossible to compare two spots and their candidates directly since they will have different number of neighbors hence different mark score.
So after database search, they take spot pairs and corresponding candidates and using the database again verify the distance between the spots, if the distance is verified, then another spot is picked and two more distances are verified. To complete the process the fourth spot is picked and three more distances are verified. In case of failure on any step, corresponding candidates are discarded and process re-starts with new pair of spots or candidates. When the number of spots in the verified pattern reaches four, all corresponding candidates are considered reliable, and only then they may be used for attitude estimation. This is a very slow process taking typically from a couple of seconds to one minute.
On the contrary, according to the confidence based match, as soon as two reliable matches are identified, they can be used right away to compute the attitude. No further verification step is needed. The verification step is reduced to checking that the confidence value is greater than the threshold. This process is far less computing intensive and therefore much faster.
One advantage of the proposed solution is the ability to treat every spot independently after its pattern has been generated. Since the matching is performed using only the pattern related to a particular spot, and the verification step is simplified to sorting and filtering of match candidates for that spot, algorithm flow may be executed in 2≤n≤K concurrent threads parallel execution threads, where K is the number of spots extracted from captured image and n the number of threads. This solution allows taking advantage of modern multi-core processors by executing the matching step in parallel on different cores. This is not the case in the classical approach where the verification step needs to compare the distance between different spots. This verification steps are not independent computation for each spot. Using the same approach with classic polestar algorithm is somewhat problematic, because verification of matches involve several spots at the same time. Gain in terms of execution time for classic polestar is also hard to predict since verification step execution time may vary depending on the set of objects in question.
The executable code may be stored either in read only memory 503, on the hard disk 506 or on a removable digital medium such as for example a disk. According to a variant, the executable code of the programs can be received by means of a communication network, via the network interface 504, in order to be stored in one of the storage means of the communication device 500, such as the hard disk 506, before being executed.
The central processing unit 501 is adapted to control and direct the execution of the instructions or portions of software code of the program or programs according to embodiments of the invention, which instructions are stored in one of the aforementioned storage means. After powering on, the CPU 501 is capable of executing instructions from main RAM memory 502 relating to a software application after those instructions have been loaded from the program ROM 503 or the hard-disc (HD) 506 for example. Such a software application, when executed by the CPU 501, causes the steps of the flowcharts shown in
Any step of the algorithm shown in
Although the present invention has been described hereinabove with reference to specific embodiments, the present invention is not limited to the specific embodiments, and modifications will be apparent to a skilled person in the art which lie within the scope of the present invention.
Many further modifications and variations will suggest themselves to those versed in the art upon making reference to the foregoing illustrative embodiments, which are given by way of example only and which are not intended to limit the scope of the invention, that being determined solely by the appended claims. In particular the different features from different embodiments may be interchanged, where appropriate.
In the claims, the word “comprising” does not exclude other elements or steps, and the indefinite article “a” or “an” does not exclude a plurality. The mere fact that different features are recited in mutually different dependent claims does not indicate that a combination of these features cannot be advantageously used.
Number | Date | Country | Kind |
---|---|---|---|
15307060.2 | Dec 2015 | EP | regional |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2016/081380 | 12/16/2016 | WO | 00 |