fits-rs

Crates.iofits-rs
lib.rsfits-rs
version0.3.0
sourcesrc
created_at2017-07-20 05:29:05.883774
updated_at2017-08-11 07:38:36.791027
descriptionFITS encoder and decoder in Rust
homepagehttps://github.com/fifth-postulate/fits-rs/wiki
repositoryhttps://github.com/fifth-postulate/fits-rs
max_upload_size
id24235
size10,651,262
Daan van Berkel (dvberkel)

documentation

http://fifth-postulate.nl/fits-rs/

README

fits-rs Build Status Crate

FITS encoder and decoder in Rust.

Make sure to check out the documentation of this crate.

FITS

The Flexible Image Transport System (FITS) is

an open standard defining a digital file format useful for storage, transmission and processing of scientific and other images.

The reference documentation on the FITS standard can be found an NASA's FITS pages. You can get a copy by executing the following command:

wget --output-document=fits-reference.pdf "https://www.aanda.org/articles/aa/pdf/2010/16/aa15362-10.pdf"

Reading Primary Header

Even though the headers of FITS files are in ASCII, you can use this crate to read the primary header.

    let args: Vec<String> = env::args().collect();
    let filename = &args[1];
    let header_index = u64:from_str(&args[2]).expect("should be a non-negative number");

    let mut f = File::open(filename).expect("file not found");
    let mut buffer: Vec<u8> = vec!();
    let _ = f.read_to_end(&mut buffer);

    let result = fits(&buffer);

    match result {
        IResult::Done(_, trappist1) => {
            let header: &Header = if header_index = 0 {
                &trappist1.primary_hdu.header
            } else {
                &trappist1.extensions[header_index].header
            }

            for record in header.keyword_records {
                println!("{:?}", record);
            }
        },
        _ => panic!("Whoops, something went wrong")
    }

You can find this binary in src/bin/headers.rs.

Unfortunately, some extensions are in binary.

Commit count: 148

cargo fmt