All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nom.tam.fits.header.Standard Maven / Gradle / Ivy

package nom.tam.fits.header;

import nom.tam.fits.AsciiTable;
import nom.tam.fits.BinaryTable;
import nom.tam.fits.ImageData;
import nom.tam.fits.RandomGroupsData;
import nom.tam.fits.TableData;
import nom.tam.fits.UndefinedData;

/*
 * #%L
 * nom.tam FITS library
 * %%
 * Copyright (C) 1996 - 2024 nom-tam-fits
 * %%
 * This is free and unencumbered software released into the public domain.
 *
 * Anyone is free to copy, modify, publish, use, compile, sell, or
 * distribute this software, either in source code form or as a compiled
 * binary, for any purpose, commercial or non-commercial, and by any
 * means.
 *
 * In jurisdictions that recognize copyright laws, the author or authors
 * of this software dedicate any and all copyright interest in the
 * software to the public domain. We make this dedication for the benefit
 * of the public at large and to the detriment of our heirs and
 * successors. We intend this dedication to be an overt act of
 * relinquishment in perpetuity of all present and future rights to this
 * software under copyright law.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 * #L%
 */

/**
 * 

* This data dictionary lists the 53 keywords currently defined in the FITS Standard. *

*

* See http://heasarc.gsfc.nasa.gov/docs/fcg/standard_dict.html *

* * @author Richard van Nieuwenhoven */ @SuppressWarnings("deprecation") public enum Standard implements IFitsHeader { /** * The value field shall contain a character string identifying who compiled the information in the data associated * with the key. This keyword is appropriate when the data originate in a published paper or are compiled from many * sources. */ AUTHOR(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "author name(s)"), /** * The value field shall contain an integer. The absolute value is used in computing the sizes of data structures. * It shall specify the number of bits that represent a data value. RANGE: -64,-32,8,16,32 * * @see Bitpix */ BITPIX(SOURCE.MANDATORY, HDU.ANY, VALUE.INTEGER, "bits per data element", // replaceable("header:bitpix", Object.class) // ), /** * This keyword shall be used only in primary array headers or IMAGE extension headers with positive values of * BITPIX (i.e., in arrays with integer data). Columns 1-8 contain the string, `BLANK ' (ASCII blanks in columns * 6-8). The value field shall contain an integer that specifies the representation of array values whose physical * values are undefined. */ BLANK(SOURCE.RESERVED, HDU.IMAGE, VALUE.INTEGER, "value used for undefined array elements"), /** * Columns 1-8 contain ASCII blanks. This keyword has no associated value. Columns 9-80 may contain any ASCII text. * Any number of card images with blank keyword fields may appear in a key. */ BLANKS("", SOURCE.RESERVED, HDU.ANY, VALUE.NONE, null), /** * This keyword may be used only in the primary key. It shall appear within the first 36 card images of the FITS * file. (Note: This keyword thus cannot appear if NAXIS is greater than 31, or if NAXIS is greater than 30 and the * EXTEND keyword is present.) Its presence with the required logical value of T advises that the physical block * size of the FITS file on which it appears may be an integral multiple of the logical record length, and not * necessarily equal to it. Physical block size and logical record length may be equal even if this keyword is * present or unequal if it is absent. It is reserved primarily to prevent its use with other meanings. Since the * issuance of version 1 of the standard, the BLOCKED keyword has been deprecated. * * @deprecated no blocksize other that 2880 may be used. */ @Deprecated BLOCKED(SOURCE.RESERVED, HDU.PRIMARY, VALUE.LOGICAL, "Non-standard FITS block size"), /** * This keyword shall be used, along with the BZERO keyword, when the array pixel values are not the true physical * values, to transform the primary data array values to the true physical values they represent, using the * equation: physical_value = BZERO + BSCALE * array_value. The value field shall contain a floating point number * representing the coefficient of the linear term in the scaling equation, the ratio of physical value to array * value at zero offset. The default value for this keyword is 1.0. */ BSCALE(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "data quantization scaling"), /** * The value field shall contain a character string, describing the physical units in which the quantities in the * array, after application of BSCALE and BZERO, are expressed. The units of all FITS key keyword values, with the * exception of measurements of angles, should conform with the recommendations in the IAU Style Manual. For angular * measurements given as floating point values and specified with reserved keywords, degrees are the recommended * units (with the units, if specified, given as 'deg'). */ BUNIT(SOURCE.RESERVED, HDU.IMAGE, VALUE.STRING, "data physical unit"), /** * This keyword shall be used, along with the BSCALE keyword, when the array pixel values are not the true physical * values, to transform the primary data array values to the true values using the equation: physical_value = BZERO * + BSCALE * array_value. The value field shall contain a floating point number representing the physical value * corresponding to an array value of zero. The default value for this keyword is 0.0. */ BZERO(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "data quantization offset"), /** * The value field shall contain a floating point number giving the partial derivative of the coordinate specified * by the CTYPEn keywords with respect to the pixel index, evaluated at the reference point CRPIXn, in units of the * coordinate specified by the CTYPEn keyword. These units must follow the prescriptions of section 5.3 of the FITS * Standard. * * @see WCS#CDELTna */ CDELTn(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "coordinate spacing along axis"), /** * This keyword shall have no associated value; columns 9-80 may contain any ASCII text. Any number of COMMENT card * images may appear in a key. */ COMMENT(SOURCE.RESERVED, HDU.ANY, VALUE.NONE, null), /** * The CONTINUE keyword, when followed by spaces in columns 9 and 10 of the card image and a character string * enclosed in single quotes starting in column 11 or higher, indicates that the quoted string should be treated as * a continuation of the character string value in the previous key keyword. To conform to this convention, the * character string value on the previous keyword must end with the ampersand character ('&'), but the ampersand * is not part of the value string and should be deleted before concatenating the strings together. The character * string value may be continued on any number of consecutive CONTINUE keywords, thus effectively allowing * arbitrarily long strings to be written as keyword values. */ CONTINUE(SOURCE.RESERVED, HDU.ANY, VALUE.NONE, null), /** * This keyword is used to indicate a rotation from a standard coordinate system described by the CTYPEn to a * different coordinate system in which the values in the array are actually expressed. Rules for such rotations are * not further specified in the Standard; the rotation should be explained in comments. The value field shall * contain a floating point number giving the rotation angle in degrees between axis n and the direction implied by * the coordinate system defined by CTYPEn. In unit degrees. */ CROTAn(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "[deg] coordinate axis rotation angle"), /** * The value field shall contain a floating point number, identifying the location of a reference point along axis * n, in units of the axis index. This value is based upon a counter that runs from 1 to NAXISn with an increment of * 1 per pixel. The reference point value need not be that for the center of a pixel nor lie within the actual data * array. Use comments to indicate the location of the index point relative to the pixel. * * @see WCS#CRPIXna */ CRPIXn(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "coordinate axis reference pixel"), /** * The value field shall contain a floating point number, giving the value of the coordinate specified by the CTYPEn * keyword at the reference point CRPIXn. Units must follow the prescriptions of section 5.3 of the FITS Standard. * * @see WCS#CRVALna */ CRVALn(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "coordinate axis value at reference pixel"), /** * The value field shall contain a character string, giving the name of the coordinate represented by axis n. * * @see WCS#CTYPEna */ CTYPEn(SOURCE.RESERVED, HDU.IMAGE, VALUE.STRING, "coordinate axis type / name"), /** * The value field shall always contain a floating point number, regardless of the value of BITPIX. This number * shall give the maximum valid physical value represented by the array, exclusive of any special values. */ DATAMAX(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "maximum data value"), /** * The value field shall always contain a floating point number, regardless of the value of BITPIX. This number * shall give the minimum valid physical value represented by the array, exclusive of any special values. */ DATAMIN(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "minimum data value"), /** * The date on which the HDU was created, in the format specified in the FITS Standard. The old date format was * 'yy/mm/dd' and may be used only for dates from 1900 through 1999. the new Y2K compliant date format is * 'yyyy-mm-dd' or 'yyyy-mm-ddTHH:MM:SS[.sss]'. * * @see DateTime#DATE */ DATE(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "date of file creation"), /** * The date of the observation, in the format specified in the FITS Standard. The old date format was 'yy/mm/dd' and * may be used only for dates from 1900 through 1999. The new Y2K compliant date format is 'yyyy-mm-dd' or * 'yyyy-mm-ddTHH:MM:SS[.sss]'. * * @see DateTime#DATE_OBS */ DATE_OBS("DATE-OBS", SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "date of the observation"), /** * This keyword has no associated value. Columns 9-80 shall be filled with ASCII blanks. */ END(SOURCE.MANDATORY, HDU.ANY, VALUE.NONE, null), /** * The value field shall contain a floating point number giving the equinox in years for the celestial coordinate * system in which positions are expressed. Starting with Version 1, the Standard has deprecated the use of the * EPOCH keyword and thus it shall not be used in FITS files created after the adoption of the standard; rather, the * EQUINOX keyword shall be used. * * @deprecated Deprecated by the FITS standard in favor of {@link #EQUINOX}. */ EPOCH(SOURCE.RESERVED, HDU.ANY, VALUE.REAL, "[yr] equinox of celestial coordinate system"), /** * The value field shall contain a floating point number giving the equinox in years for the celestial coordinate * system in which positions are expressed. This version of the keyword does not support alternative coordinate * systems. * * @see WCS#EQUINOXa */ EQUINOX(SOURCE.RESERVED, HDU.ANY, VALUE.REAL, "[yr] equinox of celestial coordinate system"), /** * If the FITS file may contain extensions, a card image with the keyword EXTEND and the value field containing the * logical value T must appear in the primary key immediately after the last NAXISn card image, or, if NAXIS=0, the * NAXIS card image. The presence of this keyword with the value T in the primary key does not require that * extensions be present. */ EXTEND(SOURCE.INTEGRAL, HDU.PRIMARY, VALUE.LOGICAL, "allow extensions"), /** * The value field shall contain an integer, specifying the level in a hierarchy of extension levels of the * extension key containing it. The value shall be 1 for the highest level; levels with a higher value of this * keyword shall be subordinate to levels with a lower value. If the EXTLEVEL keyword is absent, the file should be * treated as if the value were 1. This keyword is used to describe an extension and should not appear in the * primary key.RANGE: [1:] DEFAULT: 1 */ EXTLEVEL(SOURCE.RESERVED, HDU.ANY, VALUE.INTEGER, "hierarchical level of the extension"), /** * The value field shall contain a character string, to be used to distinguish among different extensions of the * same type, i.e., with the same value of XTENSION, in a FITS file. This keyword is used to describe an extension * and but may appear in the primary header also. */ EXTNAME(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "HDU name"), /** * The value field shall contain an integer, to be used to distinguish among different extensions in a FITS file * with the same type and name, i.e., the same values for XTENSION and EXTNAME. The values need not start with 1 for * the first extension with a particular value of EXTNAME and need not be in sequence for subsequent values. If the * EXTVER keyword is absent, the file should be treated as if the value were 1. This keyword is used to describe an * extension and should not appear in the primary key.RANGE: [1:] DEFAULT: 1 */ EXTVER(SOURCE.RESERVED, HDU.ANY, VALUE.INTEGER, "HDU version"), /** * The value field shall contain an integer that shall be used in any way appropriate to define the data structure, * consistent with Eq. 5.2 in the FITS Standard. This keyword originated for use in FITS Random Groups where it * specifies the number of random groups present. In most other cases this keyword will have the value 1. */ GCOUNT(SOURCE.MANDATORY, HDU.ANY, VALUE.INTEGER, "group count", replaceable("randomgroupsdata:groups", RandomGroupsData.class), // replaceable("undefineddata:groups", UndefinedData.class), // replaceable("header:groups", RandomGroupsData.class) // ), /** * The value field shall contain the logical constant T. The value T associated with this keyword implies that * random groups records are present. */ GROUPS(SOURCE.MANDATORY, HDU.GROUPS, VALUE.LOGICAL, "random groups data", // replaceable("randomgroupsdata:groups", RandomGroupsData.class) // ), /** * This keyword shall have no associated value; columns 9-80 may contain any ASCII text. The text should contain a * history of steps and procedures associated with the processing of the associated data. Any number of HISTORY card * images may appear in a key. */ HISTORY(SOURCE.RESERVED, HDU.ANY, VALUE.NONE, "processing history of the data"), /** * The value field shall contain a character string identifying the instrument used to acquire the data associated * with the key. */ INSTRUME(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "name of instrument"), /** * The value field shall contain a non-negative integer no greater than 999, representing the number of axes in the * associated data array. A value of zero signifies that no data follow the key in the HDU. In the context of FITS * 'TABLE' or 'BINTABLE' extensions, the value of NAXIS is always 2.RANGE: [0:999] */ NAXIS(SOURCE.MANDATORY, HDU.ANY, VALUE.INTEGER, "dimensionality of data"), /** * The value field of this indexed keyword shall contain a non-negative integer, representing the number of elements * along axis n of a data array. The NAXISn must be present for all values n = 1,...,NAXIS, and for no other values * of n. A value of zero for any of the NAXISn signifies that no data follow the key in the HDU. If NAXIS is equal * to 0, there should not be any NAXISn keywords.RANGE: [0:] */ NAXISn(SOURCE.MANDATORY, HDU.ANY, VALUE.INTEGER, "n'th data dimension", // replaceable("tablehdu:naxis1", TableData.class, "Size of table row in bytes"), // replaceable("tablehdu:naxis2", TableData.class, "Number of table rows"), replaceable("header:naxis2", Object.class)), /** * The value field shall contain a character string giving a name for the object observed. */ OBJECT(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "name of observed object"), /** * The value field shall contain a character string identifying who acquired the data associated with the key. */ OBSERVER(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "observer(s) who acquired the data"), /** * The value field shall contain a character string identifying the organization or institution responsible for * creating the FITS file. */ ORIGIN(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "organization responsible for the data"), /** * The value field shall contain an integer that shall be used in any way appropriate to define the data structure, * consistent with Eq. 5.2 in the FITS Standard. This keyword was originated for use with FITS Random Groups and * represented the number of parameters preceding each group. It has since been used in 'BINTABLE' extensions to * represent the size of the data heap following the main data table. In most other cases its value will be zero. */ PCOUNT(SOURCE.MANDATORY, HDU.ANY, VALUE.INTEGER, "associated parameter count", // replaceable("binarytable:pcount", TableData.class, "heap size in bytes"), replaceable("randomgroups:pcount", RandomGroupsData.class, "parameter values per group"), replaceable("undefineddata:pcount", UndefinedData.class), replaceable("header:pcount", Object.class)), /** * This keyword is reserved for use within the FITS Random Groups structure. This keyword shall be used, along with * the PZEROn keyword, when the nth FITS group parameter value is not the true physical value, to transform the * group parameter value to the true physical values it represents, using the equation, physical_value = PZEROn + * PSCALn * group_parameter_value. The value field shall contain a floating point number representing the * coefficient of the linear term, the scaling factor between true values and group parameter values at zero offset. * The default value for this keyword is 1.0. */ PSCALn(SOURCE.INTEGRAL, HDU.GROUPS, VALUE.REAL, "parameter quantization scaling"), /** * This keyword is reserved for use within the FITS Random Groups structure. The value field shall contain a * character string giving the name of parameter n. If the PTYPEn keywords for more than one value of n have the * same associated name in the value field, then the data value for the parameter of that name is to be obtained by * adding the derived data values of the corresponding parameters. This rule provides a mechanism by which a random * parameter may have more precision than the accompanying data array elements; for example, by summing two 16-bit * values with the first scaled relative to the other such that the sum forms a number of up to 32-bit precision. */ PTYPEn(SOURCE.INTEGRAL, HDU.GROUPS, VALUE.STRING, "name of random groups parameter"), /** * This keyword is reserved for use within the FITS Random Groups structure. This keyword shall be used, along with * the PSCALn keyword, when the nth FITS group parameter value is not the true physical value, to transform the * group parameter value to the physical value. The value field shall contain a floating point number, representing * the true value corresponding to a group parameter value of zero. The default value for this keyword is 0.0. The * transformation equation is as follows: physical_value = PZEROn + PSCALn * group_parameter_value.DEFAULT: 0.0 */ PZEROn(SOURCE.INTEGRAL, HDU.GROUPS, VALUE.REAL, "parameter quantization offset"), /** * Coordinate reference frame of major/minor axes.If absent the default value is 'FK5'. This version of the keyword * does not support alternative coordinate systems. * * @see WCS#RADESYSa */ RADESYS(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "celestial coordinate reference frame"), /** * Coordinate reference frame of major/minor axes (generic). * * @deprecated Deprecated in the current FITS satndard, use {@link #RADESYS} instead. */ RADECSYS(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "celestial coordinate reference frame"), /** * [Hz] Rest frequency of observed spectral line. * * @since 1.19 * * @see WCS#RESTFRQa */ RESTFRQ(SOURCE.RESERVED, HDU.IMAGE, VALUE.REAL, "[Hz] line rest frequency"), /** * [Hz] Rest frequeny of observed spectral line (generic). * * @deprecated Deprecated in the current FITS standard, use {@link #RESTFRQ} instead. */ RESTFREQ(SOURCE.RESERVED, HDU.ANY, VALUE.REAL, "[Hz] observed line rest frequency"), /** * The value field shall contain a character string citing a reference where the data associated with the key are * published. */ REFERENC(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "bibliographic reference"), /** * The SIMPLE keyword is required to be the first keyword in the primary key of all FITS files. The value field * shall contain a logical constant with the value T if the file conforms to the standard. This keyword is mandatory * for the primary key and is not permitted in extension headers. A value of F signifies that the file does not * conform to this standard. */ SIMPLE(SOURCE.MANDATORY, HDU.PRIMARY, VALUE.LOGICAL, "primary HDU", // replaceable("header:simple", Object.class, "Java FITS: " + new java.util.Date()) // ), /** * The value field of this indexed keyword shall contain an integer specifying the column in which field n starts in * an ASCII TABLE extension. The first column of a row is numbered 1.RANGE: [1:] */ TBCOLn(SOURCE.MANDATORY, HDU.ASCII_TABLE, VALUE.INTEGER, "column byte offset", // replaceable("asciitable:tbcolN", AsciiTable.class) // ), /** * The value field of this indexed keyword shall contain a character string describing how to interpret the contents * of field n as a multidimensional array, providing the number of dimensions and the length along each axis. The * form of the value is not further specified by the Standard. A proposed convention is described in Appendix B.2 of * the FITS Standard in which the value string has the format '(l,m,n...)' where l, m, n,... are the dimensions of * the array. */ TDIMn(SOURCE.RESERVED, HDU.BINTABLE, VALUE.STRING, "dimensionality of column array elements", // replaceable("binarytable:tdimN", BinaryTable.class) // ), /** * The value field of this indexed keyword shall contain a character string describing the format recommended for * the display of the contents of field n. If the table value has been scaled, the physical value shall be * displayed. All elements in a field shall be displayed with a single, repeated format. For purposes of display, * each byte of bit (type X) and byte (type B) arrays is treated as an unsigned integer. Arrays of type A may be * terminated with a zero byte. Only the format codes in Table 8.6, discussed in section 8.3.4 of the FITS Standard, * are permitted for encoding. The format codes must be specified in upper case. If the Bw.m, Ow.m, and Zw.m formats * are not readily available to the reader, the Iw.m display format may be used instead, and if the ENw.d and ESw.d * formats are not available, Ew.d may be used. The meaning of this keyword is not defined for fields of type P in * the Standard but may be defined in conventions using such fields. */ TDISPn(SOURCE.RESERVED, HDU.TABLE, VALUE.STRING, "column display format"), /** * The value field shall contain a character string identifying the telescope used to acquire the data associated * with the key. */ TELESCOP(SOURCE.RESERVED, HDU.ANY, VALUE.STRING, "name of telescope / observatory"), /** * The value field shall contain a non-negative integer representing the number of fields in each row of a 'TABLE' * or 'BINTABLE' extension. The maximum permissible value is 999. RANGE: [0:999] */ TFIELDS(SOURCE.MANDATORY, HDU.TABLE, VALUE.INTEGER, "number of columns in the table"), /** * The value field of this indexed keyword shall contain a character string describing the format in which field n * is encoded in a 'TABLE' or 'BINTABLE' extension. */ TFORMn(SOURCE.MANDATORY, HDU.TABLE, VALUE.STRING, "column data format", // replaceable("asciitable:tformN", AsciiTable.class), // replaceable("binarytable:tformN", BinaryTable.class) // ), /** * The value field of this keyword shall contain an integer providing the separation, in bytes, between the start of * the main data table and the start of a supplemental data area called the heap. The default value shall be the * product of the values of NAXIS1 and NAXIS2. This keyword shall not be used if the value of PCOUNT is zero. A * proposed application of this keyword is presented in Appendix B.1 of the FITS Standard. */ THEAP(SOURCE.INTEGRAL, HDU.BINTABLE, VALUE.INTEGER, "heap byte offset", // replaceable("binarytable:theap", BinaryTable.class) // ), /** * In ASCII 'TABLE' extensions, the value field for this indexed keyword shall contain the character string that * represents an undefined value for field n. The string is implicitly blank filled to the width of the field. In * binary 'BINTABLE' table extensions, the value field for this indexed keyword shall contain the integer that * represents an undefined value for field n of data type B, I, or J. The keyword may not be used in 'BINTABLE' * extensions if field n is of any other data type. */ TNULLn(SOURCE.INTEGRAL, HDU.TABLE, VALUE.ANY, "column value for undefined elements"), /** * This indexed keyword shall be used, along with the TZEROn keyword, when the quantity in field n does not * represent a true physical quantity. The value field shall contain a floating point number representing the * coefficient of the linear term in the equation, physical_value = TZEROn + TSCALn * field_value, which must be * used to compute the true physical value of the field, or, in the case of the complex data types C and M, of the * real part of the field with the imaginary part of the scaling factor set to zero. The default value for this * keyword is 1.0. This keyword may not be used if the format of field n is A, L, or X.DEFAULT: 1.0 */ TSCALn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "column quantization scaling"), /** * The value field for this indexed keyword shall contain a character string, giving the name of field n. It is * recommended that only letters, digits, and underscore (hexadecimal code 5F, ('_') be used in the name. String * comparisons with the values of TTYPEn keywords should not be case sensitive. The use of identical names for * different fields should be avoided. */ TTYPEn(SOURCE.RESERVED, HDU.TABLE, VALUE.STRING, "column name"), /** * The value field shall contain a character string describing the physical units in which the quantity in field n, * after any application of TSCALn and TZEROn, is expressed. The units of all FITS key keyword values, with the * exception of measurements of angles, should conform with the recommendations in the IAU Style Manual. For angular * measurements given as floating point values and specified with reserved keywords, degrees are the recommended * units (with the units, if specified, given as 'deg'). */ TUNITn(SOURCE.RESERVED, HDU.TABLE, VALUE.STRING, "column physical unit"), /** * This indexed keyword shall be used, along with the TSCALn keyword, when the quantity in field n does not * represent a true physical quantity. The value field shall contain a floating point number representing the true * physical value corresponding to a value of zero in field n of the FITS file, or, in the case of the complex data * types C and M, in the real part of the field, with the imaginary part set to zero. The default value for this * keyword is 0.0. This keyword may not be used if the format of field n is A, L, or X.DEFAULT: 0.0 */ TZEROn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "column quantization offset"), /** * The value field of this indexed keyword shall contain a floating point number specifying the maximum valid * physical value represented in column n of the table, exclusive of any special values. This keyword may only be * used in 'TABLE' or 'BINTABLE' extensions and is analogous to the DATAMAX keyword used for FITS images. * * @since 1.19 */ TDMAXn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "maximum value in the column"), /** * The value field of this indexed keyword shall contain a floating point number specifying the minimum valid * physical value represented in column n of the table, exclusive of any special values. This keyword may only be * used in 'TABLE' or 'BINTABLE' extensions and is analogous to the DATAMIN keyword used for FITS images. * * @since 1.19 */ TDMINn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "minimum value in the column"), /** * The value field of this indexed keyword shall contain a floating point number specifying the upper bound of the * legal range of physical values that may be represented in column n of the table. The column may contain values * that are greater than this legal maximum value but the interpretation of such values is not defined here. The * value of this keyword is typically used as the maxinum value when constructing a histogram of the values in the * column. This keyword may only be used in 'TABLE' or 'BINTABLE' extensions. * * @since 1.19 */ TLMAXn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "maximum legal value in the column"), /** * The value field of this indexed keyword shall contain a floating point number specifying the lower bound of the * legal range of physical values that may be represented in column n of the table. The column may contain values * that are less than this legal minimum value but the interpretation of such values is not defined here. The value * of this keyword is typically used as the mininum value when constructing a histogram of the values in the column. * This keyword may only be used in 'TABLE' or 'BINTABLE' extensions. * * @since 1.19 */ TLMINn(SOURCE.RESERVED, HDU.TABLE, VALUE.REAL, "minimum legal value in the column"), /** * The value field shall contain a character string giving the name of the extension type. This keyword is mandatory * for an extension key and must not appear in the primary key. For an extension that is not a standard extension, * the type name must not be the same as that of a standard extension. */ XTENSION(SOURCE.MANDATORY, HDU.EXTENSION, VALUE.STRING, "HDU extension type", replaceable("imagedata:xtension", ImageData.class, "image HDU"), // replaceable("binarytable:xtension", BinaryTable.class, "binary table HDU"), // replaceable("asciitable:xtension", AsciiTable.class, "ASCII table HDU"), // replaceable("undefineddata:xtension", UndefinedData.class), // replaceable("header:xtension", Object.class) // ), /** * If set to true, it indicates that the HDU should inherit all non-confliucting keywords from the * primary HDU. * * @since 1.19 */ INHERIT(SOURCE.RESERVED, HDU.EXTENSION, VALUE.LOGICAL, "inherit primary header entries"); private static final ThreadLocal> COMMENT_CONTEXT = new ThreadLocal<>(); /** * A shorthand for {@link #NAXISn}.n(1), that is the regular dimension along the first, fastest FITS * array index (this is the same as the last dimension of Java arrays). */ public static final IFitsHeader NAXIS1 = NAXISn.n(1); /** * A shorthand for {@link #NAXISn}.n(2), that is the regular dimension along the second fastest FITS * array index (this is the same as the one before the last dimension of Java arrays). */ public static final IFitsHeader NAXIS2 = NAXISn.n(2); /** * The value of the XTENSION keword in case of a binary table. */ public static final String XTENSION_ASCIITABLE = "TABLE"; /** * The value of the XTENSION keword in case of a binary table. */ public static final String XTENSION_BINTABLE = "BINTABLE"; /** * The value of the XTENSION keword in case of an image. */ public static final String XTENSION_IMAGE = "IMAGE"; private final StandardCommentReplacement[] commentReplacements; private final FitsKey key; Standard(SOURCE status, HDU hdu, VALUE valueType, String comment, StandardCommentReplacement... replacements) { this(null, status, hdu, valueType, comment, replacements); } Standard(String headerName, SOURCE status, HDU hdu, VALUE valueType, String comment, StandardCommentReplacement... replacements) { key = new FitsKey(headerName == null ? name() : headerName, status, hdu, valueType, comment); commentReplacements = replacements; FitsKey.registerStandard(this); } @Override public final FitsKey impl() { return key; } @Override public String comment() { Class contextClass = COMMENT_CONTEXT.get(); if (contextClass == null) { contextClass = Object.class; } for (StandardCommentReplacement stdCommentReplacement : commentReplacements) { if (stdCommentReplacement.getContext().isAssignableFrom(contextClass)) { if (stdCommentReplacement.getComment() != null) { return stdCommentReplacement.getComment(); } } } return key.comment(); } /** * @deprecated (for internal use) Using {@link nom.tam.fits.HeaderCard#setComment(String)} after * creating a header card with this keyword provides a more transparent way of setting * context-specific comments. This convoluted approach is no longer supported and will be * removed in the future. * * @param clazz Usually a subclass of nom.tam.fits.Data. * * @see nom.tam.fits.HeaderCard#setComment(String) */ public static void context(Class clazz) { COMMENT_CONTEXT.set(clazz); } /** * scan for a comment with the specified reference key. * * @param commentKey the reference key * * @return the comment for the reference key * * @deprecated ()for internal use) */ public String getCommentByKey(String commentKey) { for (StandardCommentReplacement commentReplacement : commentReplacements) { if (commentReplacement.getRef().equals(commentKey)) { String foundcommentReplacement = commentReplacement.getComment(); if (foundcommentReplacement == null) { return comment(); } return foundcommentReplacement; } } return null; } /** * set the comment for the specified reference key. * * @param commentKey the reference key * @param value the comment to set when the fits key is used. * * @deprecated ()for internal use) */ public void setCommentByKey(String commentKey, String value) { for (StandardCommentReplacement commentReplacement : commentReplacements) { if (commentReplacement.getRef().equals(commentKey)) { commentReplacement.setComment(value); return; } } } private static StandardCommentReplacement replaceable(String string, Class clazz) { return new StandardCommentReplacement(string, clazz); } private static StandardCommentReplacement replaceable(String string, Class clazz, String comment) { return new StandardCommentReplacement(string, clazz, comment); } /** * Returns the standard FITS keyword that matches the specified actual key. * * @param key The key as it may appear in a FITS header, e.g. "CTYPE1A" * * @return The standard FITS keyword/pattern that matches, e.g. {@link WCS#CTYPEna}. * * @see IFitsHeader#extractIndices(String) * * @since 1.19 */ public static IFitsHeader match(String key) { return FitsKey.matchStandard(key); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy