#propagation #calculations #set #tle #sgp4 #modular #sdp4

bin+lib satellite

Modular set of functions for SGP4 and SDP4 propagation of TLEs

3 releases

new 0.1.2 Sep 14, 2024
0.1.1 Sep 4, 2024
0.1.0 Aug 19, 2024

#127 in Geospatial

Download history 158/week @ 2024-08-19 132/week @ 2024-09-02

290 downloads per month

MIT license

1.5MB
3K SLoC

Satellite-pro ⚡️

Support WebAssembly Crates.io License Static Badge Crates.io Total Downloads

A high-performance library for satellite propagation using TLEs and powered by Rust, inspired by satellite-js. Provides the functions necessary for SGP4/SDP4 calculations. Also provides functions for coordinate transforms.

This library's is a superset of satellite-js。Its API is almost identical to that of satellite.js, and due to the use of Rust and WASM, its performance is several times faster.

Speed

🚧 Work in Progress

Ideally, this library should be faster than satellite.js, but currently, not all APIs are meeting the expected speed, and improvements are needed.

Installation

npm

Attention: The package name is satellite-pro, which is different from the original package name.

npm install satellite-pro --save

Rust

[dependencies]
satellite = "0.1"

Usage

JS

import * as satellite from "satellite-pro";

const tleLine1 = "1 44714C 19074B   24257.74770833  .00012054  00000+0  80755-3 0  2576",
const tleLine2 = "2 44714  53.0541  99.4927 0001373  86.0479  80.2511 15.06391223    18";

const satrec = satellite.twoline2satrec(tleLine1, tleLine2);
const _position_and_velocity = satellite.propagate(satrec, 2024, 9, 22, 12, 12, 12, 0);

⚠️:Your project should support webAssembly.

If you are using Vite as your build tool, you can follow the steps below.

npm install vite-plugin-wasm vite-plugin-top-level-await --save-dev

vite.config.js

import wasm from "vite-plugin-wasm";
import topLevelAwait from "vite-plugin-top-level-await";

// ...
  plugins: [ 
            wasm(),
            topLevelAwait(),
            //... 
  ]
//

Rust

use satellite;

pub fn main(){
    let tle_line1 = "1 44714C 19074B   24257.74770833  .00012054  00000+0  80755-3 0  2576";
    let tle_line2 = "2 44714  53.0541  99.4927 0001373  86.0479  80.2511 15.06391223    18";
    let mut satrec = satellite::twoline2satrec(tle_line1, tle_line2);
    let _position_and_velocity = satellite::propagate(&mut satrec, 2024.0, 9.0, 22.0, 12.0, 12.0, 12.0, 0.0);
}

todo

  • Performance optimization after compiling to wasm
  • Add testCase

Dependencies

~2.4–4MB
~66K SLoC