From d58e6147bcc5fc0f1607ee5adc4791d9e75b5db8 Mon Sep 17 00:00:00 2001 From: ga84mun Date: Thu, 18 Apr 2024 08:20:02 +0200 Subject: [PATCH 1/2] make verbose do something and citation remainder will only show once --- panoptica/panoptic_evaluator.py | 17 +++++++++++------ panoptica/timing.py | 3 ++- panoptica/utils/citation_reminder.py | 3 ++- 3 files changed, 15 insertions(+), 8 deletions(-) diff --git a/panoptica/panoptic_evaluator.py b/panoptica/panoptic_evaluator.py index 0119fbc..361627f 100644 --- a/panoptica/panoptic_evaluator.py +++ b/panoptica/panoptic_evaluator.py @@ -98,7 +98,7 @@ def panoptic_evaluate( edge_case_handler: EdgeCaseHandler | None = None, log_times: bool = False, result_all: bool = True, - verbose: bool = False, + verbose: bool = True, **kwargs, ) -> tuple[PanopticaResult, dict[str, _ProcessingPair]]: """ @@ -128,14 +128,16 @@ def panoptic_evaluate( >>> panoptic_evaluate(SemanticPair(...), instance_approximator=InstanceApproximator(), iou_threshold=0.6) (PanopticaResult(...), {'UnmatchedInstanceMap': _ProcessingPair(...), 'MatchedInstanceMap': _ProcessingPair(...)}) """ - print("Panoptic: Start Evaluation") + if verbose: + print("Panoptic: Start Evaluation") if edge_case_handler is None: # use default edgecase handler edge_case_handler = EdgeCaseHandler() debug_data: dict[str, _ProcessingPair] = {} # First Phase: Instance Approximation if isinstance(processing_pair, PanopticaResult): - print("-- Input was Panoptic Result, will just return") + if verbose: + print("-- Input was Panoptic Result, will just return") return processing_pair, debug_data # Crops away unecessary space of zeroes @@ -145,7 +147,8 @@ def panoptic_evaluate( assert ( instance_approximator is not None ), "Got SemanticPair but not InstanceApproximator" - print("-- Got SemanticPair, will approximate instances") + if verbose: + print("-- Got SemanticPair, will approximate instances") processing_pair = instance_approximator.approximate_instances(processing_pair) start = perf_counter() processing_pair = instance_approximator.approximate_instances(processing_pair) @@ -162,7 +165,8 @@ def panoptic_evaluate( ) if isinstance(processing_pair, UnmatchedInstancePair): - print("-- Got UnmatchedInstancePair, will match instances") + if verbose: + print("-- Got UnmatchedInstancePair, will match instances") assert ( instance_matcher is not None ), "Got UnmatchedInstancePair but not InstanceMatchingAlgorithm" @@ -184,7 +188,8 @@ def panoptic_evaluate( ) if isinstance(processing_pair, MatchedInstancePair): - print("-- Got MatchedInstancePair, will evaluate instances") + if verbose: + print("-- Got MatchedInstancePair, will evaluate instances") processing_pair = evaluate_matched_instance( processing_pair, eval_metrics=eval_metrics, diff --git a/panoptica/timing.py b/panoptica/timing.py index dbee75a..965df51 100644 --- a/panoptica/timing.py +++ b/panoptica/timing.py @@ -9,7 +9,8 @@ def wrapper(*args, **kwargs): result = func(*args, **kwargs) end_time = time.time() elapsed_time = end_time - start_time - print(f"-- {func.__name__} took {elapsed_time} seconds to execute.") + if hasattr(kwargs, "verbose") and getattr(kwargs, "verbose"): + print(f"-- {func.__name__} took {elapsed_time} seconds to execute.") return result return wrapper diff --git a/panoptica/utils/citation_reminder.py b/panoptica/utils/citation_reminder.py index 92cd262..8671bd8 100644 --- a/panoptica/utils/citation_reminder.py +++ b/panoptica/utils/citation_reminder.py @@ -13,7 +13,7 @@ def wrapper(*args, **kwargs): console = Console() console.rule("Thank you for using [bold]panoptica[/bold]") console.print( - f"Please support our development by citing", + "Please support our development by citing", justify="center", ) console.print( @@ -22,6 +22,7 @@ def wrapper(*args, **kwargs): ) console.rule() console.line() + os.environ["PANOPTICA_CITATION_REMINDER"] = "false" # Show only once return func(*args, **kwargs) return wrapper From c3060289eaa3063d661a93e37dc55ff28bc8e404 Mon Sep 17 00:00:00 2001 From: ga84mun Date: Thu, 18 Apr 2024 08:27:07 +0200 Subject: [PATCH 2/2] recreate old behavior --- panoptica/panoptic_evaluator.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/panoptica/panoptic_evaluator.py b/panoptica/panoptic_evaluator.py index 361627f..18b8d6f 100644 --- a/panoptica/panoptic_evaluator.py +++ b/panoptica/panoptic_evaluator.py @@ -82,7 +82,8 @@ def evaluate( decision_threshold=self.__decision_threshold, result_all=result_all, log_times=self.__log_times, - verbose=self.__verbose if verbose is None else verbose, + verbose=True if verbose is None else verbose, + verbose_calc=self.__verbose if verbose is None else verbose, ) @@ -98,7 +99,8 @@ def panoptic_evaluate( edge_case_handler: EdgeCaseHandler | None = None, log_times: bool = False, result_all: bool = True, - verbose: bool = True, + verbose=False, + verbose_calc=False, **kwargs, ) -> tuple[PanopticaResult, dict[str, _ProcessingPair]]: """ @@ -202,7 +204,7 @@ def panoptic_evaluate( if isinstance(processing_pair, PanopticaResult): if result_all: - processing_pair.calculate_all(print_errors=verbose) + processing_pair.calculate_all(print_errors=verbose_calc) return processing_pair, debug_data raise RuntimeError("End of panoptic pipeline reached without results")