selene_drivers — Selene Driver Classes¶
The ale.drivers.selene_drivers module
Added in version 0.8.1.
- class ale.drivers.selene_drivers.KaguyaMiPds3NaifSpiceDriver(file, num_ephem=909, num_quats=909, props={})¶
- Bases: - LineScanner,- Pds3Label,- NaifSpice,- Driver- Driver for a PDS3 Kaguya Multiband Imager (Mi) images. Specifically level2b2 Vis and Nir images. - NOTES¶- Kaguaya has adjusted values for some of its keys, usually suffixed with CORRECTED_. These corrected values should always be preferred over the original values. 
 - property base_band¶
- Which band the bands are registered to. 
 - property boresight_x¶
- Returns the x focal plane coordinate of the boresight. Expects ikid to be defined. This should be the NAIF integer ID for the sensor. - Returns¶- : float
- Boresight focal plane x coordinate 
 
 - property boresight_y¶
- Returns the y focal plane coordinate of the boresight. Expects ikid to be defined. This should be the NAIF integer ID for the sensor. - Returns¶- : float
- Boresight focal plane x coordinate 
 
 - property detector_center_line¶
- Returns the center detector line of the detector. Expects ikid to be defined. This should be the NAIF integer ID code for the sensor. - We subtract 0.5 from the center line because as per the IK: Center of the first pixel is defined as “1.0”. - Returns¶- : int
- The detector line of the principle point 
 
 - property detector_center_sample¶
- Returns the center detector sample of the detector. Expects ikid to be defined. This should be the NAIF integer ID code for the sensor. - We subtract 0.5 from the center sample because as per the IK: Center of the first pixel is defined as “1.0”. - Returns¶- : int
- The detector sample of the principle point 
 
 - property ephemeris_start_time¶
- Returns the ephemeris start time of the image. Expects spacecraft_id to be defined. This should be the integer naif ID code of the spacecraft. - Returns¶- : float
- ephemeris start time of the image 
 
 - property focal2pixel_lines¶
- Calculated using 1/pixel pitch Expects ikid to be defined. This should be the NAIF integer ID code for the sensor. - Returns¶- : list
- focal plane to detector lines 
 
 - property focal2pixel_samples¶
- Calculated using 1/pixel pitch Expects ikid to be defined. This should be the NAIF integer ID code for the sensor. - Returns¶- : list
- focal plane to detector samples 
 
 - property focal_length¶
- Returns camera focal length Expects ikid to be defined. This should be the NAIF ID for the base band. - Returns¶- : float
- Camera focal length 
 
 - property instrument_id¶
- Id takes the form of LISM_<BASE_BAND> where <BASE_BAND> is which band the bands were registered to. - Returns¶- : str
- instrument id 
 
 - property line_exposure_duration¶
- Returns Line Exposure Duration - Kaguya has an unintuitive key for this called CORRECTED_SAMPLING_INTERVAL. The original LINE_EXPOSURE_DURATION PDS3 keys is often incorrect and cannot be trusted. - Returns¶- : float
- Line exposure duration 
 
 - property sensor_frame_id¶
- Returns the sensor frame id. Depends on the instrument that was used to capture the image. - Returns¶- : int
- Sensor frame id 
 
 - property spacecraft_clock_start_count¶
- The original SC_CLOCK_START_COUNT key is often incorrect and cannot be trusted. Therefore we get this information from CORRECTED_SC_CLOCK_START_COUNT - Returns¶- : float
- spacecraft clock start count in seconds 
 
 - property spacecraft_clock_stop_count¶
- The original SC_CLOCK_STOP_COUNT key is often incorrect and cannot be trusted. Therefore we get this information from CORRECTED_SC_CLOCK_STOP_COUNT - Returns¶- : float
- spacecraft clock stop count in seconds 
 
 - property spacecraft_name¶
- Returns “MISSION_NAME” as a proxy for spacecraft_name. - No NAIF code exists for the spacecraft name ‘SELENE-M.’ The NAIF code exists only for ‘SELENE’ or ‘KAGUYA’ – ‘SELENE’ is captured as ‘MISSION_NAME’ - Returns¶- : str
- mission name 
 
 - property usgscsm_distortion_model¶
- Kaguya uses a unique radial distortion model so we need to overwrite the method packing the distortion model into the ISD. - from the IK: - Line-of-sight vector of pixel no. n can be expressed as below. - Distortion coefficients information: INS<INSTID>_DISTORTION_COEF_X = ( a0, a1, a2, a3) INS<INSTID>_DISTORTION_COEF_Y = ( b0, b1, b2, b3), - Distance r from the center: r = - (n - INS<INSTID>_CENTER) * INS<INSTID>_PIXEL_SIZE. - Line-of-sight vector v is calculated as v[X] = INS<INSTID>BORESIGHT[X] + a0 + a1*r + a2*r^2 + a3*r^3 , v[Y] = INS<INSTID>BORESIGHT[Y] + r+a0 + a1*r +a2*r^2 + a3*r^3 , v[Z] = INS<INSTID>BORESIGHT[Z] - Expects odkx and odky to be defined. These should be a list of optical distortion x and y coefficients respectively. - Returns¶- : dict
- radial distortion model 
 
 
- class ale.drivers.selene_drivers.KaguyaTcPds3NaifSpiceDriver(file, num_ephem=909, num_quats=909, props={})¶
- Bases: - LineScanner,- Pds3Label,- NaifSpice,- Driver- Driver for a PDS3 Kaguya Terrain Camera (TC) images. Specifically level2b0 mono and stereo images. - NOTES¶- Kaguaya has adjusted values for some of its keys, usually suffixed with CORRECTED_. These corrected values should always be preffered over the original values. 
- The Kaguya TC doesn’t use a generic Distortion Model, uses on unique to the TC. Therefore, methods normally in the Distortion classes are reimplemented here. 
 - property boresight_x¶
- Returns the x focal plane coordinate of the boresight. Expects ikid to be defined. This should be the NAIF integer ID for the sensor. - Returns¶- : float
- Boresight focal plane x coordinate 
 
 - property boresight_y¶
- Returns the y focal plane coordinate of the boresight. Expects ikid to be defined. This should be the NAIF integer ID for the sensor. - Returns¶- : float
- Boresight focal plane x coordinate 
 
 - property detector_center_line¶
- Returns the center detector line of the detector. Expects tc_id to be defined. This should be a string of the form LISM_TC1 or LISM_TC2. - We subtract 0.5 from the center line because as per the IK: Center of the first pixel is defined as “1.0”. - Returns¶- : int
- The detector line of the principle point 
 
 - property detector_center_sample¶
- Returns the center detector sample of the detector. Expects tc_id to be defined. This should be a string of the form LISM_TC1 or LISM_TC2. - We subtract 0.5 from the center sample because as per the IK: Center of the first pixel is defined as “1.0”. - Returns¶- : int
- The detector sample of the principle point 
 
 - property detector_start_line¶
- Returns¶- : int
- Zero based Detector line corresponding to the first image line 
 
 - property detector_start_sample¶
- Returns starting detector sample - Starting sample varies from swath mode (either FULL, NOMINAL or HALF). - From Kaguya IK kernel: - Sensor - Start Pixel - End Pixel (+dummy) - NAIF ID - LISM_TC1 - 1 - 4096 - -131351 - LISM_TC2 - 1 - 4096 - -131371 - LISM_TC1_WDF (Double DCT Full) - 1 - 4096 - -131352 - LISM_TC1_WTF (Double Through Full) - 1 - 1600 - -131353 - LISM_TC1_SDF (Single DCT Full) - 1 - 4096 - -131354 - LISM_TC1_STF (Single Through Full) - 1 - 3208 - -131355 - LISM_TC1_WDN (Double DCT Nominal) - 297 - 3796(+4) - -131356 - LISM_TC1_WTN (Double Through Nominal) - 297 - 1896 - -131357 - LISM_TC1_SDN (Single DCT Nominal) - 297 - 3796(+4) - -131358 - LISM_TC1_STN (Single Through Nominal) - 297 - 3504 - -131359 - LISM_TC1_WDH (Double DCT Half) - 1172 - 2921(+2) - -131360 - LISM_TC1_WTH (Double Through Half) - 1172 - 2771 - -131361 - LISM_TC1_SDH (Single DCT Half) - 1172 - 2921(+2) - -131362 - LISM_TC1_STH (Single Through Half) - 1172 - 2923 - -131363 - LISM_TC1_SSH (Single SP_support Half) - 1172 - 2921 - -131364 - LISM_TC2_WDF (Double DCT Full) - 1 - 4096 - -131372 - LISM_TC2_WTF (Double Through Full) - 1 - 1600 - -131373 - LISM_TC2_SDF (Single DCT Full) - 1 - 4096 - -131374 - LISM_TC2_STF (Single Through Full) - 1 - 3208 - -131375 - LISM_TC2_WDN (Double DCT Nominal) - 297 - 3796(+4) - -131376 - LISM_TC2_WTN (Double Through Nominal) - 297 - 1896 - -131377 - LISM_TC2_SDN (Single DCT Nominal) - 297 - 3796(+4) - -131378 - LISM_TC2_STN (Single Through Nominal) - 297 - 3504 - -131379 - LISM_TC2_WDH (Double DCT Half) - 1172 - 2921(+2) - -131380 - LISM_TC2_WTH (Double Through Half) - 1172 - 2771 - -131381 - LISM_TC2_SDH (Single DCT Half) - 1172 - 2921(+2) - -131382 - LISM_TC2_STH (Single Through Half) - 1172 - 2923 - -131383 - LISM_TC2_SSH (Single SP_support Half) - 1172 - 2921 - -131384 - Returns¶- : int
- Detector sample corresponding to the first image sample 
 
 - property ephemeris_start_time¶
- Returns the ephemeris start time of the image. Expects spacecraft_id to be defined. This should be the integer naif ID code of the spacecraft. - Returns¶- : float
- ephemeris start time of the image 
 
 - property exposure_duration¶
- Returns Line Exposure Duration - Kaguya TC has an unintuitive key for this called CORRECTED_SAMPLING_INTERVAL. The original LINE_EXPOSURE_DURATION PDS3 keys is often incorrect and cannot be trusted. - Returns¶- : float
- Line exposure duration 
 
 - property focal2pixel_lines¶
- Calculated using 1/pixel pitch Expects tc_id to be defined. This should be a string of the form LISM_TC1 or LISM_TC2. - Returns¶- : list
- focal plane to detector lines 
 
 - property focal2pixel_samples¶
- Calculated using 1/pixel pitch Expects tc_id to be defined. This should be a string of the form LISM_TC1 or LISM_TC2. - Returns¶- : list
- focal plane to detector samples 
 
 - property focal_length¶
- Returns camera focal length Expects tc_id to be defined. This should be a string of the form LISM_TC1 or LISM_TC2. - Returns¶- : float
- Camera focal length 
 
 - property ikid¶
- Returns ikid of LISM_TC1 or LISM_TC2, depending which camera was used for capturing the image. - Some keys are stored in the IK kernel under a general ikid for TC1/TC2 presumably because they are not affected by the addtional parameters encoded in the ikid returned by self.ikid. This method exists for those gdpool calls. - Expects instrument_id to be defined in the Pds3Label mixin. This should be a string containing either TC1 or TC2 - Returns¶- : int
- ikid of LISM_TC1 or LISM_TC2 
 
 - property instrument_host_name¶
- Returns the name of the instrument host. Kaguya/SELENE labels do not have an explicit instrument host name in the pvl, so we use the spacecraft name. - Returns¶- : str
- Spacecraft name as a proxy for instrument host name. 
 
 - property instrument_id¶
- Id takes the form of LISM_<INSTRUMENT_ID>_<SD><COMPRESS><SWATH> where - INSTRUMENT_ID = TC1/TC2 SD = S/D short for single or double, which in turn means whether the label belongs to a mono or stereo image. - COMPRESS = D/T short for DCT or through, we assume image has been decompressed already - SWATCH = swatch mode, different swatch modes have different FOVs - Returns¶- : str
- instrument id 
 
 - property sensor_frame_id¶
- Returns the sensor frame id. Depends on the instrument that was used to capture the image. - Returns¶- : int
- Sensor frame id 
 
 - property spacecraft_clock_start_count¶
- The original SC_CLOCK_START_COUNT key is often incorrect and cannot be trusted. Therefore we get this information from CORRECTED_SC_CLOCK_START_COUNT - Returns¶- : float
- spacecraft clock start count in seconds 
 
 - property spacecraft_clock_stop_count¶
- The original SC_CLOCK_STOP_COUNT key is often incorrect and cannot be trusted. Therefore we get this information from CORRECTED_SC_CLOCK_STOP_COUNT - Returns¶- : float
- spacecraft clock stop count in seconds 
 
 - property spacecraft_direction¶
- Gets the moving direction of the spacecraft from the label, where -1 is moving as intended and 1 is moving inverted. - Returns¶- : int
- Moving direction of the spacecraft 
 
 - property spacecraft_name¶
- Returns “MISSION_NAME” as a proxy for spacecraft_name. - No NAIF code exists for the spacecraft name ‘SELENE-M.’ The NAIF code exists only for ‘SELENE’ or ‘KAGUYA’ – ‘SELENE’ is captured as ‘MISSION_NAME’ - Returns¶- : str
- mission name 
 
 - property usgscsm_distortion_model¶
- Kaguya uses a unique radial distortion model so we need to overwrite the method packing the distortion model into the ISD. - from the IK: - Line-of-sight vector of pixel no. n can be expressed as below. - Distortion coefficients information: INS<INSTID>_DISTORTION_COEF_X = ( a0, a1, a2, a3) INS<INSTID>_DISTORTION_COEF_Y = ( b0, b1, b2, b3), - Distance r from the center: r = - (n - INS<INSTID>_CENTER) * INS<INSTID>_PIXEL_SIZE. - Line-of-sight vector v is calculated as v[X] = INS<INSTID>BORESIGHT[X] + a0 + a1*r + a2*r^2 + a3*r^3 , v[Y] = INS<INSTID>BORESIGHT[Y] + r+a0 + a1*r +a2*r^2 + a3*r^3 , v[Z] = INS<INSTID>BORESIGHT[Z] - Expects odkx and odky to be defined. These should be a list of optical distortion x and y coefficients respectively. - Returns¶- : dict
- radial distortion model 
 
 
 
          