Planetary Test Data contains a list of planetary data for software testing purposes and utilities to retrieve them.
- Free software: BSD license
- Downloads a core set of sample Planetary test data into
./mission_data/or./tests/mission_data/if./tests/exists.
- Download to central cache directory and use symbolic links to share data between projects or other locations.
- Find smaller example images to reduce download times.
- Command line usage improvements
- Include a mode that allows users to somehow specify subsets of data to retrieve. Perhaps selecting by mission or instrument name.
- Improve label testing.
- Include Mission Names with each product.
- Include product type with each product.
See also the Github issues for this project.
To download the core set of planetary test data install this package with pip
and then run the command get_mission_data:
pip install planetary_test_data get_mission_data
Additional usage options are shown below:
usage: get_mission_data [-h] [--all] [--file FILE] [--dir DIR] [--tags [TAGS]]
[--instruments [INSTRUMENTS]] [--missions [MISSIONS]]
optional arguments:
-h, --help show this help message and exit
--all, -a Download all products.
--file FILE, -f FILE Override default data.json by providing path to custom
data.json file.
--dir DIR, -d DIR Directory to place test data products in.
--tags [TAGS], -t [TAGS]
Retrieve products whose tags match those provided
here.
--instruments [INSTRUMENTS], -i [INSTRUMENTS]
Get products by instrument
--missions [MISSIONS], -m [MISSIONS]
Get products by mission
To get a copy of a subset of data.json:
get_mission_json
Additional usage options are shown below:
usage: get_mission_json [-h] [--all] [--file FILE] [--dir DIR] [--tags [TAGS]]
[--instruments [INSTRUMENTS]] [--missions [MISSIONS]]
optional arguments:
-h, --help show this help message and exit
--all, -a Download all products.
--file FILE, -f FILE Override default data.json by providing path to custom
data.json file.
--dir DIR, -d DIR Directory to place test data products in.
--tags [TAGS], -t [TAGS]
Retrieve products whose tags match those provided
here.
--instruments [INSTRUMENTS], -i [INSTRUMENTS]
Get products by instrument
--missions [MISSIONS], -m [MISSIONS]
Get products by mission
Running get_mission_data will do the following:
- If
testsdirectory exists it will createtests/mission_dataif necessary. Iftestsdoes not exist, it will just createmission_datain the current directory. - The data prodcuts tagged to be
coreproducts will be downloaded into the download directory. - Use the
-aor--allflag to get all the images. This, however, is NOT recommended for you will download over 200 images and labels. - The
-tor--tagswill retrieve products matched with the supplied tag. To give multiple tags, use the flag multiple times. - The
-dor--dirflag can be used to save the images in a new custom location. - If there exists a custom
data.jsonlocally and you would rather use that file to download images rather than the default, use the-for--fileflag and then the path to thedata.json. This is especially useful if there are test images needed that do not exist in or are not part of thecorein the defaultdata.json(seeget_mission_jsonbelow). - To get products by mission use the
--missionor-mflag. This will download all the products from the given mission, even noncoreproducts, unless explicity givencoreas a tag. To specify multiple missions, use the flag multiple times. You must spell the mission the same as spelled in Missions and Instruments (case matters!). - To get products by instruments use the
--instrumentsor-iflag. This will download all the products from the given instrument, even noncoreproducts, unless explicity givencoreas a tag. To specify multiple instruments, use the flag multiple times. You must spell the instrument the same as spelled in Missions and Instruments (case matters!). - Only products which do not exist in the download directory will be downloaded.
Running get_mission_json will do the following:
- Create a copy of
data.jsonin thetestsortestdirectory. This will just be thecoredata by default. The purpose of getting a copy of thedata.jsonis so it is easier to include images in respective projects that are not included in the defaultdata.json. Then developers can use the-fflag onget_mission_data(see above) to use this customdata.json. - If
data.jsonalready exists, an exception is raised. - The same flags apply to
get_mission_jsonasget_mission_data.
The PDS mission data included in the package can be found here.
The following are core products:
- 0047MH0000110010100214C00_DRCL.IMG
- 0047MH0000110010100214C00_DRCL.LBL
- 1p134482118erp0902p2600r8m1.img
- 1p190678905erp64kcp2600l8c1.img
- 2p129641989eth0361p2600r8m1.img
- 2m132591087cfd1800p2977m2f1.img
- h58n3118.img
- r01090al.img
If there are products you think should be included or removed from this dataset
please file a Github issue. New images should be images from instruments that
are not already included or different file types (i.e. EDR vs RDR). New core
images should be distinctly different than the ones that exist and would expose
test and/or edge cases for multiple PlanetaryPy projects/affiliates. For
example, if there was not an RGB image included in the core products (which
there is), then that would test image would expose an edge case for many
projects. However, it is best to use get_mission_json to get a copy of
data.json, add the desired test images to that json file, and then download
images using get_mission_data -f path/to/data.json. We recommend using a
make test command to get the proper mission data before testing.
The data.json file contains PDS product names, urls and other
metainformation about the product. This structure will be extended to support
generic testing, for instance the label key will be changed to a
dictionary that includes product label keys and the values found at those keys.
Below is a sample snippet of a data.json entry:
"1m298459885effa312p2956m2m1.img": {
"instrument": "MICROSCOPIC IMAGER",
"label": "PDS3",
"opens": "True",
"url": "http://pds-imaging.jpl.nasa.gov/data/mer/opportunity/mer1mo_0xxx/data/sol1918/edr/1m298459885effa312p2956m2m1.img"
},
The following missions and their instruments have products available for testing:
- 2001 Mars Odyssey
- Thermal Emission Imaging System
- Cassini
- Cassini Radar
- Imaging Science Subsystem
- Imaging Science Subsystem Narrow Angle
- Visual And Infrared Mapping Spectrometer
- Chandrayaan-1
- Context Camera
- High Resolution Imaging Science Experiment
- Mars Color Imager
- Moon Mineralogy Mapper
- Clementine
- High Resolution Camera
- Long Wave Infrared Camera
- Nearinfrared Camera
- Ultraviolet/Visible (Uv/Vis) Camera
- Ultraviolet/Visible Camera
- ESA Mars Express
- High Resolution Stereo Camera
- Galileo
- Near-Infrared Mapping Spectrometer
- Solid_State_Imaging
- Lunar Reconnaissance Orbiter
- Lunar Reconnaissance Orbiter Camera
- Lyman Alpha Mapping Project
- Mid Infrared Camera 1
- Mid Infrared Camera 2
- Near Infrared Camera 1
- Near Infrared Camera 2
- Near Infrared Spectrometer 1
- Near Infrared Spectrometer 2
- Total Luminance Photometer
- Visible Camera
- Visible Spectrometer
- MESSENGER
- Mercury Dual Imaging System Narrow Angle Camera
- Mercury Dual Imaging System Narrow Angle Camera, Mercury Dual Imaging System Wide Angle Camera
- Mercury Dual Imaging System Wide Angle Camera
- Magellan
- Global Topography Data Record
- Radar
- Radar System
- Synthetic-Aperture Radar
- Mariner 10
- Mariner 10
- Mariner 9
- Imaging Science Subsystem
- Mars Exploration Rover
- Alpha Particle X-Ray Spectrometer
- Descent Camera
- Front Hazard Avoidance Camera Left
- Front Hazard Avoidance Camera Right
- Hazard Avoidance Camera
- Microscopic Imager
- Moessbauer Spectrometer
- Navigation Camera
- Navigation Camera Left
- Panoramic Camera
- Panoramic Camera Left
- Panoramic Camera Right
- Panoromic Camera
- Rock Abrasion Tool
- Mars Global Surveyor
- Mars Orbiter Camera - Wide Angle
- Mars Orbiter Camera Wide Angle
- Near Infrared Mapping Spectrometer
- Mars Pathfinder
- Alpha X-Ray Spectrometer
- Alpha X-Ray Spectrometer (Apxs)
- Atmospheric Structure Instrument / Meteorology Package
- Imager For Mars Pathfinder
- Rover Camera Left
- Mars Science Laboratory
- Front Hazard Avoidance Camera Left String B
- Mars Descent Imager Camera
- Mars Hand Lens Imager Camera
- Mast Camera Left
- Navigation Camera Left String A
- Phoenix
- Optical Microscope
- Robotic Arm Camera
- Surface Stereo Imager
- Viking Lander
- Camera_1
- Camera_2
- Viking Orbiter
- Viking Visual Imaging Subsystem
- Visual_Imaging_Subsystem_Camera_A, Visual_Imaging_Subsystem_Camera_B
- Voyager
- Imaging Science Subsystem
- Imaging Science Subsystem - Narrow Angle Camera