# DTED Reader for Rust
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="LICENSE"](LICENSE)
[data:image/s3,"s3://crabby-images/66b39/66b3964617509e8be720b3b65d4f01864c358f86" alt="Crates.io Version"](https://crates.io/crates/dted2)
[data:image/s3,"s3://crabby-images/75d4f/75d4f3ad928b4c56b4d17d859ecd5df5cd758050" alt="Minimum rustc version"](#rust-version-requirements-msrv)
Refactor of [`dted`](https://github.com/fizyk20/dted), with updated version of [`nom`](https://crates.io/crates/nom), improved functionality, added features, fixes, and optimizations!
## Usage
```rust ignore
use dted2::{ DTEDData, DTEDMetadata };
let data = DTEDData::read("dted_file.dt2").unwrap();
let metadata: DTEDMetadata = data.metadata;
// or can read just the header without the rest of the data
let metadata: DTEDMetadata = DTEDData::read_header("dted_file.dt2").unwrap();
// query elevation, returns None if out of bounds
let elevation: f64 = data.get_elevation(50.0, 10.0).unwrap();
```
## Description
The `dted2` crate is a Rust library designed to parse and handle [DTED (Digital Terrain Elevation Data)](https://www.dlr.de/de/eoc/Portaldata/60/Resources/dokumente/7_sat_miss/SRTM-XSAR-DEM-DTED-1.1.pdf) files. DTED files are a standard format used for storing raster elevation data, particularly for military and simulation applications. The data in DTED files is stored in a matrix of elevation points, representing the terrain's height above a given datum. This format supports several military and simulation applications including line-of-sight analysis, 3D visualization, and mission planning.
DTED data is organized into three levels of resolution:
* _Level 0_: Approximately 900 meters between data points.
* _Level 1_: Approximately 90 meters between data points.
* _Level 2_: Approximately 30 meters between data points.
Each level of DTED provides different details suitable for various precision requirements in applications.
## Features
* __Data Handling__: Efficient handling of large datasets with options to process only required sections of data for memory management.
* __Read Functionality__: Parse DTED files (`.dt0`, `.dt1`, `.dt2`) into usable data structures. ***Currently only `.dt2` files have been tested. `dt1` and `dt0` files should in theory work.***
## TODO
* __Geographic Processing__: Convert DTED raster data into geographic coordinates based on the WGS84 datum.
* __Additional DTED Header parsing__: Add support for additional header records. Currently both `DSI` and `ACC` records are being worked on, and only the standard `UHL` header is being read alongside the data.