FITS Format Overview
FITS format, an acronym for the "Flexible Image Transport System", is a file format designed to hold numeric data and descriptive metadata that can be transported between systems. The format is standardized and maintained by NASA. A FITS format file consists of a data array (pixel data for an image) and a header containing metadata describing the pixel data and providing other documentation about the file. The FITS header and data follow a rigid structure defined in the standard. It is critical to note that FITS format is a file format, not an image format, as other types of data may be encoded in a FITS file
A FITS format image consists of a human readable and printable text format "header" followed by the image pixel data. The header contains image documentation such as number of rows and columns, the data and time the image was taken, etc. The header is comprised of discrete header records that are each 80 bytes long and contain a specific piece of information such as the number of image rows. There must be an integral number of 80 byte header records in a FITS header, and the total header length must be an integral multiple of 36 records, or 2880 bytes. The END keyword line terminates the header and is followed by blank characters that pad the header to a multiple of 2880 bytes. The pixel data begins on the next 2880 byte boundary after the header. The complete file containing the header and pixel data must be padded with blank characters at its end in order to reach a size that is a multiple of 2880 bytes. These 2880 byte intervals are necessary for storing a FITS image on a blocked medium such as a magnetic tape. FITS also allows super blocks of multiples of 2880 bytes.
All FITS header characters must be in the range of ASCII codes 32 through 126 (hex 0x20 through 0x7e). Mira automatically scans the header and replaces characters outside this range. Some special replacements include 'd' to replace the degrees symbol, and 'k' to replace the Greek beta character. Other values outside this range are replaced with a tilde '~' character.
Each line of the header is called a header record, and has a length of 80 bytes. In the present documentation, a header record unit is often termed a keyword line. The FITS Standard refers to a header record as a "card image", since FITS was developed when keypunched cards were used for data input.
A header record consists of the following components:
 A
keyword, starting in column 1, that identifies the information
contained in the header record.
    A
keyword, starting in column 1, that identifies the information
contained in the header record.
 A
value, sometimes called the keyword value, beginning in column 10
(see below).
    A
value, sometimes called the keyword value, beginning in column 10
(see below).
 An
optional slash in column 32 that separates the value from an
optional comment (see below).
    An
optional slash in column 32 that separates the value from an
optional comment (see below).
 An
optional comment starting in or after column 33 that describes the
keyword.
    An
optional comment starting in or after column 33 that describes the
keyword.
There are other details such as the range of columns used for specific types of keyword values, but these will not be addressed here. A typical header record looks like the following one:
NAXIS1 = 512 / number of image columns
Beyond the last non-blank character, the remainder of the 80-byte line is padded with blanks (ASCII code 32, or hex 20). The format shown in this NAXIS header record is typical of all FITS keyword lines.
The keyword name, including spaces, is exactly 8 bytes long and is left justified in the 80-byte header record. Except for HISTORY, COMMENT, and <blank> keywords, an equals sign, =, follows in column 9. An optional slash may be placed in column 32. Between columns 10 and 32 is placed the value of the keyword, in this example, the number 512. Notice that the value 512 is right justified with one blank space after. Right justification to column 30 is required for integer, real, and character values, although this detail is sometimes missed by software authors.
Keywords that contain character string data must have a left justified character string enclosed within single quotation marks (') beginning after the ‘=’ sign. The string must also be padded to a minimum length of 8 characters between quotation marks. Character value keywords such as SIMPLE do not use quotation marks, but use a single character such as T (true) or F (false).
A simple header in proper FITS keyword format is listed below.
| SIMPLE = T BITPIX = -32 NAXIS = 1 NAXIS1 = 512 BSCALE = 1.51E002 DATE-OBS= '1999-21-05T05:20:45.005' TIME-OBS= '05:20:45.005' / EXPTIME = 500.0 MIRATYPE= '16 bit unsigned' / OBJECT = 'This string requires quotes' HISTORY This is a string not emclosed in quotes COMMENT This is a string not emclosed in quotes END | 
The NAXIS1 keyword used in the example is an essential FITS keyword because it specifies the image dimension in the direction of the most rapidly varying subscript. The term most rapidly varying subscript is intended for those who write computer programs to read and write FITS format. For a 2-D image, the value of NAXIS1 corresponds to the number of columns in the image, which would be 512 columns in the example. The number of image dimensions is specified using the NAXIS keyword, and this would have a value of either 1 or 2 for MIRA compatible images. If the image has 2 dimensions, there must be an NAXIS2 keyword in the header.
The 4 mandatory keywords for every FITS format image are SIMPLE, BITPIX, NAXIS, and END. A value of NAXIS=0 is allowed. If NAXIS is greater than zero, then the NAXISnnn keywords are also required for a data array of up to nnn dimensions. Following the 80 character line containing the END keyword, the header is padded with blank characters (ASCII 32) to the next multiple of 2880 bytes.
Mira Pro x64 Script User's Guide, v.8.76 Copyright Ⓒ 2024
Mirametrics, Inc. All Rights Reserved.