ALE on the Command Line - isd_generate¶
Prerequisites¶
Before you can generate an ISD, you will need:
- ALE
- An image (Locating Image Data) formatted according to your driver type.
- SPICE Data according to your driver type (optionally, use web-based spice with
-wflag)
Using Web Spice
Using web-based spice with -w might still be buggy for some missions. Report any issues to the ALE repo.
See Getting Started with ALE for an overview of ALE Installation, NAIF SPICE Data Setup, and other ALE Topics.
Driver Types¶
For NaifSpice + IsisLabel Drivers, you will need:
-
An image imported into ISIS .cub format with a
-2isisapp. -
NAIF SPICE Kernels (See Setting up NAIF Data).
For IsisSpice Drivers, you will need:
-
An image imported into ISIS .cub format with a
-2isisapp, -
AND the image must be
spiceinited withspiceinit from=<your.cub>.
For Pds3Label Drivers, you will need:
-
An image in PDS3 format
-
NAIF SPICE Kernels (See Setting up NAIF Data).
Driver Types: NaifSpice, IsisSpice, IsisLabel, and Pds3Label.
NaifSpice drivers use the NAIF Kernels to look up spice data to an image, while IsisSpice drivers depend on the image already having spice data attached with spiceinit.
IsisLabel drivers use images in the ISIS .cub format, while Pds3Label drivers use images in the PDS format.
NaifSpice + IsisLabel is the most commonly used driver type, but you can check the ALE driver to find out if IsisSpice or Pds3Label drivers are available instead or in addition:
- Look at the drivers in the ALE repository.
- Click on the drivers for the spacecraft that captured your image.
- Find the class for your sensor, and look for NaifSpice, IsisSpice, IsisLabel, or Pds3Label next to the class name.
There may be a class for both NaifSpice and IsisSpice; in that case you can use either, or use the -n or -i argument to specify which one to use. You might use -i for IsisSpice if you want to avoid re-spiceiniting a .cub.
By default, ALE will run through different drivers until either it finds one that works (at which point it will stop), or all drivers fail.
Using isd_generate¶
The basic usage of isd_generate is as follows:
isd_generate default run, no arguments
To run isd_generate with no arguments on a .cub named B10_013341_1010_XN_79S172W.cub:
Output¶
Upon a successful run of isd_generate, an uncompressed ISD file will be generated.
By default, this is your image's name, with a .json file extension (i.e. B10_013341_1010_XN_79S172W.json).
Specifying Output
To output to a specified filename, use --out or -o. This example outputs a 'MyIsd.json' file:
To output a brotli-compressed ISD, use --compress or -c. This results in a .br file:
To uncompress an ISD (converts .br to .json):
Verbosity¶
When using the --verbose (-v) argument, program run information
is printed to the console, followed by the text of the ISD. This can be helpful when troubleshooting.
NAIF SPICE Data and Kernels¶
To ensure the use of a NaifSpice Driver (and NAIF SPICE Data) to generate an ISD, use the --only_naif_spice (-n) flag. If you have a spiceinited .cub and you want to avoid re-spiceiniting it or using NAIF SPICE Data, use the --only-isis-spice (-i) flag.
When using an NAIF SPICE Data, you can specify a metakernel using the --kernel (-k) argument, followed by the path to your metakernel.
Using a NaifSpice Driver with a metakernel
Folder with example NAIF Data: [Download as .zip] [View in GitHub]
This folder contains NAIF Data consisting of the various kernels
necessary to generate an ISD for the B10_013341_1010_XN_79S172W image.
You can open the kernels ending in .t* and view their contents as text files.
The kernels ending in .b* are binary kernels;
NAIF SPICE Utilities
can be used to investigate their contents.
mro_B10_72W.tm is the metakernel file.
If you open it, you can see it is a list of other kernels.
If you needed to use specific kernels, you could copy a metakernal and edit the list.
To use a NaifSpice Driver and specify a metakernal:
Troubleshooting¶
Troubleshooting Checklist
- Is your image in ISIS format (or PDS format for Pds3Label Drivers)?
- use
a
-2isisapp to convert images to ISIS format.
- use
a
- Do you have spice data set up?
- If using a NaifSpice Driver:
- Spice Data Downloaded from NAIF?
-
$ALESPICEROOTset? - Metakernel
PATH_VALUEset?
- If using an IsisSpice Driver:
- Spice Data attached to your image by
spiceinit?
- Spice Data attached to your image by
- If using a NaifSpice Driver:
- Check what's wrong with a
--verboserun.
Investigating with --verbose¶
Use the --verbose (-v) argument to troubleshoot and see why ALE might not be recognizing your image.
Check for info about the failure under Trying <class 'ale.drivers.[X]_drivers...'> where [X] is
ALE's abbreviation for the spacecraft/sensor that captured your image.
If requesting assistance, it may be helpful to post what version of ALE you have, shown with:
Arguments¶
Output File¶
-o,--out[filename]-
Optional output file. If not specified, this will be set to the input filename with its final suffix replaced with .json. If multiple input files are provided, this option will be ignored and the default strategy of replacing their final suffix with .json will be used to generate the output file paths.
-c,--compress-
Output a compressed isd json file with .br file extension. Ale uses the brotli compression algorithm. To decompress an isd file run:
python -c "import ale.isd_generate as isdg; isdg.decompress_json('/path/to/isd.br')"
ALE Processing Settings and Info¶
-v,--verbose-
Display extra information as program runs.
--version-
Shows ALE version number
--max_workers[integer]-
If more than one file is provided to work on, this program will engage multiprocessing to parallelize the work. This multiprocessing will default to the number of processors on the machine. If you want to throttle this to use less resources on your machine, indicate the number of processors you want to use.
Spice Data¶
-w,--use_web_spice- Indicates that the program should get Kernel information over the web using the SpiceQL backend. This is an experimental setting, report any bugs to the ALE repo.
-k,--kernel[filename]-
Typically this is an optional metakernel file, care should be taken by the user that it is applicable to all of the input files. It can also be a single ISIS cube, which is sometimes needed if the input file is a label file.
-i,--only_isis_spice-
Only use drivers that read from spiceinit'd ISIS cubes.
-n,--only_naif_spice-
Only use drivers that generate fresh spice data.
Spatial Settings¶
-l,--local-
Generate local spice data, an isd that is unaware of itself relative to target body. This is largely used for landed/rover data.
-N,--nadir-
Generate nadir spice pointing, an isd that has pointing directly towards the center of the target body.