KPL/FK BepiColombo MMO Spacecraft Frames Kernel ============================================================================= This frame kernel contains complete set of frame definitions for the BepiColombo Mercury Magnetospheric Orbiter Spacecraft (MMO) including definitions for the MMO fixed and MMO science instrument frames. This kernel also contains NAIF ID/name mapping for the MMO science instruments and S/C structures (see the last section of the file). Version and Date ----------------------------------------------------------------------------- Version 0.2 -- July 17, 2017 -- Marc Costa Sitja, ESAC/ESA Added MPO_SPIN_AXIS reference frame to implement the science phase nominal attitude. Version 0.1 -- March 1, 2017 -- Marc Costa Sitja, ESAC/ESA Added basic reference frames in order to incorporate HEP-ELE, ENA and MPPE-LEP instrument kernels and to map the MMO reference frames to the MCS/MPO Spacecraft. Version 0.0 -- February 7, 2017 -- Marc Costa Sitja, ESAC/ESA Preliminary Version. Only NAIF IDs for the spacecraft are defined. References ----------------------------------------------------------------------------- 1. ``Frames Required Reading'' 2. ``Kernel Pool Required Reading '' 3. ``C-Kernel Required Reading'' 4. ``HEP-e field-of-view analysis (Feasibility study for Venus flyby)'', Go Murakami (ISAS/JAXA), 5th September 2016 Contact Information ----------------------------------------------------------------------------- If you have any questions regarding this file contact SPICE support at ESAC: Marc Costa Sitja (+34) 91-8131-457 mcosta@sciops.esa.int, esa_spice@sciops.esa.int or NAIF at JPL: Boris Semenov (818) 354-8136 Boris.Semenov@jpl.nasa.gov Implementation Notes ----------------------------------------------------------------------------- This file is used by the SPICE system as follows: programs that make use of this frame kernel must "load" the kernel normally during program initialization. Loading the kernel associates the data items with their names in a data structure called the "kernel pool". The SPICELIB routine FURNSH loads a kernel into the pool as shown below: FORTRAN: (SPICELIB) CALL FURNSH ( frame_kernel_name ) C: (CSPICE) furnsh_c ( frame_kernel_name ); IDL: (ICY) cspice_furnsh, frame_kernel_name MATLAB: (MICE) cspice_furnsh ( 'frame_kernel_name' ) PYTHON: (SPICEYPY)* furnsh( frame_kernel_name ) In order for a program or routine to extract data from the pool, the SPICELIB routines GDPOOL, GIPOOL, and GCPOOL are used. See [2] for more details. This file was created and may be updated with a text editor or word processor. * SPICEPY is a non-official, community developed Python wrapper for the NAIF SPICE toolkit. Its development is managed on Github. It is available at: https://github.com/AndrewAnnex/SpiceyPy BepiColombo MMO Mission NAIF ID Codes ----------------------------------------------------------------------------- The following names and NAIF ID codes are assigned to the MMO spacecraft, its structures and science instruments (the keywords implementing these definitions are located in the section "BepiColombo Mission NAIF ID Codes -- Definition Section" at the end of this file): MMO Spacecraft and Spacecraft Structures names/IDs: MMO -68 (synonyms: BEPICOLOMBO MMO, MERCURY MAGNETOSPHERIC ORBITER) MMO_SPACECRAFT -68000 (synonym: MMO_SC) BepiColombo MMO Mission Frames ----------------------------------------------------------------------------- The following MPO frames are defined in this kernel file: Name Relative to Type NAIF ID ====================== ===================== ============ ========= Spacecraft frames: ------------------ MMO_SPACECRAFT J2000 CK -68000 MMO_SPACECRAFT_CRUISE MMO_SPACECRAFT FIXED -68001 MMO_MMO_SPIN_AXIS MMO_SPACECRAFT CK -68900 MMO_MDM MMO_SPACECRAFT FIXED -68100 MMO_MMO-MGF MMO_SPACECRAFT FIXED -68200 MMO_MPPE_ENA MMO_SPACECRAFT FIXED -68330 MMO_MSASI MMO_SPACECRAFT FIXED -68400 MMO_PWI MMO_SPACECRAFT FIXED -68500 In addition, the following frames, in use by the BepiColombo mission, are defined in other kernels or `built into' the SPICE system: Name Relative to Type NAIF ID ====================== ===================== ============ ========= BepiColombo mission specific science frames (2): ------------------------------------------------ BC_MME_IAU2006_OF_DATE J2000 DYNAMIC -121921 BC_MME_IAU2006_J2000 J2000 FIXED -121922 BC_MME_IAU2009_OF_DATE J2000 DYNAMIC -121923 BC_MME_IAU2009_J2000 J2000 FIXED -121924 (2) These frames are defined in the frame kernel file "bc_sci_vVV.tf" (VV is the version number) SPICE 'Built-in' PCK frames in use by BepiColombo (3): ------------------------------------------------------ IAU_MERCURY J2000 PCK built-in IAU_EARTH J2000 PCK built-in (3) Data for these frames is loaded using either the PCK file "pckVVVVV.tpc" (VVVVV is the version number) BepiColombo MMO Frames Hierarchy -------------------------------------------------------------------------- The diagram below shows the BepiColombo MMO frames hierarchy (except for science operations frames): "J2000" INERTIAL +-----------------------------------------------+ | | | | | |<--pck |<--pck |<--pck | |<--ck | | | | | v | v | v "IAU_EARTH" | "IAU_MERCURY" | "MCS_SPACECRAFT"(**) ----------- | ------------- | ---------------- | | | v | | "IAU_VENUS" | | ----------- | |<--fixed | v | "MMO_SPACECRAFT_CRUISE" | ----------------------- | | |<--ck(*) |<--ck(*) | | v | "MMO_SPACECRAFT" v +---------------------+ . . . . . . . . V Individual instrument frame trees are provided in the other sections of this file (*) In these cases transformation is fixed but it has to be stored in a CK to make SPICE "traverse" appropriate frame tree branch based on the time of interest and/or loaded kernels. (**) There is currently no Frame Definition nor NAIF IDs for the BepiColombo Mercury Composite Spacecraft (MCS) and the frame definition is equivalent to the BepiColombo Mercury Planet Orbiter (MPO) -- MPO_SPACECRAFT. Implementation of Frame Chains for Different Mission Phases ------------------------------------------------------------------------------- Different routes along the branches of the MMO frame hierarchy are implemented for different mission phases depending on the availability of the orientation data and the source, format and type of the data. This subsection summarizes mission phase specific implementations. Cruise ------ "J2000" Inertial ---------------- | | <----------- CK segment containing TLM quaternions, AEM data or | test attitude generated by the BepiColombo SGS and v the ESA SPICE Service "MCS_SPACECRAFT" ---------------- | | <----------- Fixed rotation based on frame definitions | V "MMO_SPACECRAFT_CRUISE" ----------------------- | | <----------- CK segment representing fixed rotation defined | by the MMO design and to make SPICE "transverse" V to the appropiate frame chain "MMO_SPACECRAFT" ---------------- Science Phase ------------- "J2000" Inertial ---------------- | | <----------- CK segment containing TLM quaternions, AEM data or | test attitude generated by the BepiColombo SGS and | the ESA SPICE Service V "MMO_SPACECRAFT" ---------------- MMO Spacecraft and Spacecraft Structures Frames ------------------------------------------------------------------------ This section of the file contains the definitions of the spacecraft and spacecraft structures frames. DISCLAIMER: The origin of the frames specified in the following definitions are not implemented. The ``true'' origin of all frames is in the center of the MMO_SPACECRAFT frame, the center of which is defined by the position given by the SPK (ephemeris) kernel in use. MMO Spacecraft Bus Frame ----------------------------------------------------------------------------- The MMO spacecraft frame -- MMO_SPACECRAFT --, is defined by the S/C design as follows (from [4]): - +Z axis is perpendicular to the MPO-MOSIF separation plane and points to the HGA in deployed configuration; - +X axis is parallel to the MPO-MOSIF separation plane and points to WPT-S1 antenna; - +Y axis completes the right-handed frame and is parallel to the to the MEFISTO antennas; - the origin of this frame is the Mercury Transfer Module/MPO interface point on the separation plane. These diagram(s) illustrate the MMO_SPACECRAFT frame: +Z S/C side (HGA) view: ----------------------- .--------------------. .' '. .' +Ysc '. .' ^ '. .' | '. . | . | | | | | | | | | | o------------> | | +Xsc | | | . . '. .' '. .' '. .' '. .' '--------------------' +Zsc is out of the page. Since the S/C bus attitude with respect to an inertial frame is provided by a C-kernel (see [3] for more information), this frame is defined as a CK-based frame. \begindata FRAME_MMO_SPACECRAFT = -68000 FRAME_-68000_NAME = 'MMO_SPACECRAFT' FRAME_-68000_CLASS = 3 FRAME_-68000_CLASS_ID = -68000 FRAME_-68000_CENTER = -68 CK_-68000_SCLK = -68 CK_-68000_SPK = -68 \begintext MMO Spacecraft Cruise Frame ---------------------------------------------------------------------------- The MMO Spacecraft Cruise frame -- MMO_SPACECRAFT_CRUISE -- is a special frame used in cruise in order to "attach" the MMO spacecraft to the MCS during the cruise phase, it is defined as follows (from [4]): - +Z axis is perpendicular to the MPO-MOSIF separation plane and is anti-parallel to the MCS S/C +Z axis; - +X axis is parallel to the MPO-MOSIF separation plane and points to WPT-S1 antenna; it is rotated -30 degrees with respect to the MCS +X axis around the +Z axis - +Y axis completes the right-handed frame; - the origin of this frame is the Mercury Transfer Module/MPO interface point on the separation plane. This frame is defined a fixed-offset frame. Since the SPICE frames subsystem calls for specifying the reverse transformation--going from the instrument or structure frame to the base frame--as compared to the description given above, the order of rotations assigned to the TKFRAME_*_AXES keyword is also reversed compared to the above text, and the signs associated with the rotation angles assigned to the TKFRAME_*_ANGLES keyword are the opposite from what is written in the above text. \begindata FRAME_MMO_SPACECRAFT_CRUISE = -68001 FRAME_-68001_NAME = 'MMO_SPACECRAFT_CRUISE' FRAME_-68001_CLASS = 4 FRAME_-68001_CLASS_ID = -68001 FRAME_-68001_CENTER = -68 TKFRAME_-68001_RELATIVE = 'MMO_SPACECRAFT' TKFRAME_-68001_SPEC = 'ANGLES' TKFRAME_-68001_UNITS = 'DEGREES' TKFRAME_-68001_AXES = ( 1, 3, 1 ) TKFRAME_-68001_ANGLES = ( 0.0, -30.0, 180.0 ) \begintext MMO Spin Axis Frame ---------------------------------------------------------------------------- The MMO Spin Axis frame -- MMO_SPIN_AXIS -- is a special frame used in the science phase default orientation CK files. In these files the MMO_SPACECRAFT frame orientation is not stored relative to the J2000 frame. Instead it is "decomposed" into two orientations: the nominal spin axis orientation captured in the segments providing the orientation of the MMO_SPIN_AXIS frame relative to the J2000 frame and the nominal rotation about the spin axis captured in the segments providing the orientation of the MMO_SPACECRAFT frame relative to the MMO_SPIN_AXIS frame. MMO_SPIN_AXIS is defined as a CK-based frame. \begindata FRAME_MMO_SPIN_AXIS = -68900 FRAME_-68900_NAME = 'MMO_SPIN_AXIS' FRAME_-68900_CLASS = 3 FRAME_-68900_CLASS_ID = -68900 FRAME_-68900_CENTER = -68 CK_-68900_SCLK = -68 CK_-68900_SPK = -68 \begintext MPPE (Mercury Plasma Particle Experiment) Frames: ------------------------------------------------- This section of the file contains the definitions of the MPPD frames. MPPE Frame Tree: ~~~~~~~~~~~~~~~~ The diagram below shows the MPPE frame hierarchy. [TBW] HEP-ele Frame: ~~~~~~~~~~~~~~ These diagram(s) illustrate the HEP-ele frame: +Z S/C side (HGA) view: ----------------------- .--------------------. .' '. .' +Ysc '. .' ^ '. .' | '. . | . | | | | | | | | | | o------------> | | +Xsc | | | . . '. .' '. .' '. .' '. .' '--------------------' +Zsc is out of the page. Since the SPICE frames subsystem calls for specifying the reverse transformation--going from the instrument or structure frame to the base frame--as compared to the description given above, the order of rotations assigned to the TKFRAME_*_AXES keyword is also reversed compared to the above text, and the signs associated with the rotation angles assigned to the TKFRAME_*_ANGLES keyword are the opposite from what is written in the above text. \begindata FRAME_MMO_MPPE_HEP-ELE = -68330 FRAME_-68330_NAME = 'MMO_MPPE_HEP-ELE' FRAME_-68330_CLASS = 4 FRAME_-68330_CLASS_ID = -68330 FRAME_-68330_CENTER = -68 TKFRAME_-68330_RELATIVE = 'MMO_SPACECRAFT' TKFRAME_-68330_SPEC = 'ANGLES' TKFRAME_-68330_UNITS = 'DEGREES' TKFRAME_-68330_ANGLES = ( 0.0, 180.0, 90.0 ) TKFRAME_-68330_AXES = ( 3, 2, 1 ) \begintext ENA Frame: ~~~~~~~~~~ \begindata FRAME_MMO_MPPE_ENA = -68370 FRAME_-68370_NAME = 'MMO_MPPE_ENA' FRAME_-68370_CLASS = 4 FRAME_-68370_CLASS_ID = -68370 FRAME_-68370_CENTER = -68 TKFRAME_-68370_RELATIVE = 'MMO_SPACECRAFT' TKFRAME_-68370_SPEC = 'ANGLES' TKFRAME_-68370_UNITS = 'DEGREES' TKFRAME_-68370_ANGLES = ( -90.0, 90.0, 0.0 ) TKFRAME_-68370_AXES = ( 1, 2, 3 ) \begintext MPPE-LEP Frame: ~~~~~~~~~~~~~~~ \begindata FRAME_MMO_MPPE-LEP = -68380 FRAME_-68380_NAME = 'MMO_MPPE-LEP' FRAME_-68380_CLASS = 4 FRAME_-68380_CLASS_ID = -68380 FRAME_-68380_CENTER = -68 TKFRAME_-68380_RELATIVE = 'MMO_SPACECRAFT' TKFRAME_-68380_SPEC = 'ANGLES' TKFRAME_-68380_UNITS = 'DEGREES' TKFRAME_-68380_ANGLES = ( 0.0, 00.0, 0.0 ) TKFRAME_-68380_AXES = ( 1, 2, 3 ) \begintext BEPICOLOMBO MPO NAIF ID Codes to Name Mapping ------------------------------------------------------------------------------ This section contains name to NAIF ID mappings for the BepiColombo MPO mission. Once the contents of this file is loaded into the KERNEL POOL, these mappings become available within SPICE, making it possible to use names instead of ID code in the high level SPICE routine calls. Spacecraft: ---------------------------------------------------------------- This table presents the BepiColombo Spacecraft and its main structures' names and --------------------- ------- -------------------------- Name ID Synonyms --------------------- ------- -------------------------- MMO -68 BEPICOLOMBO MMO, MERCURY MAGNETOSPHERIC ORBITER MMO_SPACECRAFT -68000 MMO_SC MMO_SPACECRAFT_CRUISE -68001 ---------------------- ------- -------------------------- Notes: -- 'MMO', 'BEPICOLOMBO MMO' and 'MERCURY MAGNETOSPHERIC ORBITER' are synonyms and all map to the BepiColombo MPO spacecraft ID (-68); -- 'MMO_SC' and 'MMO_SPACECRAFT' are synonyms and all map to the BepiColombo MMO S/C bus structure ID (-68000); \begindata NAIF_BODY_NAME += ( 'MMO' ) NAIF_BODY_CODE += ( -68 ) NAIF_BODY_NAME += ( 'BEPICOLOMBO MMO' ) NAIF_BODY_CODE += ( -68 ) NAIF_BODY_NAME += ( 'MERCURY MAGNETOSPHERIC ORBITER' ) NAIF_BODY_CODE += ( -68 ) NAIF_BODY_NAME += ( 'MMO_SPACECRAFT' ) NAIF_BODY_CODE += ( -68000 ) NAIF_BODY_NAME += ( 'MMO_SC' ) NAIF_BODY_CODE += ( -68000 ) \begintext MPPE: ----- This table summarizes MPPE IDs: ---------------------- -------- Name ID ---------------------- -------- MMO_MPPE -68300 MMO_MPPE_HEP-ELE -68330 MMO_MPPE_HEP-ELE_UPPER -68331 MMO_MPPE_HEP-ELE_LOWER -68332 MMO_MPPE_HEP-ELE-CRUISE -68333 MMO_MPPE_ENA -68370 MMO_MPPE_ENA_CRUISE -68371 MMO_MPPE-LEP -68380 ---------------------- -------- Name-ID Mapping keywords: \begindata NAIF_BODY_NAME += ( 'MMO_MPPE' ) NAIF_BODY_CODE += ( -68300 ) NAIF_BODY_NAME += ( 'MMO_MPPE_HEP-ELE' ) NAIF_BODY_CODE += ( -68330 ) NAIF_BODY_NAME += ( 'MMO_MPPE_HEP-ELE_UPPER' ) NAIF_BODY_CODE += ( -68331 ) NAIF_BODY_NAME += ( 'MMO_MPPE_HEP-ELE_LOWER' ) NAIF_BODY_CODE += ( -68332 ) NAIF_BODY_NAME += ( 'MMO_MPPE_HEP-ELE_CRUISE' ) NAIF_BODY_CODE += ( -68333 ) NAIF_BODY_NAME += ( 'MMO_MPPE_ENA' ) NAIF_BODY_CODE += ( -68370 ) NAIF_BODY_NAME += ( 'MMO_MPPE_ENA_CRUISE' ) NAIF_BODY_CODE += ( -68371 ) NAIF_BODY_NAME += ( 'MMO_MPPE-LEP' ) NAIF_BODY_CODE += ( -68380 ) \begintext End of FK file.