From f9edb49dcf8a7761db531ba81be54174b6b0c058 Mon Sep 17 00:00:00 2001 From: Michael Ring Date: Sat, 30 Dec 2023 00:23:15 +0100 Subject: [PATCH 1/2] Allows GraXpert commandline to run all extraction methods based on a preferences file that contains background grid points --- graxpert/CommandLineTool.py | 49 ++++++++++++++++++++++++++++++------- graxpert/main.py | 1 + 2 files changed, 41 insertions(+), 9 deletions(-) diff --git a/graxpert/CommandLineTool.py b/graxpert/CommandLineTool.py index 2fb9bdd..ad92200 100644 --- a/graxpert/CommandLineTool.py +++ b/graxpert/CommandLineTool.py @@ -1,6 +1,8 @@ import logging import os import sys +from pathlib import Path +import numpy as np from appdirs import user_config_dir @@ -10,7 +12,7 @@ from graxpert.astroimage import AstroImage from graxpert.background_extraction import extract_background from graxpert.preferences import load_preferences, save_preferences - +import json class CommandLineTool: def __init__(self, args): @@ -26,19 +28,48 @@ def execute(self): processed_Astro_Image.fits_header = astro_Image.fits_header background_Astro_Image.fits_header = astro_Image.fits_header - ai_version = self.get_ai_version() + interpol_type_option="AI" + RBF_kernel = "RBF" + background_points=[] + sample_size=50 + downscale_factor = 1 + spline_order=0 + + if (self.args.preferencesfile): + try: + preferencesfile = Path(self.args.preferencesfile) + if preferencesfile.is_file() and preferencesfile.suffix == ".json": + prefs=json.load(preferencesfile.open("r")) + background_points=prefs["background_points"] + sample_size=prefs["sample_size"] + spline_order=prefs["spline_order"] + RBF_kernel=prefs["RBF_kernel"] + interpol_type_option=prefs["interpol_type_option"] + if interpol_type_option == "Kriging" or interpol_type_option == "RBF": + downscale_factor = 4 + + except Exception as e: + logging.exception(e) + logging.shutdown() + sys.exit(1) + + if interpol_type_option == "AI": + ai_model_path_from_version(self.get_ai_version()) + else: + ai_model_path=None + background_Astro_Image.set_from_array( extract_background( astro_Image.img_array, - [], - "AI", + np.array(background_points), + interpol_type_option, self.args.smoothing, - 1, - 50, - "RBF", - 0, + downscale_factor, + sample_size, + RBF_kernel, + spline_order, self.args.correction, - ai_model_path_from_version(ai_version), + ai_model_path ) ) diff --git a/graxpert/main.py b/graxpert/main.py index 710f668..b969640 100644 --- a/graxpert/main.py +++ b/graxpert/main.py @@ -177,6 +177,7 @@ def main(): ) parser.add_argument("-correction", "--correction", nargs="?", required=False, default="Subtraction", choices=["Subtraction", "Division"], type=str, help="Subtraction or Division") parser.add_argument("-smoothing", "--smoothing", nargs="?", required=False, default=0.0, type=float, help="Strength of smoothing between 0 and 1") + parser.add_argument("-preferencesfile", "--preferencesfile", nargs="?", required=False, default="", type=str, help="Allows GraXpert commandline to run all extraction methods based on a preferences file that contains background grid points") parser.add_argument("-output", "--output", nargs="?", required=False, type=str, help="Filename of the processed image") parser.add_argument("-bg", "--bg", required=False, action="store_true", help="Also save the background model") parser.add_argument("-cli", "--cli", required=False, action="store_true", help="Has to be added when using the command line integration of GraXpert") From e9a69f3c61a2168f67a5c88ad5d2b865c9f4444b Mon Sep 17 00:00:00 2001 From: David Schmelter Date: Sat, 30 Dec 2023 12:29:37 +0100 Subject: [PATCH 2/2] support overwriting of preferences by cli arguments, code cleanup --- graxpert/CommandLineTool.py | 129 ++++++++++++++++++------------------ graxpert/main.py | 23 +++++-- 2 files changed, 81 insertions(+), 71 deletions(-) diff --git a/graxpert/CommandLineTool.py b/graxpert/CommandLineTool.py index ad92200..a3fdc13 100644 --- a/graxpert/CommandLineTool.py +++ b/graxpert/CommandLineTool.py @@ -1,18 +1,18 @@ +import json import logging import os import sys -from pathlib import Path -import numpy as np +import numpy as np from appdirs import user_config_dir -from graxpert.ai_model_handling import (ai_model_path_from_version, - download_version, latest_version, - list_local_versions) +from graxpert.ai_model_handling import ai_model_path_from_version, download_version, latest_version, list_local_versions from graxpert.astroimage import AstroImage from graxpert.background_extraction import extract_background -from graxpert.preferences import load_preferences, save_preferences -import json +from graxpert.preferences import Prefs, load_preferences, save_preferences + +user_preferences_filename = os.path.join(user_config_dir(appname="GraXpert"), "preferences.json") + class CommandLineTool: def __init__(self, args): @@ -21,127 +21,128 @@ def __init__(self, args): def execute(self): astro_Image = AstroImage(do_update_display=False) astro_Image.set_from_file(self.args.filename, None, None) - + processed_Astro_Image = AstroImage(do_update_display=False) background_Astro_Image = AstroImage(do_update_display=False) - + processed_Astro_Image.fits_header = astro_Image.fits_header background_Astro_Image.fits_header = astro_Image.fits_header - - interpol_type_option="AI" - RBF_kernel = "RBF" - background_points=[] - sample_size=50 + downscale_factor = 1 - spline_order=0 - if (self.args.preferencesfile): + if self.args.preferences_file: + preferences = Prefs() + preferences.interpol_type_option = "AI" try: - preferencesfile = Path(self.args.preferencesfile) - if preferencesfile.is_file() and preferencesfile.suffix == ".json": - prefs=json.load(preferencesfile.open("r")) - background_points=prefs["background_points"] - sample_size=prefs["sample_size"] - spline_order=prefs["spline_order"] - RBF_kernel=prefs["RBF_kernel"] - interpol_type_option=prefs["interpol_type_option"] - if interpol_type_option == "Kriging" or interpol_type_option == "RBF": - downscale_factor = 4 + preferences_file = os.path.abspath(self.args.preferences_file) + if os.path.isfile(preferences_file): + with open(preferences_file, "r") as f: + json_prefs = json.load(f) + preferences.background_points = json_prefs["background_points"] + preferences.sample_size = json_prefs["sample_size"] + preferences.spline_order = json_prefs["spline_order"] + preferences.RBF_kernel = json_prefs["RBF_kernel"] + preferences.interpol_type_option = json_prefs["interpol_type_option"] + preferences.ai_version = json_prefs["ai_version"] + + if preferences.interpol_type_option == "Kriging" or preferences.interpol_type_option == "RBF": + downscale_factor = 4 except Exception as e: logging.exception(e) logging.shutdown() sys.exit(1) + else: + preferences = load_preferences(user_preferences_filename) + preferences.interpol_type_option = "AI" + + if self.args.smoothing: + preferences.smoothing_option = self.args.smoothing + logging.info(f"Using user-supplied smoothing value {preferences.smoothing_option}.") + + if self.args.correction: + preferences.corr_type = self.args.correction + logging.info(f"Using user-supplied correction type {preferences.corr_type}.") - if interpol_type_option == "AI": - ai_model_path_from_version(self.get_ai_version()) + if preferences.interpol_type_option == "AI": + ai_model_path = ai_model_path_from_version(self.get_ai_version(preferences)) else: - ai_model_path=None + ai_model_path = None background_Astro_Image.set_from_array( extract_background( astro_Image.img_array, - np.array(background_points), - interpol_type_option, - self.args.smoothing, + np.array(preferences.background_points), + preferences.interpol_type_option, + preferences.smoothing_option, downscale_factor, - sample_size, - RBF_kernel, - spline_order, - self.args.correction, - ai_model_path + preferences.sample_size, + preferences.RBF_kernel, + preferences.spline_order, + preferences.corr_type, + ai_model_path, ) ) processed_Astro_Image.set_from_array(astro_Image.img_array) processed_Astro_Image.save(self.get_save_path(), self.get_output_file_format()) - if (self.args.bg): + if self.args.bg: background_Astro_Image.save(self.get_background_save_path(), self.get_output_file_format()) - - def get_ai_version(self): - prefs_filename = os.path.join( - user_config_dir(appname="GraXpert"), "preferences.json" - ) - prefs = load_preferences(prefs_filename) + def get_ai_version(self, prefs): + user_preferences = load_preferences(user_preferences_filename) ai_version = None if self.args.ai_version: ai_version = self.args.ai_version + logging.info(f"Using user-supplied AI version {ai_version}.") else: ai_version = prefs.ai_version if ai_version is None: ai_version = latest_version() - - logging.info( - "using AI version {}. you can change this by providing the argument '-ai_version'".format( - ai_version - ) - ) + logging.info(f"Using AI version {ai_version}. You can overwrite this by providing the argument '-ai_version'") if not ai_version in [v["version"] for v in list_local_versions()]: try: - logging.info( - "AI version {} not found locally, downloading...".format(ai_version) - ) + logging.info(f"AI version {ai_version} not found locally, downloading...") download_version(ai_version) - logging.info("download successful".format(ai_version)) + logging.info("download successful") except Exception as e: logging.exception(e) logging.shutdown() sys.exit(1) - prefs.ai_version = ai_version - save_preferences(prefs_filename, prefs) - + user_preferences.ai_version = ai_version + save_preferences(user_preferences_filename, user_preferences) + return ai_version - + def get_output_file_ending(self): file_ending = os.path.splitext(self.args.filename)[-1] - + if file_ending.lower() == ".xisf": return ".xisf" else: return ".fits" - + def get_output_file_format(self): output_file_ending = self.get_output_file_ending() if (output_file_ending) == ".xisf": return "32 bit XISF" else: return "32 bit Fits" - + def get_save_path(self): - if (self.args.output is not None): + if self.args.output is not None: base_path = os.path.dirname(self.args.filename) output_file_name = self.args.output + self.get_output_file_ending() return os.path.join(base_path, output_file_name) - + else: return os.path.splitext(self.args.filename)[0] + "_GraXpert" + self.get_output_file_ending() - + def get_background_save_path(self): save_path = self.get_save_path() return os.path.splitext(save_path)[0] + "_background" + self.get_output_file_ending() diff --git a/graxpert/main.py b/graxpert/main.py index b969640..0456315 100644 --- a/graxpert/main.py +++ b/graxpert/main.py @@ -14,9 +14,10 @@ from packaging import version -from graxpert.version import release as graxpert_release, version as graxpert_version from graxpert.ai_model_handling import list_local_versions, list_remote_versions from graxpert.mp_logging import configure_logging +from graxpert.version import release as graxpert_release +from graxpert.version import version as graxpert_version available_local_versions = [] available_remote_versions = [] @@ -177,23 +178,31 @@ def main(): ) parser.add_argument("-correction", "--correction", nargs="?", required=False, default="Subtraction", choices=["Subtraction", "Division"], type=str, help="Subtraction or Division") parser.add_argument("-smoothing", "--smoothing", nargs="?", required=False, default=0.0, type=float, help="Strength of smoothing between 0 and 1") - parser.add_argument("-preferencesfile", "--preferencesfile", nargs="?", required=False, default="", type=str, help="Allows GraXpert commandline to run all extraction methods based on a preferences file that contains background grid points") + parser.add_argument( + "-preferences_file", + "--preferences_file", + nargs="?", + required=False, + default="", + type=str, + help="Allows GraXpert commandline to run all extraction methods based on a preferences file that contains background grid points", + ) parser.add_argument("-output", "--output", nargs="?", required=False, type=str, help="Filename of the processed image") parser.add_argument("-bg", "--bg", required=False, action="store_true", help="Also save the background model") parser.add_argument("-cli", "--cli", required=False, action="store_true", help="Has to be added when using the command line integration of GraXpert") - parser.add_argument('-v', '--version', action='version', version="GraXpert version: " + graxpert_version + " release: " + graxpert_release) - + parser.add_argument("-v", "--version", action="version", version=f"GraXpert version: {graxpert_version} release: {graxpert_release}") args = parser.parse_args() - - if (args.cli): + + if args.cli: from graxpert.CommandLineTool import CommandLineTool + clt = CommandLineTool(args) clt.execute() logging.shutdown() else: ui_main() - + else: ui_main()