MercatorBaseProjection

Struct MercatorBaseProjection 

Source
pub struct MercatorBaseProjection<const C: i64> { /* private fields */ }
Expand description

§Mercator Projection

The Mercator projection is a cylindrical map projection originating from the 16th century. It is widely recognized as the first regularly used map projection. It is a conformal projection where the equator projects to a straight line at constant scale. A rhumb line, or course of constant heading, projects to a straight line, making it suitable for navigational purposes.

Classification: Conformal cylindrical

Available forms: Forward and Inverse, spherical and ellipsoidal

Defined area: Global, but best used near the equator

Alias: merc

Domain: 2D

Input type: Geodetic coordinates

Output type: Projected coordinates

§Projection String

+proj=merc

§Usage

The Mercator projection is often used for equatorial regions and navigational charts. It is not suitable for world maps due to significant area distortions. For example, Greenland appears larger than South America in the projection, despite Greenland’s actual area being approximately one-eighth of South America’s.

Examples:

  • Using latitude of true scale:
    $ echo 56.35 12.32 | proj +proj=merc +lat_ts=56.5
    3470306.37    759599.90
  • Using scaling factor:
    $ echo 56.35 12.32 | proj +proj=merc +k_0=2
    12545706.61    2746073.80

Note: +lat_ts and +k_0 are mutually exclusive. If both are used, +lat_ts takes precedence over +k_0.

§Parameters

  • lat_ts: Latitude of true scale
  • k_0: Scaling factor
  • lon_0: Longitude of origin
  • x_0: False easting
  • y_0: False northing
  • ellps: Ellipsoid
  • R: Radius of the sphere

§Mathematical Definition

Spheroidal Form

  • Forward Projection: $$x = k_0 \cdot R \cdot \lambda$$ $$y = k_0 \cdot R \cdot \psi$$ where $$\psi = \ln\left(\tan\left(\frac{\pi}{4} + \frac{\phi}{2}\right)\right)$$
  • Inverse Projection: $$\lambda = x / (k_0 \cdot R)$$ $$\psi = y / (k_0 \cdot R)$$ $$\phi = \frac{\pi}{2} - 2 \cdot \arctan\left(\exp(-\psi)\right)$$

Ellipsoidal Form

  • Forward Projection: $$x = k_0 \cdot a \cdot \lambda$$ $$y = k_0 \cdot a \cdot \psi$$ where $$\psi = \ln\left(\tan\left(\frac{\pi}{4} + \frac{\phi}{2}\right)\right) - 0.5 \cdot e \cdot \ln\left(\frac{1 + e \cdot \sin(\phi)}{1 - e \cdot \sin(\phi)}\right)$$
  • Inverse Projection: $$\lambda = x / (k_0 \cdot a)$$ $$\psi = y / (k_0 \cdot a)$$ $$\phi = \arctan(\tau)$$ where $$\tau = \tan(\phi)$$

§Further Reading

Mercator Projection

Trait Implementations§

Source§

impl<const C: i64> Clone for MercatorBaseProjection<C>

Source§

fn clone(&self) -> MercatorBaseProjection<C>

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<const C: i64> CoordinateStep for MercatorBaseProjection<C>

Source§

fn new(proj: Rc<RefCell<Proj>>) -> Self

Create a new Converter
Source§

fn forward<P: TransformCoordinates>(&self, p: &mut P)

forward conversion
Source§

fn inverse<P: TransformCoordinates>(&self, p: &mut P)

inverse conversion
Source§

impl<const C: i64> Debug for MercatorBaseProjection<C>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<const C: i64> PartialEq for MercatorBaseProjection<C>

Source§

fn eq(&self, other: &MercatorBaseProjection<C>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<const C: i64> ProjectCoordinates for MercatorBaseProjection<C>

Source§

fn code(&self) -> i64

ESPG code for this projection
Source§

fn name(&self) -> &'static str

Projection name
Source§

fn names() -> &'static [&'static str]

Returns the list of canonical names for this projection. This is an associated function, similar to a static method.
Source§

fn datum_type() -> u8

get the datum type. Defaults to no datum
Source§

impl<const C: i64> StructuralPartialEq for MercatorBaseProjection<C>

Auto Trait Implementations§

§

impl<const C: i64> Freeze for MercatorBaseProjection<C>

§

impl<const C: i64> !RefUnwindSafe for MercatorBaseProjection<C>

§

impl<const C: i64> !Send for MercatorBaseProjection<C>

§

impl<const C: i64> !Sync for MercatorBaseProjection<C>

§

impl<const C: i64> Unpin for MercatorBaseProjection<C>

§

impl<const C: i64> !UnwindSafe for MercatorBaseProjection<C>

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V