Skip to main content

StormRelativeVelocity

Struct StormRelativeVelocity 

Source
pub struct StormRelativeVelocity { /* private fields */ }
Expand description

Storm-relative velocity — subtracts a storm motion vector from radial velocity.

This makes it easier to identify rotation signatures (mesocyclones) in storm systems by removing the bulk storm motion. The input field should contain radial velocity data.

The storm motion is specified as a direction (degrees from north) and speed (m/s). The component of the storm motion along each gate’s radial direction is subtracted from the measured velocity.

§Example

use nexrad_process::derived::StormRelativeVelocity;

// Storm moving from 240° at 15 m/s
let srv = StormRelativeVelocity::new(240.0, 15.0)?;
let sr_velocity = srv.process(&velocity_field)?;

Implementations§

Source§

impl StormRelativeVelocity

Source

pub fn new(storm_direction_degrees: f32, storm_speed_mps: f32) -> Result<Self>

Create a new storm-relative velocity processor.

§Parameters
  • storm_direction_degrees — Direction the storm is moving FROM, in degrees clockwise from north (0-360).
  • storm_speed_mps — Storm movement speed in m/s.
§Errors

Returns an error if speed is negative.

Trait Implementations§

Source§

impl SweepProcessor for StormRelativeVelocity

Source§

fn name(&self) -> &str

A human-readable name for this processor.
Source§

fn process(&self, input: &SweepField) -> Result<SweepField>

Process the input field, producing a new field with the same geometry.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.