110 likes | 121 Views
Explore the Frames Kernel, which establishes relationships between reference frames, allowing SPICE software to compute frame transformations. Learn about frame classes, specifications, and important points to know.
E N D
Frames KernelFK June 2004
Introduction What does the FRAMES subsystem do? • It establishes relationships between reference frames used in geometry computations -- it "chains frames together." • It connects frames with sources of their orientation specifications. • Based on this relationship and orientation source information, it allows SPICE software to compute transformations between neighboring frames in the "chain," and to combine these transformations in the right order, thus providing an ability to compute orientation of any frame in the chain with respect to any other frame in the chain at any time. (*) (*) If the complete set of underlying SPICE data need to compute the transformation is available. Frames Kernel
Sample Frame Tree and Chains Frames Kernel
Frame Classes • Examples • Earth Equator/Equinox of Epoch (J2000, …) • Planet Equator/Equinox of Epoch (MARSIAU, ...) • Star Catalog (FK4, ...) • Ecliptic of Epoch (ECLIPJ2000, ...) • Solar system body IAU frames (IAU_SATURN, …) • High precision Earth frames (ITRF93, …) • Spacecraft (CASSINI_SC_BUS, …) • Platform (MGS_NADIR_DECK, …) • Moving parts of an instrument (MPL_RA_JOINT1, ...) • Instrument mounting alignment (CASSINI_ISS_NAC, …) • Topocentric (DSS-14_TOPO, …) Frame class Inertial Body-fixed CK-based Fixed Offset Frames Kernel
Frames Class Specifications Frame class Frame Defined in Orientation provided in Inertial SPICELIB/CSPICE/Icy SPICELIB/CSPICE/Icy Bodyfixed SPICELIB/CSPICE/Icy PCK CK based FK CK Fixed offset FK FK and FK Frames Kernel
FRAMES Subsystem Interfaces SXFORM/PXFORM returns state or position transformation matrix CALL SXFORM ( ‘FROM_FRAME_NAME’, ‘TO_FRAME_NAME’, ET, MAT6x6 ) CALL PXFORM ( ‘FROM_FRAME_NAME’, ‘TO_FRAME_NAME’, ET, MAT3X3 ) SPKEZR/SPKPOS returns state or position vector in specified frame CALL SPKEZR ( BOD, ET, ‘FRAME_NAME’, CORR, OBS, STATE, LT ) CALL SPKPOS ( BOD, ET, ‘FRAME_NAME’, CORR, OBS, POSITN, LT ) The above are FORTRAN examples, using SPICELIB modules. The same interfaces exist for C, using CSPICE modules, and for Icy. Frames Kernel
CK-Based Frames “Must Know” These are VERY IMPORTANT points you must understand! • The frames routines (SPKEZR/SPKEZ, SPKPOS, SXFORM, PXFORM) all read CK files using tolerance = 0 • For discrete CKs the orientation of a CK-based frame will be computed only if the time provided to a Frames routine exactly matches one of the times stored in the CK file; otherwise an error will be signaled. • For continuous CKs the orientation of a CK-based frame will be computed only if the time provided to a Frames routine falls within one of the interpolation intervals defined by the CK file; otherwise an error will be signaled. • Using SPKEZR or SXFORM requires CKs with angular rates • Since these routines return a state vector (1x6) or state transformation matrix (6x6), angular rates must be present in the CK in order to compute vectors and matrixes; if rates are not present, an error will be signaled. • SPKPOS and PXFORM, which return a position vector (1x3) and a position transformation matrix (3x3) respectively, can be used instead because they require only orientation data to be present in the CK. • Ephemeris time input to Frames routines is converted to SCLK to access CKs • SCLK and LSK kernels must be loaded to support this conversion. • SCLK ID is specified in one of the CK frame definition keywords; if not, it’s assumed to be the Frame ID divided by a 1000. Frames Kernel
What are the Names of Frames? • Refer to FRAMES.REQ for the list of NAIF “built in” (hard coded) inertial and body-fixed frames • Refer to a project’s Frames Kernel (FK) file for a list of frames defined for the spacecraft, its subsystems and instruments • Refer to an earth stations FK for a list of frames defined for the DSN and other stations Frames Kernel
Frames Kernel File • Uses the SPICE text kernel file standards • Loaded using the FURNSH routine • Usually contains comprehensive information about the defined frames in the text section(s) of the file • Contains frame definition information consisting of a set of keywords in the data sections of the file. For example, the frame for the scanner assembly frame of the ASPERA instrument on the Mars Express spacecraft is defined thusly: \begindata FRAME_MEX_ASPERA_SAF = -41111 FRAME_-41111_NAME = 'MEX_ASPERA_SAF' FRAME_-41111_CLASS = 3 FRAME_-41111_CLASS_ID = -41111 FRAME_-41111_CENTER = -41 CK_-41111_SCLK = -41 CK_-41111_SPK = -41 \begintext Frames Kernel
Frame Definition - Important Details • Frame ID is an integer number used by the SPICE system as a “handle” in buffering and retrieving various parameters associated with a frame. In an FK it “glues” together the keywords defining the frame. • The frame CLASS_ID is the number that connects a frame with the orientation data for it • For body-fixed frames CLASS_ID is the ID of the natural body. It is used as input to PCK routines called by the Frame subsystem to compute orientation of the frame. • Frame ID and CLASS_ID are not the same for the body-fixed frames defined in the Toolkit but they can be the same for the frames defined in the FK files • For CK-based frames CLASS_ID is the CK structure ID. It is used as input to CK routines called by the Frame subsystem to compute orientation of the frame • Normally CLASS_ID of a CK-based frame is the same as the frame ID • For fixed offset frames CLASS_ID is the ID that is used to retrieve the frame definition keywords containing orientation of the frame. • Normally CLASS_ID of a fixed offset frame is the same as the frame ID Frames Kernel
Frame Tree Example:ASPERA Instrument on Mars Express "J2000" <-inertial | +-----------------------------------------------------+ | | | |<-pck | |<-pck | | | V | V "IAU_MARS" | "IAU_EARTH" MARS BODY-FIXED |<-ck EARTH BODY-FIXED --------------- | ---------------- V "MEX_SPACECRAFT" +-----------------------------------------------------+ | | |<-fixed |<-fixed | | V V "MEX_ASPERA_URF" "MEX_ASPERA_IMA_URF" ----------------- -------------------- | | |<-ck |<-fixed | | V V "MEX_ASPERA_SAF” “MEX_ASPERA_IMA” --------------------------------------------- ... ---------------- | | | |<-fixed |<-fixed |<-fixed | | | V V V "MEX_ASPERA_ELS" "MEX_ASPERA_NPI" "MEX_ASPERA_NPD1" ---------------- ---------------- ---------------- Blue text indicates frame class Frames Kernel