EquidistantCylindricalProjection

Struct EquidistantCylindricalProjection 

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

§Equidistant Cylindrical (Plate Carrée)

Classification: Conformal cylindrical

Available forms: Forward and inverse

Defined area: Global, but best used near the equator

Alias: eqc, plate_carrée, simple_cylindrical

Domain: 2D

Input type: Geodetic coordinates

Output type: Projected coordinates

§Projection String

+proj=eqc

§Usage

Because of the distortions introduced by this projection, it has little use in navigation or cadastral mapping and finds its main use in thematic mapping. In particular, the Plate Carrée has become a standard for global raster datasets, such as Celestia and NASA World Wind, because of the particularly simple relationship between the position of an image pixel on the map and its corresponding geographic location on Earth.

§Special Cases of Cylindrical Equidistant Projection:

  • Plain/Plane Chart: $0°$
  • Simple Cylindrical: $0°$
  • Plate Carrée: $0°$
  • Ronald Miller—minimum overall scale distortion: $37°30’$
  • E. Grafarend and A. Niermann: $42°$
  • Ronald Miller—minimum continental scale distortion: $43°30’$
  • Gall Isographic: $45°$
  • Ronald Miller Equirectangular: $50°30’$
  • E. Grafarend and A. Niermann minimum linear distortion: $61°7’$

§Example

Example using EPSG 32662 (WGS84 Plate Carrée):

echo 2 47 | proj +proj=eqc +ellps=WGS84

Output: 222638.98 5232016.07

Example using Plate Carrée projection with true scale at latitude 30° and central meridian 90°W:

echo -88 30 | proj +proj=eqc +lat_ts=30 +lon_0=90w

Output: 192811.01 3339584.72

§Parameters

  • +lon_0 (Central meridian)
  • +lat_0 (Latitude of origin)
  • +lat_ts (Latitude of true scale)
  • +x_0 (False easting)
  • +y_0 (False northing)
  • +ellps (Ellipsoid name)
  • +R (Radius of the sphere)

§Mathematical Definition

§Forward projection:

$$x = \lambda \cos(\phi_{ts})$$ $$y = \phi - \phi_0$$

§Inverse projection:

$$\lambda = x / \cos(\phi_{ts})$$ $$\phi = y + \phi_0$$

§Further Reading

Equidistant Cylindrical

Trait Implementations§

Source§

impl Clone for EquidistantCylindricalProjection

Source§

fn clone(&self) -> EquidistantCylindricalProjection

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 CoordinateStep for EquidistantCylindricalProjection

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 Debug for EquidistantCylindricalProjection

Source§

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

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

impl PartialEq for EquidistantCylindricalProjection

Source§

fn eq(&self, other: &EquidistantCylindricalProjection) -> 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 ProjectCoordinates for EquidistantCylindricalProjection

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 StructuralPartialEq for EquidistantCylindricalProjection

Auto Trait Implementations§

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