Experiment overview
| Setting | Value |
|---|
| Max. nr. evaluations | 4 |
| Max. nr. evaluations (from arguments) | 2 |
| Number random steps | 1 |
| Nr. of workers (parameter) | 1 |
| Main process memory (GB) | 8 |
| Worker memory (GB) | 4 |
| Nr. imported jobs | 2 |
Best RESULT, min (total: 2 + inserted jobs: 2)
| OO_Info_int_param | OO_Info_int_param_two | OO_Info_float_param | OO_Info_choice_param | OO_Info_SLURM_JOB_ID | int_param | float_param | int_param_two | choice_param | RESULT |
|---|
| -100.0 | -100.0 | -100.0 | 2.0 | 1169835.0 | -100 | -100.0 | -100 | 2 | -330166.12 |
Job Summary per Generation Node
| Generation Node | Total | COMPLETED |
| SOBOL | 1 | 1 |
| BOTORCH_MODULAR | 3 | 3 |
Experiment parameters
| Name | Type | Lower bound | Upper bound | Values | Type | Log Scale? |
|---|
| int_param | rangeparameter | -100 | 10 | | int | No |
| float_param | rangeparameter | -100 | 10 | | float | No |
| choice_param | choiceparameter | | | 1, 2, 4, 8, 16, hallo | | |
| int_param_two | rangeparameter | -100 | 10 | | int | No |
Number of evaluations
| Failed |
Succeeded |
Running |
Total |
| 0 |
4 |
0 |
4 |
Result names and types
Last progressbar status
2025-10-25 00:11:53 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, waiting for 1 job, finished 1 job
Git-Version
Commit: 87dbf732124d22378d92f4f9fd4a3243b54c0639 (8883-2-g87dbf7321)
trial_index,submit_time,queue_time,worker_generator_uuid,start_time,end_time,run_time,program_string,exit_code,signal,hostname,OO_Info_int_param,OO_Info_int_param_two,OO_Info_float_param,OO_Info_choice_param,OO_Info_SLURM_JOB_ID,arm_name,trial_status,generation_node,RESULT,int_param,float_param,int_param_two,choice_param
0,,,,,,,,,,,,,,,,0_0,COMPLETED,SOBOL,-44757.758453810296487063169479370117,-25,-18.47261905670166015625,-49,16
1,,,,,,,,,,,,,,,,1_0,COMPLETED,BOTORCH_MODULAR,-211290.86524153899517841637134552002,-93,-95.709654572706540420767851173878,-32,2
2,1761343783,94,41b4affe-3400-461c-a5b7-6140617ac68b,1761343877,1761343883,6,./.tests/optimization_example --int_param='-100' --float_param='-100' --choice_param='2' --int_param_two='-100' --nr_results=1,0,,c131,-100,-100,-100,2,1169835,2_0,COMPLETED,BOTORCH_MODULAR,-330166.119999999995343387126922607422,-100,-100,-100,2
3,1761343887,15,41b4affe-3400-461c-a5b7-6140617ac68b,1761343902,1761343908,6,./.tests/optimization_example --int_param='-100' --float_param='-45.11725223336728873846' --choice_param='2' --int_param_two='-100' --nr_results=1,0,,c44,-100,-100,-45.117252233367288738463685149327,2,1169839,3_0,COMPLETED,BOTORCH_MODULAR,-245033.509714229992823675274848937988,-100,-45.117252233367288738463685149327,-100,2
========================================================================
To cancel, press CTRL c, then run 'scancel 1169823'
⠋ Importing logging...
⠋ Importing warnings...
⠋ Importing argparse...
⠋ Importing datetime...
⠋ Importing dataclass...
⠋ Importing socket...
⠋ Importing stat...
⠋ Importing pwd...
⠋ Importing base64...
⠋ Importing json...
⠋ Importing yaml...
⠋ Importing toml...
⠋ Importing csv...
⠋ Importing ast...
⠋ Importing rich.table...
⠋ Importing rich print...
⠋ Importing rich.pretty...
⠋ Importing pformat...
⠋ Importing rich.prompt...
⠋ Importing types.FunctionType...
⠋ Importing typing...
⠋ Importing ThreadPoolExecutor...
⠋ Importing submitit.LocalExecutor...
⠋ Importing submitit.Job...
⠋ Importing importlib.util...
⠋ Importing platform...
⠋ Importing inspect frame info...
⠋ Importing pathlib.Path...
⠋ Importing uuid...
⠋ Importing cowsay...
⠋ Importing shutil...
⠋ Importing itertools.combinations...
⠋ Importing os.listdir...
⠋ Importing os.path...
⠋ Importing PIL.Image...
⠋ Importing sixel...
⠋ Importing subprocess...
⠋ Importing tqdm...
⠙ Importing beartype...
⠋ Importing statistics...
⠋ Trying to import pyfiglet...
⠇ Importing helpers...
⠋ Parsing arguments...
⠴ Importing torch...
⠋ Importing numpy...
[WARNING 10-25 00:09:30] ax.service.utils.with_db_settings_base: Ax currently requires a sqlalchemy version below 2.0. This will be addressed in a future release. Disabling SQL storage in Ax for now, if you would like to use SQL storage please install Ax with mysql extras via `pip install ax-platform[mysql]`.
⠴ Importing ax...
⠋ Importing ax.core.generator_run...
⠋ Importing Cont_X_trans and Y_trans from ax.adapter.registry...
⠋ Importing ax.core.arm...
⠋ Importing ax.core.objective...
⠋ Importing ax.core.Metric...
⠋ Importing ax.exceptions.core...
⠋ Importing ax.exceptions.generation_strategy...
⠋ Importing CORE_DECODER_REGISTRY...
⠋ Trying ax.generation_strategy.generation_node...
⠋ Importing GenerationStep, GenerationStrategy from generation_strategy...
⠋ Importing GenerationNode from generation_node...
⠋ Importing ExternalGenerationNode...
⠋ Importing MaxTrials...
⠋ Importing GeneratorSpec...
⠋ Importing Models from ax.generation_strategy.registry...
⠋ Importing get_pending_observation_features...
⠋ Importing load_experiment...
⠋ Importing save_experiment...
⠋ Importing save_experiment_to_db...
⠋ Importing TrialStatus...
⠋ Importing Data...
⠋ Importing Experiment...
⠋ Importing parameter types...
⠋ Importing TParameterization...
⠋ Importing pandas...
⠋ Importing AxClient and ObjectiveProperties...
⠋ Importing RandomForestRegressor...
⠋ Importing botorch...
⠋ Importing submitit...
⠋ Importing ax logger...
⠋ Importing SQL-Storage-Stuff...
Using old run's --time: 60
Run-UUID: a18cc77b-7fc8-4ee0-8013-afb4e86d5198
_________________________________________________
/ \
| OmniOpt2 - Optimizing like a koala climbing a tre |
| e—slowly but surely reaching the perfect spot. |
\ /
=================================================
\
\
\
\
("`-' '-/") .___..--' ' "`-._
` *_ * ) `-. ( ) .`-.__. `)
(_Y_.) ' ._ ) `._` ; `` -. .-'
_.. `--'_..-_/ /--' _ .' ,4
( i l ),-'' ( l i),' ( ( ! .-'
⠋ Writing worker creation log...
omniopt --continue runs/__main__tests__BOTORCH_MODULAR___nogridsearch/0 --num_parallel_jobs 1 --worker_timeout 10 --follow --gpus=1 --mem_gb=4 --num_random_steps=1 --max_eval=2 --send_anonymized_usage_stats --generate_all_jobs_at_once --live_share --live_share
⠋ Disabling logging...
⠋ Setting run folder...
⠋ Creating folder /data/horse/ws/s3811141-oo_crap/omniopt/runs/__main__tests__BOTORCH_MODULAR___nogridsearch/1...
⠋ Writing revert_to_random_when_seemingly_exhausted file ...
⠋ Writing username state file...
⠋ Writing result names file...
⠋ Writing result min/max file...
⠋ Saving state files...
Run-folder: /data/horse/ws/s3811141-oo_crap/omniopt/runs/__main__tests__BOTORCH_MODULAR___nogridsearch/1
Continuation from runs/__main__tests__BOTORCH_MODULAR___nogridsearch/0
⠋ Writing live_share file if it is present...
⠋ Writing job_start_time file...
⠸ Writing git information
⠋ Checking max_eval...
⠋ Calculating number of steps...
⠋ Adding excluded nodes...
⠋ Initializing ax_client...
⠋ Setting orchestrator...
See https://imageseg.scads.de/omniax/share?user_id=s3811141&experiment_name=__main__tests__BOTORCH_MODULAR___nogridsearch&run_nr=28 for live-results.
You have 1 CPUs available for the main process. Using CUDA device NVIDIA H100.
Generation strategy: BOTORCH_MODULAR for 5 steps.
Run-Program: ./.tests/optimization_example --int_param='%(int_param)' --float_param='%(float_param)' --choice_param='%(choice_param)' --int_param_two='%(int_param_two)' --nr_results=1
Experiment parameters
┏━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━┳━━━━━━━━━━━━┓
┃ Name ┃ Type ┃ Lower bound ┃ Upper bound ┃ Values ┃ Type ┃ Log Scale? ┃
┡━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━╇━━━━━━━━━━━━┩
│ int_param │ rangeparameter │ -100 │ 10 │ │ int │ No │
│ float_param │ rangeparameter │ -100 │ 10 │ │ float │ No │
│ choice_param │ choiceparameter │ │ │ 1, 2, 4, 8, 16, hallo │ │ │
│ int_param_two │ rangeparameter │ -100 │ 10 │ │ int │ No │
└───────────────┴─────────────────┴─────────────┴─────────────┴───────────────────────┴───────┴────────────┘
Result-Names
┏━━━━━━━━━━━━━┳━━━━━━━━━━━━━┓
┃ Result-Name ┃ Min or max? ┃
┡━━━━━━━━━━━━━╇━━━━━━━━━━━━━┩
│ RESULT │ min │
└─────────────┴─────────────┘
⠙ Write files and show overview
BOTORCH_MODULAR, best RESULT: -330166.12, waiting for 1 job, finished 1 job : 100%|██████████| 4/4 [02:13<00:00, 33.42s/it]
Best RESULT, min (total: 2 + inserted jobs: 2)
┏━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━┳━━━━━━━━━━━━┓
┃ OO_Info_int_param ┃ OO_Info_int_param_two ┃ OO_Info_float_param ┃ OO_Info_choice_param ┃ OO_Info_SLURM_JOB_ID ┃ int_param ┃ float_param ┃ int_param_two ┃ choice_param ┃ RESULT ┃
┡━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━╇━━━━━━━━━━━━┩
│ -100.0 │ -100.0 │ -100.0 │ 2.0 │ 1169835.0 │ -100 │ -100.0 │ -100 │ 2 │ -330166.12 │
└───────────────────┴───────────────────────┴─────────────────────┴──────────────────────┴──────────────────────┴───────────┴─────────────┴───────────────┴──────────────┴────────────┘
Runtime Infos
┏━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━━━━━┳━━━━━━━━━━━━━┓
┃ Number of evaluations ┃ Min time ┃ Max time ┃ Average time ┃ Median time ┃
┡━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━╇━━━━━━━━━━━╇━━━━━━━━━━━━━━╇━━━━━━━━━━━━━┩
│ 2 │ 6.00 sec │ 6.00 sec │ 6.00 sec │ 6.00 sec │
└───────────────────────┴───────────┴───────────┴──────────────┴─────────────┘
2025-10-25 00:09:39 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, Started OmniOpt2 run...
2025-10-25 00:09:42 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, getting new HP set
2025-10-25 00:09:42 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, requested 1 jobs, got 1, 1.97 s/job
2025-10-25 00:09:43 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, eval #1/1 start
2025-10-25 00:09:43 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, starting new job
2025-10-25 00:09:44 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, unknown 1 = ∑1/1, started new job
2025-10-25 00:09:45 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, unknown 1 = ∑1/1, waiting for 1 job
2025-10-25 00:09:50 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, pending 1 = ∑1/1, waiting for 1 job
2025-10-25 00:10:44 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, running 1 = ∑1/1, waiting for 1 job
2025-10-25 00:11:24 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, running 1 = ∑1/1, new result: RESULT: -330166.120000
2025-10-25 00:11:26 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, waiting for 1 job, finished 1 job
2025-10-25 00:11:27 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, getting new HP set
2025-10-25 00:11:27 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, requested 1 jobs, got 1, 0.79 s/job
2025-10-25 00:11:27 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, eval #1/1 start
2025-10-25 00:11:27 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, starting new job
2025-10-25 00:11:28 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, unknown 1 = ∑1/1, started new job
2025-10-25 00:11:29 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, unknown 1 = ∑1/1, waiting for 1 job
2025-10-25 00:11:30 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, pending 1 = ∑1/1, waiting for 1 job
2025-10-25 00:11:49 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, completed 1 = ∑1/1, new result: RESULT: -245033.509714
2025-10-25 00:11:53 (41b4affe-3400-461c-a5b7-6140617ac68b): BOTORCH_MODULAR, best RESULT: -330166.12, waiting for 1 job, finished 1 job
Job submission durations
┏━━━━━━━━━┳━━━━━━━━━┳━━━━━━┳━━━━━━━━━━━━━━┓
┃ Batch ┃ Seconds ┃ Jobs ┃ Time per job ┃
┡━━━━━━━━━╇━━━━━━━━━╇━━━━━━╇━━━━━━━━━━━━━━┩
│ 1 │ 1.555 │ 1 │ 1.555 │
│ 2 │ 0.321 │ 1 │ 0.321 │
├─────────┼─────────┼──────┼──────────────┤
│ Average │ 0.938 │ │ │
│ Median │ 0.938 │ │ │
│ Total │ 1.876 │ │ │
│ Max │ 1.555 │ │ │
│ Min │ 0.321 │ │ │
└─────────┴─────────┴──────┴──────────────┘
Model generation times
┏━━━━━━━━━━━┳━━━━━━━━━┳━━━━━━┳━━━━━━━━━━━━━━┓
┃ Iteration ┃ Seconds ┃ Jobs ┃ Time per job ┃
┡━━━━━━━━━━━╇━━━━━━━━━╇━━━━━━╇━━━━━━━━━━━━━━┩
│ 1 │ 1.972 │ 1 │ 1.972 │
│ 2 │ 0.788 │ 1 │ 0.788 │
├───────────┼─────────┼──────┼──────────────┤
│ Average │ 1.380 │ │ │
│ Median │ 1.380 │ │ │
│ Total │ 2.760 │ │ │
│ Max │ 1.972 │ │ │
│ Min │ 0.788 │ │ │
└───────────┴─────────┴──────┴──────────────┘
Arguments Overview
| Key | Value |
|---|
| config_yaml | None |
| config_toml | None |
| config_json | None |
| num_random_steps | 1 |
| max_eval | 2 |
| run_program | None |
| experiment_name | None |
| mem_gb | 4 |
| parameter | None |
| continue_previous_job | runs/__main__tests__BOTORCH_MODULAR___nogridsearch/0 |
| experiment_constraints | None |
| run_dir | runs |
| seed | None |
| verbose_tqdm | False |
| model | None |
| gridsearch | False |
| occ | False |
| show_sixel_scatter | False |
| show_sixel_general | False |
| show_sixel_trial_index_result | False |
| follow | True |
| send_anonymized_usage_stats | True |
| ui_url | None |
| root_venv_dir | /home/s3811141 |
| exclude | None |
| main_process_gb | 8 |
| max_nr_of_zero_results | 10 |
| abbreviate_job_names | False |
| orchestrator_file | None |
| checkout_to_latest_tested_version | False |
| live_share | True |
| disable_tqdm | False |
| disable_previous_job_constraint | False |
| workdir | |
| occ_type | euclid |
| result_names | ['RESULT=min'] |
| minkowski_p | 2 |
| signed_weighted_euclidean_weights | |
| generation_strategy | None |
| generate_all_jobs_at_once | True |
| revert_to_random_when_seemingly_exhausted | True |
| load_data_from_existing_jobs | [] |
| n_estimators_randomforest | 100 |
| max_attempts_for_generation | 20 |
| external_generator | None |
| username | None |
| max_failed_jobs | None |
| num_cpus_main_job | None |
| calculate_pareto_front_of_job | [] |
| show_generate_time_table | False |
| force_choice_for_ranges | False |
| max_abandoned_retrial | 20 |
| share_password | None |
| dryrun | False |
| db_url | None |
| run_program_once | None |
| worker_generator_path | None |
| save_to_database | False |
| range_max_difference | 1000000 |
| skip_search | False |
| dont_warm_start_refitting | False |
| refit_on_cv | False |
| fit_out_of_design | False |
| fit_abandoned | False |
| dont_jit_compile | False |
| num_restarts | 20 |
| raw_samples | 1024 |
| max_num_of_parallel_sruns | 16 |
| no_transform_inputs | False |
| no_normalize_y | False |
| transforms | [] |
| number_of_generators | 1 |
| num_parallel_jobs | 1 |
| worker_timeout | 10 |
| slurm_use_srun | False |
| time | |
| partition | |
| reservation | None |
| force_local_execution | False |
| slurm_signal_delay_s | 0 |
| nodes_per_job | 1 |
| cpus_per_task | 1 |
| account | None |
| gpus | 1 |
| dependency | None |
| run_mode | local |
| verbose | False |
| verbose_break_run_search_table | False |
| debug | False |
| flame_graph | False |
| memray | False |
| no_sleep | False |
| tests | False |
| show_worker_percentage_table_at_end | False |
| auto_exclude_defective_hosts | False |
| run_tests_that_fail_on_taurus | False |
| raise_in_eval | False |
| show_ram_every_n_seconds | 0 |
| show_generation_and_submission_sixel | False |
| just_return_defaults | False |
| prettyprint | False |
| runtime_debug | False |
| debug_stack_regex | |
| debug_stack_trace_regex | None |
| show_func_name | False |
| beartype | False |
1761343773.3252,1,0,0
1761343783.3522,1,0,0
1761343783.9586,1,1,100
1761343887.9367,1,1,100
1761343888.092,1,2,200
1761343902.9446,1,2,200
1761343903.7756,1,1,100
1761343912.9888,1,1,100
1761343913.0716,1,0,0
1761343915.2554,1,0,0
This logs the CPU and RAM usage of the main worker process.
timestamp,ram_usage_mb,cpu_usage_percent
1761343773,805.22265625,17.1
1761343833,839.41796875,16.5
1761343895,840.91796875,13.5
RESULT (goal: minimize)
Best value: -330166.12
Achieved at:
- int_param = -100
- float_param = -100
- int_param_two = -100
- choice_param = 2
Parameter statistics
| Parameter | Min | Max | Mean | Std Dev | Count |
|---|
| run_time | 6 | 6 | 6 | 0 | 2 |
| OO_Info_int_param | -100 | -100 | -100 | 0 | 2 |
| OO_Info_int_param_two | -100 | -100 | -100 | 0 | 2 |
| OO_Info_float_param | -100 | -45.1173 | -72.5586 | 27.4414 | 2 |
| OO_Info_choice_param | 2 | 2 | 2 | 0 | 2 |
| RESULT | -330166.12 | -44757.7585 | -207812.0634 | 103627.6503 | 4 |
| int_param | -100 | -25 | -79.5 | 31.5951 | 4 |
| float_param | -100 | -18.4726 | -64.8249 | 34.3805 | 4 |
| int_param_two | -100 | -32 | -70.25 | 30.3511 | 4 |
| choice_param | 2 | 16 | 5.5 | 6.0622 | 4 |
Show SLURM-Job-ID (if it exists)
submitit INFO (2025-10-25 00:10:45,307) - Starting with JobEnvironment(job_id=1169835, hostname=c131, local_rank=0(1), node=0(1), global_rank=0(1))
submitit INFO (2025-10-25 00:10:45,309) - Loading pickle: /data/horse/ws/s3811141-oo_crap/omniopt/runs/__main__tests__BOTORCH_MODULAR___nogridsearch/1/single_runs/1169835/1169835_submitted.pkl
Trial-Index: 2
Parameters: {"int_param": -100, "float_param": -100.0, "int_param_two": -100, "choice_param": 2}
Debug-Infos:
========
DEBUG INFOS START:
Program-Code: ./.tests/optimization_example --int_param='-100' --float_param='-100' --choice_param='2' --int_param_two='-100' --nr_results=1
pwd: /data/horse/ws/s3811141-oo_crap/omniopt
File: ./.tests/optimization_example
UID: 2105408
GID: 200270
SLURM_JOB_ID: 1169835
Status-Change-Time: 1755346813.0
Size: 5714 Bytes
Permissions: -rwxr-xr-x
Owner: s3811141
Last access: 1761343877.0
Last modification: 1755343211.0
Hostname: c131
========
DEBUG INFOS END
./.tests/optimization_example --int_param='-100' --float_param='-100' --choice_param='2' --int_param_two='-100' --nr_results=1
stdout:
OO-Info: int_param: -100
OO-Info: int_param_two: -100
OO-Info: float_param: -100
OO-Info: choice_param: 2
RESULT: -330166.12
stderr was empty
Result: {'RESULT': -330166.12}
Final-results: {'RESULT': -330166.12}
EXIT_CODE: 0
submitit INFO (2025-10-25 00:11:23,698) - Job completed successfully
submitit INFO (2025-10-25 00:11:23,699) - Exiting after successful completion