Configuration

Hyrax ships with a complete default configuration file that can be used immediately to run the software, however, to make the most of Hyrax you’ll need to modify the configuration to suit your specific needs.

Using the configuration system

When creating an instance of a Hyrax object in a notebook or running hyrax from the command line, the configuration is the primary method for specifying the parameters.

If no configuration file is specified, the default will be used. To specify a different configuration file, use the -c | --runtime-config flag from the CLI or pass the path to the configuration file when creating a Hyrax object.

from hyrax import Hyrax

# Create an instance of the Hyrax object
f = Hyrax(config_file=<path_to_config_file.toml>)

# Train the model specified in the configuration file
f.train()

Your first custom configuration

You could create a copy of the entire default configuration file and modify it to suit your needs, however that’s typically not required because often there are only a few parameters that must be updated for any given Hyrax action.

If a specific configuration file is provided, Hyrax will combine it with the default configuration and overwrite the default values with the specific ones.

For example, if a file called my_config.toml had the following contents:

1[general]
2    log_level = "debug"

It could be used to override the default log_level configuration, while leaving the rest of the configuration unchanged.

from hyrax import Hyrax

# Create an instance of the Hyrax object
f = Hyrax(config_file=my_config.toml)

# Train the model specified in the configuration file
f.train()

Updating settings in a notebook

Additionally, Hyrax supports modification of the configuration interactively in a notebook.

from hyrax import Hyrax

# Create a Hyrax instance, implicitly using the default configuration
f = Hyrax()

# Set the log level for the Hyrax instance config
f.config['general']['log_level'] = 'debug'

# Train the model specified in the configuration file
f.train()

Immutable configurations

Once Hyrax begins running an action, the configuration becomes immutable. This means that the configuration cannot be changed during the execution of an action, and attempting to do so in code will raise an exception.

By making the configuration immutable during execution, we ensure that the state of all parameters can be accurately saved with the results of the action.

About the default configuration

The default configuration for Hyrax contains safe default values for all of the settings that Hyrax uses. A portion of the default configuration file is shown below.

Note

Only the first portion of the default configuration file is shown below. The entire file can be found at the bottom of the page here: Complete default configuration file.

 1[general]
 2# Set to `true` during development to skip checking for default config values
 3# in external libraries. Use `false` otherwise.
 4dev_mode = false
 5
 6# Destination of log messages. Options: 'stderr', 'stdout' specify the console,
 7# "path/to/hyrax.log" specifies a file.
 8log_destination = "stderr"
 9
10# Lowest log level to emit. Options: "critical", "error", "warning", "info", "debug".
11log_level = "info"
12
13# Directory where data is stored.
14data_dir = "./data"
15
16#Top level directory for writing results.
17results_dir = "./results"
18
19
20[download]
21# Cut out width in arcseconds.
22sw = "22asec"
23
24# Cut out height in arcseconds.
25sh = "22asec"

There is a lot of information there, but don’t worry, we’ll break it down for you.

First, the file formatted using TOML for its easy readability and because it is one of the few markdown languages that natively support comments. TOML files are organized into “tables”, and each table contains one or more key/value pairs.

For instance the [general] table (the first table in the config) contains several keys including log_level and results_dir. Each of those keys has a value associated with it. e.g. log_level = "info".

Second, every key has an associated comment describing what the key does. We attempt to keep the comments as concise as possible.

Finally, the configuration file is organized into tables that roughly correspond to the different actions that Hyrax can take. For instance, the [train] table contains parameters needed when training a model such as epochs and weights_filename. While the [infer] table contains keys such as model_weights_file.

Complete default configuration file

  1[general]
  2# Set to `true` during development to skip checking for default config values
  3# in external libraries. Use `false` otherwise.
  4dev_mode = false
  5
  6# Destination of log messages. Options: 'stderr', 'stdout' specify the console,
  7# "path/to/hyrax.log" specifies a file.
  8log_destination = "stderr"
  9
 10# Lowest log level to emit. Options: "critical", "error", "warning", "info", "debug".
 11log_level = "info"
 12
 13# Directory where data is stored.
 14data_dir = "./data"
 15
 16#Top level directory for writing results.
 17results_dir = "./results"
 18
 19
 20[download]
 21# Cut out width in arcseconds.
 22sw = "22asec"
 23
 24# Cut out height in arcseconds.
 25sh = "22asec"
 26
 27# The filters to download.
 28filter = ["HSC-G", "HSC-R", "HSC-I", "HSC-Z", "HSC-Y"]
 29
 30# The type of data to download.
 31type = "coadd"
 32
 33# The data release to download from.
 34rerun = "pdr3_wide"
 35
 36# Path to credentials.ini file for the downloader. File contents should be:
 37# username = "<your username>"
 38# password = "<your password>"
 39credentials_file = "./credentials.ini"
 40
 41# Alternate way to pass credentials to the downloader. Users should prefer a
 42# credentials.ini file to avoid exposing credentials with source control.
 43username = false
 44password = false
 45
 46# The number of sources to download from the catalog. Default is -1, which
 47# downloads all sources in the catalog.
 48num_sources = -1
 49
 50# The number of concurrent connections to use when downloading data.
 51concurrent_connections = 4
 52
 53# The number of seconds between printing download statistics.
 54stats_print_interval = 60
 55
 56# The path to the catalog file that defines which cutouts to download.
 57fits_file = "./catalog.fits"
 58
 59# The number of seconds to wait before retrying a failed HTTP request in seconds.
 60retry_wait = 30
 61
 62# How many times to retry a failed HTTP request before moving on to the next one.
 63retries = 3
 64
 65# Number of seconds to wait for a full HTTP response from the server.
 66timeout = 3600
 67
 68# The number of sky location rectangles should we request in a single request.
 69chunk_size = 990
 70
 71# Request the image layer from the cutout service
 72image = true
 73
 74# Request the variance layer from the cutout service
 75variance = false
 76
 77# Request the mask layer from the cutout service
 78mask = false
 79
 80
 81[model]
 82# NOTE: All parameters are NOT used by all models. Check the model code before training.
 83
 84# The name of the model to use. Option are a built-in model class name or import path
 85# to an external model. e.g. "HyraxAutoencoder", "user_pkg.model.ExternalModel"
 86name = "HyraxAutoencoder"
 87
 88# The number of output channels from the first layer.
 89base_channel_size = 32
 90
 91# The length of the latent space vector. 
 92latent_dim = 64
 93
 94# The activation function of the final layer.
 95final_layer = "tanh"
 96
 97
 98[model.HyraxCNN]
 99# The number of classes to predict as the output of the model. i.e. 2 would be a
100# binary classifer, 10 would predict the 10 classes in the CiFAR dataset.
101output_classes = 10
102
103
104[criterion]
105# The name of the built-in criterion to use or the import path to an external criterion
106name = "torch.nn.CrossEntropyLoss"
107
108# Whether to "sum" or "mean" loss across channels. Only used by HyraxAutoencoderV2
109band_loss_reduction = "mean"
110
111
112[optimizer]
113# The name of the built-in optimizer to use or the import path to an external optimizer
114name = "torch.optim.SGD"
115
116
117["torch.optim.SGD"]
118# learning rate for torch.optim.SGD optimizer.
119lr = 0.01
120
121# momentum for torch.optim.SGD optimizer.
122momentum = 0.9
123
124["torch.optim.Adam"]
125# learning rate for torch.optim.SGD optimizer.
126lr = 0.01
127
128
129[train]
130# The name of the file were the model weights will be saved after training.
131weights_filename = "example_model.pth"
132
133#The number of epochs to train for.
134epochs = 10
135
136# If resuming from a check point, set to the path of the checkpoint file.
137# Otherwise set to `false` to start training from the beginning.
138resume = false
139
140# The data_set split to use when training a model.
141split = "train"
142
143# The name of the experiment when logging training results to mlflow
144experiment_name = "notebook"
145
146# The name of the run when logging training results to mlflow.
147# If false, uses result directory string, <timestamp>-train-<uid>, as run name.
148run_name = false
149
150[onnx]
151
152# The operator set version to use when exporting a model. See the following for info:
153# https://onnxruntime.ai/docs/reference/compatibility.html#onnx-opset-support
154opset_version = 20
155
156
157[model_inputs]
158# Note - the sub-table (model_inputs.<sub-table>) can be named anything you like.
159[model_inputs.data]
160# Name of the dataset class to use, or the import path to an external dataset class.
161# e.g. "HyraxCifarDataSet", "user_pkg.data_set.ExternalDataset".
162dataset_class = "HyraxCifarDataSet"
163
164# Location (directory) where the data is stored.
165data_location = "./data"
166
167# The data field that represents a unique ID for each sample.
168primary_id_field = "object_id"
169
170
171[data_set]
172# Warning - using data_set.name to define the dataset class will be deprecated.
173# Please use [model_inputs.<friendly_name>.dataset_class] instead. See usage above.
174name = "HyraxCifarDataSet"
175
176# Crop pixel dimensions for images, e.g., [100, 100]. If false, scans for the
177# smallest image size in [general].data_dir and uses it.
178crop_to = false
179
180# Used by HSCDataSet, LSSTDataset, and DownloadedLSSTDataset. 
181# Limit to only particular filters. When `false`, use all filters. 
182# Options: ["HSC-G", "HSC-R", "HSC-I", "HSC-Z", "HSC-Y"] for HSC
183# Options: ["u", "g", "r", "i", "z" , "y"] for LSST
184filters = false
185
186# Path to a fits file that specifies object IDs to use from the data stored in
187# [general].data_dir. Implementation is data_set class dependent. Use `false` for no filtering.
188filter_catalog = false
189
190# The transformation to be applied to images before being passed on to the model
191# This must be a valid Numpy function. Passing false will result in no transformations
192# (other than cropping) be applied to the images.  
193transform = "tanh"
194
195# train_size, validation_size, and test_size use these conventions:
196# * A `float` between `0.0` and `1.0` is the proportion of the dataset to include in the split.
197# * An `int`, represents the absolute number of samples in the particular split.
198# * It is an error for these values to add to more than 1.0 as ratios or the size
199#   of the dataset if expressed as integers.
200
201# Size of the train split. If `false`, the value is automatically set to the
202# complement of test_size plus validate_size (if any).
203train_size = 0.6
204
205# Size of the validation split. If `false`, and both train_size and test_size
206# are defined, the value is set to the complement of the other two sizes summed.
207# If `false`, and only one of the other sizes is defined, no validate split is created.
208validate_size = 0.2
209
210# Size of the test split. If `false`, the value is set to the complement of train_size plus
211# the validate_size (if any). If `false` and `train_size = false`, test_size is set to `0.25`.
212test_size = 0.2
213
214# Number to seed with for generating a random split. Use `false` to seed from a
215# system source at runtime.
216seed = false
217
218# If `true`, cache samples in memory during training to reduce runtime after the
219# first epoch. Set to `false` when running inference or on memory-constrained systems.
220use_cache = true
221
222# If `true`, preload the in memory cache using many worker threads when the dataset is constructed 
223# to reduce the effect of filesystem latency on first epoch runtime. 
224# Warning: Only suitable for situations where the entire dataset fits in system memory
225preload_cache = true
226
227# Override the name of the object_id column for FitsImageDataset, HSCDataset and DownloadedLSSTDataset
228object_id_column_name = false
229
230# Override the name of the filter column for FitsImageDataset and HSCDataset
231filter_column_name = false
232
233# Override the name of the filename column for FitsImageDataset and HSCDataset
234filename_column_name = false
235
236# Replace NaN in input data with a value, modes are false for no replacement or "quantile" to replace with a 
237# defined quantile of the non-NaN data, see nan_quantile.
238nan_mode = false
239
240# When replacing NaN values with a quantile, which quantile in the non-nan tensor should be used.
241nan_quantile = 0.05
242
243# The astropy table to use as a catalog in LSSTDataSet and friends
244astropy_table = false
245
246# Semi width in degrees of cutouts made from the butler (17 arcsec)
247semi_width_deg = 0.00472
248
249# Semi height in degrees of cutouts made from the butler (17 arcsec)
250semi_height_deg = 0.00472
251
252
253
254[data_set.HyraxRandomDataset]
255# Total number of samples produced by the random dataset
256size = 100
257
258# The dimensions of the numpy arrays that will be produced for each sample represented
259# as a list where each element is the size of dimension.
260shape = [2,5,5]
261
262# Seed to use for random number generation
263seed = 42
264
265# If a list is provided, the data will have randomly labeled with values from the list
266# If set to false, no labels will be included with the data.
267provided_labels = [0, 1, 2]
268
269# Set this to a positive integer to randomly replace some values with an "invalid" value.
270number_invalid_values = 0
271
272# The value to use for invalid values in the data. Must be one of the following:
273# "nan", "inf", "-inf", "none" or a float value.
274invalid_value_type = "nan"
275
276
277[data_loader]
278# The number of data points to load at once.
279batch_size = 512
280
281# STRONG RECOMMENDATION: Leave this as `false`.
282# Ensure that the data loader does no secondary shuffling of the data.
283shuffle = false
284
285
286[infer]
287# The path to the model weights file to use for inference.
288model_weights_file = false
289
290# The data_set split to use for inference. Use `false` for entire dataset.
291split = false
292
293
294[vector_db]
295# The type of vector db to use. Use "false" to disable vector database.
296name = "chromadb"
297
298# The directory where the vector database will be stored. Use "false" to create
299# a new vector database in a timestamped directory. Otherwise set to a path.
300vector_db_dir = false
301
302# The path to inference results. Setting to "false" will use the most recent
303# inference results.
304infer_results_dir = false
305
306
307[vector_db.chromadb]
308# The approximate maximum size of a shard before creating a new one. A smaller
309# value will decrease insert times while increasing search times.
310shard_size_limit = 65536
311
312# Inserting vectors with more than this many elements logs a warning message. ChromaDB
313# performance degrades with vectors of this size. Set to "false" to disable warning.
314vector_size_warning = 10000
315
316
317[vector_db.qdrant]
318# The number of elements in the vectors that will be stored in the vector database.
319# This must be the same as the size of the vectors produced by the model.
320vector_size = 64
321
322
323[results]
324# Path to inference results to use for visualization and lookups. Uses latest inference run if none provided.
325inference_dir = false
326
327
328[umap]
329# Number of data points used to fit the umap transform.
330fit_sample_size = 1024
331
332# Save the fitted umap as a pickle file 
333save_fit_umap = true
334
335# Use multiprocessing during transforming to umap space (More memory intensive)
336parallel = false
337
338# Name of the umap implementation to use
339name = "umap.UMAP"
340
341
342[umap.UMAP]
343# Specify any parameter accepted by https://umap-learn.readthedocs.io/en/latest/api.html#umap
344# Dimension of the embedded space
345n_components = 2
346
347# Controls how UMAP balances local versus global structure in the data.
348# See official documentation for details.
349n_neighbors = 15
350
351[visualize]
352
353# List of metadata field names to use in visualizer. Must be available as metadata in your dataset
354fields = []
355
356# Whether to display a panel of randomly chosen images corresponding to the selected points
357display_images = false
358
359# Name of catalog column to use for coloring points in the scatter plot. Use false for no coloring.
360color_column = false
361
362# Colormap to use for coloring points in the scatter plot when color_column is specified
363cmap = "viridis"
364
365# Only valid for .pt tensor images. Which bands should be loaded for display
366# [0,3,5] would map bands in that order to R,G,B. Single band will be grayscale.
367torch_tensor_bands = [3]
368
369# Whether to rasterize plot. Will break coloring (Haloviews Bug)
370# Helpful to reduce lag in large datasets. 
371rasterize_plot = false