From 18161bb4e9afd0b60d300daa4bf3204c773fd036 Mon Sep 17 00:00:00 2001 From: smroid Date: Thu, 4 Jul 2024 18:31:58 -0700 Subject: [PATCH] add ability to return rotation matrix with plate solution --- tetra3/tetra3.py | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/tetra3/tetra3.py b/tetra3/tetra3.py index fde7859..4501cd7 100644 --- a/tetra3/tetra3.py +++ b/tetra3/tetra3.py @@ -1556,8 +1556,8 @@ def solve_from_image(self, image, fov_estimate=None, fov_max_error=None, def solve_from_centroids(self, star_centroids, size, fov_estimate=None, fov_max_error=None, match_radius=.01, match_threshold=1e-4, solve_timeout=5000, target_pixel=None, target_sky_coord=None, distortion=0, - return_matches=False, return_visual=False, match_max_error=.002, - pattern_checking_stars=None): + return_matches=False, return_visual=False, return_rotation_matrix=False, + match_max_error=.002, pattern_checking_stars=None): """Solve for the sky location using a list of centroids. Use :meth:`tetra3.get_centroids_from_image` or your own centroiding algorithm to @@ -1609,6 +1609,7 @@ def solve_from_centroids(self, star_centroids, size, fov_estimate=None, fov_max_ stars and their pixel coordinates in the image is returned. return_visual (bool, optional): If set to True, an image is returned that visualises the solution. + return_rotation_matrix (bool, optional): If True, the 3x3 rotation matrix is returned. match_max_error (float, optional): Maximum difference allowed in pattern for a match. If None, uses the 'pattern_max_error' value from the database. pattern_checking_stars: No longer meaningful, ignored. @@ -1657,6 +1658,8 @@ def solve_from_centroids(self, star_centroids, size, fov_estimate=None, fov_max_ FOV and distortion estimates in orange, the final FOV and distortion estimates in green. Also has circles for the catalogue stars in green or red for successful/unsuccessful match. Not included if return_visual=False. + - 'rotation_matrix' 3x3 rotation matrix. Not included if + return_rotation_matrix=False. - 'status': One of: MATCH_FOUND: solution was obtained NO_MATCH: no match was found after exhausting all possibilities @@ -2133,6 +2136,9 @@ def draw_circle(centre, radius, **kwargs): solution_dict['visual'] = img + if return_rotation_matrix: + solution_dict['rotation_matrix'] = rotation_matrix.tolist() + self._logger.debug(solution_dict) self._logger.debug( 'For %d centroids, evaluated %s image patterns; searched %s pattern hashes' %