Remove all deprecated functions/traits.

This commit is contained in:
Sébastien Crozet 2015-04-18 14:58:38 +02:00
parent 313ca1b8ae
commit 36223991c1
9 changed files with 25 additions and 157 deletions

View File

@ -144,8 +144,7 @@ pub use traits::{
Transform, Transformation, Transform, Transformation,
Translate, Translation, Translate, Translation,
Transpose, Transpose,
UniformSphereSample, UniformSphereSample
VecAsPnt,
}; };
pub use structs::{ pub use structs::{
@ -335,28 +334,6 @@ pub fn sqdist<N: BaseFloat, P: FloatPnt<N, V>, V: Norm<N>>(a: &P, b: &P) -> N {
a.sqdist(b) a.sqdist(b)
} }
/*
* Perspective
*/
/// Computes a projection matrix given the frustrum near plane width, height, the field of
/// view, and the distance to the clipping planes (`znear` and `zfar`).
#[deprecated = "Use `Persp3::new(width / height, fov, znear, zfar).as_mat()` instead"]
pub fn perspective3d<N: BaseFloat + Cast<f64> + Zero + One>(width: N, height: N, fov: N, znear: N, zfar: N) -> Mat4<N> {
let aspect = width / height;
let _1: N = one();
let sy = _1 / (fov * cast(0.5)).tan();
let sx = -sy / aspect;
let sz = -(zfar + znear) / (znear - zfar);
let tz = zfar * znear * cast(2.0) / (znear - zfar);
Mat4::new(
sx, zero(), zero(), zero(),
zero(), sy, zero(), zero(),
zero(), zero(), sz, tz,
zero(), zero(), one(), zero())
}
/* /*
* Translation<V> * Translation<V>
*/ */

View File

@ -199,20 +199,6 @@ impl<N> DMat<N> {
} }
impl<N: Copy> Indexable<(usize, usize), N> for DMat<N> { impl<N: Copy> Indexable<(usize, usize), N> for DMat<N> {
/// Changes the value of a component of the matrix.
///
/// # Arguments
/// * `rowcol` - 0-based tuple (row, col) to be changed
#[inline]
fn set(&mut self, rowcol: (usize, usize), val: N) {
let (row, col) = rowcol;
assert!(row < self.nrows);
assert!(col < self.ncols);
let offset = self.offset(row, col);
self.mij[offset] = val
}
/// Just like `set` without bounds checking. /// Just like `set` without bounds checking.
#[inline] #[inline]
unsafe fn unsafe_set(&mut self, rowcol: (usize, usize), val: N) { unsafe fn unsafe_set(&mut self, rowcol: (usize, usize), val: N) {
@ -221,18 +207,6 @@ impl<N: Copy> Indexable<(usize, usize), N> for DMat<N> {
*self.mij[..].get_unchecked_mut(offset) = val *self.mij[..].get_unchecked_mut(offset) = val
} }
/// Reads the value of a component of the matrix.
///
/// # Arguments
/// * `rowcol` - 0-based tuple (row, col) to be read
#[inline]
fn at(&self, rowcol: (usize, usize)) -> N {
let (row, col) = rowcol;
assert!(row < self.nrows);
assert!(col < self.ncols);
unsafe { self.unsafe_at((row, col)) }
}
/// Just like `at` without bounds checking. /// Just like `at` without bounds checking.
#[inline] #[inline]
unsafe fn unsafe_at(&self, rowcol: (usize, usize)) -> N { unsafe fn unsafe_at(&self, rowcol: (usize, usize)) -> N {

View File

@ -42,22 +42,6 @@ macro_rules! dvec_impl(
} }
impl<N: Copy> Indexable<usize, N> for $dvec<N> { impl<N: Copy> Indexable<usize, N> for $dvec<N> {
#[inline]
fn at(&self, i: usize) -> N {
assert!(i < self.len());
unsafe {
self.unsafe_at(i)
}
}
#[inline]
fn set(&mut self, i: usize, val: N) {
assert!(i < self.len());
unsafe {
self.unsafe_set(i, val);
}
}
#[inline] #[inline]
fn swap(&mut self, i: usize, j: usize) { fn swap(&mut self, i: usize, j: usize) {
assert!(i < self.len()); assert!(i < self.len());
@ -147,7 +131,7 @@ macro_rules! dvec_impl(
for i in 0..dim { for i in 0..dim {
let mut basis_element : $dvec<N> = $dvec::new_zeros(dim); let mut basis_element : $dvec<N> = $dvec::new_zeros(dim);
basis_element.set(i, ::one()); basis_element[i] = ::one();
res.push(basis_element); res.push(basis_element);
} }
@ -166,7 +150,7 @@ macro_rules! dvec_impl(
for i in 0..dim { for i in 0..dim {
let mut basis_element : $dvec<N> = $dvec::new_zeros(self.len()); let mut basis_element : $dvec<N> = $dvec::new_zeros(self.len());
basis_element.set(i, ::one()); basis_element[i] = ::one();
if res.len() == dim - 1 { if res.len() == dim - 1 {
break; break;

View File

@ -264,20 +264,6 @@ macro_rules! indexable_impl(
} }
impl<N: Copy> Indexable<(usize, usize), N> for $t<N> { impl<N: Copy> Indexable<(usize, usize), N> for $t<N> {
#[inline]
fn at(&self, (i, j): (usize, usize)) -> N {
unsafe {
mem::transmute::<&$t<N>, &[N; $dim * $dim]>(self)[i + j * $dim]
}
}
#[inline]
fn set(&mut self, (i, j): (usize, usize), val: N) {
unsafe {
mem::transmute::<&mut $t<N>, &mut [N; $dim * $dim]>(self)[i + j * $dim] = val
}
}
#[inline] #[inline]
fn swap(&mut self, (i1, j1): (usize, usize), (i2, j2): (usize, usize)) { fn swap(&mut self, (i1, j1): (usize, usize), (i2, j2): (usize, usize)) {
unsafe { unsafe {
@ -344,7 +330,7 @@ macro_rules! row_impl(
#[inline] #[inline]
fn set_row(&mut self, row: usize, v: $tv<N>) { fn set_row(&mut self, row: usize, v: $tv<N>) {
for (i, e) in v.iter().enumerate() { for (i, e) in v.iter().enumerate() {
self.set((row, i), *e); self[(row, i)] = *e;
} }
} }
@ -353,7 +339,7 @@ macro_rules! row_impl(
let mut res: $tv<N> = ::zero(); let mut res: $tv<N> = ::zero();
for (i, e) in res.iter_mut().enumerate() { for (i, e) in res.iter_mut().enumerate() {
*e = self.at((row, i)); *e = self[(row, i)];
} }
res res
@ -385,7 +371,7 @@ macro_rules! col_impl(
#[inline] #[inline]
fn set_col(&mut self, col: usize, v: $tv<N>) { fn set_col(&mut self, col: usize, v: $tv<N>) {
for (i, e) in v.iter().enumerate() { for (i, e) in v.iter().enumerate() {
self.set((i, col), *e); self[(i, col)] = *e;
} }
} }
@ -394,7 +380,7 @@ macro_rules! col_impl(
let mut res: $tv<N> = ::zero(); let mut res: $tv<N> = ::zero();
for (i, e) in res.iter_mut().enumerate() { for (i, e) in res.iter_mut().enumerate() {
*e = self.at((i, col)); *e = self[(i, col)];
} }
res res
@ -552,7 +538,7 @@ macro_rules! inv_impl(
let mut n0 = k; // index of a non-zero entry let mut n0 = k; // index of a non-zero entry
while n0 != $dim { while n0 != $dim {
if self.at((n0, k)) != ::zero() { if self[(n0, k)] != ::zero() {
break; break;
} }
@ -571,30 +557,30 @@ macro_rules! inv_impl(
} }
} }
let pivot = self.at((k, k)); let pivot = self[(k, k)];
for j in k..$dim { for j in k..$dim {
let selfval = self.at((k, j)) / pivot; let selfval = self[(k, j)] / pivot;
self.set((k, j), selfval); self[(k, j)] = selfval;
} }
for j in 0..$dim { for j in 0..$dim {
let resval = res.at((k, j)) / pivot; let resval = res[(k, j)] / pivot;
res.set((k, j), resval); res[(k, j)] = resval;
} }
for l in 0..$dim { for l in 0..$dim {
if l != k { if l != k {
let normalizer = self.at((l, k)); let normalizer = self[(l, k)];
for j in k..$dim { for j in k..$dim {
let selfval = self.at((l, j)) - self.at((k, j)) * normalizer; let selfval = self[(l, j)] - self[(k, j)] * normalizer;
self.set((l, j), selfval); self[(l, j)] = selfval;
} }
for j in 0..$dim { for j in 0..$dim {
let resval = res.at((l, j)) - res.at((k, j)) * normalizer; let resval = res[(l, j)] - res[(k, j)] * normalizer;
res.set((l, j), resval); res[(l, j)] = resval;
} }
} }
} }
@ -668,7 +654,7 @@ macro_rules! to_homogeneous_impl(
for i in 0..$dim { for i in 0..$dim {
for j in 0..$dim { for j in 0..$dim {
res.set((i, j), self.at((i, j))) res[(i, j)] = self[(i, j)]
} }
} }
@ -687,7 +673,7 @@ macro_rules! from_homogeneous_impl(
for i in 0..$dim2 { for i in 0..$dim2 {
for j in 0..$dim2 { for j in 0..$dim2 {
res.set((i, j), m.at((i, j))) res[(i, j)] = m[(i, j)]
} }
} }
@ -708,7 +694,7 @@ macro_rules! outer_impl(
let mut res: $m<N> = ::zero(); let mut res: $m<N> = ::zero();
for i in 0..Dim::dim(None::<$t<N>>) { for i in 0..Dim::dim(None::<$t<N>>) {
for j in 0..Dim::dim(None::<$t<N>>) { for j in 0..Dim::dim(None::<$t<N>>) {
res.set((i, j), self.at(i) * other.at(j)) res[(i, j)] = self[i] * other[j]
} }
} }
res res

View File

@ -46,15 +46,6 @@ impl<N> Shape<usize> for vec::Vec0<N> {
} }
impl<N> Indexable<usize, N> for vec::Vec0<N> { impl<N> Indexable<usize, N> for vec::Vec0<N> {
#[inline]
fn at(&self, _: usize) -> N {
panic!("Cannot index a Vec0.")
}
#[inline]
fn set(&mut self, _: usize, _: N) {
}
#[inline] #[inline]
fn swap(&mut self, _: usize, _: usize) { fn swap(&mut self, _: usize, _: usize) {
} }

View File

@ -13,8 +13,8 @@ use traits::operations::{ApproxEq, POrd, POrdering, Axpy, ScalarAdd, ScalarSub,
ScalarDiv, Absolute}; ScalarDiv, Absolute};
use traits::geometry::{Transform, Rotate, FromHomogeneous, ToHomogeneous, Dot, Norm, use traits::geometry::{Transform, Rotate, FromHomogeneous, ToHomogeneous, Dot, Norm,
Translation, Translate}; Translation, Translate};
use traits::structure::{Basis, Cast, Dim, Indexable, Iterable, IterableMut, VecAsPnt, Shape, use traits::structure::{Basis, Cast, Dim, Indexable, Iterable, IterableMut, Shape, NumVec,
NumVec, FloatVec, BaseFloat, BaseNum, Bounded}; FloatVec, BaseFloat, BaseNum, Bounded};
use structs::pnt::{Pnt1, Pnt2, Pnt3, Pnt4, Pnt5, Pnt6}; use structs::pnt::{Pnt1, Pnt2, Pnt3, Pnt4, Pnt5, Pnt6};
#[cfg(feature="arbitrary")] #[cfg(feature="arbitrary")]

View File

@ -189,20 +189,6 @@ macro_rules! indexable_impl(
} }
impl<N: Copy> Indexable<usize, N> for $t<N> { impl<N: Copy> Indexable<usize, N> for $t<N> {
#[inline]
fn at(&self, i: usize) -> N {
unsafe {
mem::transmute::<&$t<N>, &[N; $dim]>(self)[i]
}
}
#[inline]
fn set(&mut self, i: usize, val: N) {
unsafe {
mem::transmute::<&mut $t<N>, &mut [N; $dim]>(self)[i] = val
}
}
#[inline] #[inline]
fn swap(&mut self, i1: usize, i2: usize) { fn swap(&mut self, i1: usize, i2: usize) {
unsafe { unsafe {
@ -792,7 +778,6 @@ macro_rules! transform_impl(
macro_rules! vec_as_pnt_impl( macro_rules! vec_as_pnt_impl(
($tv: ident, $t: ident, $($compN: ident),+) => ( ($tv: ident, $t: ident, $($compN: ident),+) => (
impl<N> $tv<N> { impl<N> $tv<N> {
#[deprecated = "use `na::orig() + this_vector` instead."]
#[inline] #[inline]
pub fn to_pnt(self) -> $t<N> { pub fn to_pnt(self) -> $t<N> {
$t::new( $t::new(
@ -800,7 +785,6 @@ macro_rules! vec_as_pnt_impl(
) )
} }
#[deprecated = "use `&(na::orig() + *this_vector)` instead."]
#[inline] #[inline]
pub fn as_pnt(&self) -> &$t<N> { pub fn as_pnt(&self) -> &$t<N> {
unsafe { unsafe {
@ -808,18 +792,6 @@ macro_rules! vec_as_pnt_impl(
} }
} }
} }
impl<N> VecAsPnt<$t<N>> for $tv<N> {
#[inline]
fn to_pnt(self) -> $t<N> {
self.to_pnt()
}
#[inline]
fn as_pnt(&self) -> &$t<N> {
self.as_pnt()
}
}
) )
); );

View File

@ -5,8 +5,8 @@ pub use traits::geometry::{AbsoluteRotate, Cross, CrossMatrix, Dot, FromHomogene
Transform, Transformation, Translate, Translation, UniformSphereSample}; Transform, Transformation, Translate, Translation, UniformSphereSample};
pub use traits::structure::{FloatVec, FloatPnt, Basis, Cast, Col, Dim, Indexable, Iterable, pub use traits::structure::{FloatVec, FloatPnt, Basis, Cast, Col, Dim, Indexable, Iterable,
IterableMut, Mat, SquareMat, Row, NumVec, NumPnt, PntAsVec, VecAsPnt, IterableMut, Mat, SquareMat, Row, NumVec, NumPnt, PntAsVec, ColSlice,
ColSlice, RowSlice, Diag, Eye, Shape, BaseFloat, BaseNum, Bounded}; RowSlice, Diag, Eye, Shape, BaseFloat, BaseNum, Bounded};
pub use traits::operations::{Absolute, ApproxEq, Axpy, Cov, Det, Inv, LMul, Mean, Outer, POrd, pub use traits::operations::{Absolute, ApproxEq, Axpy, Cov, Det, Inv, LMul, Mean, Outer, POrd,
RMul, ScalarAdd, ScalarSub, ScalarMul, ScalarDiv, Transpose, EigenQR}; RMul, ScalarAdd, ScalarSub, ScalarMul, ScalarDiv, Transpose, EigenQR};

View File

@ -173,12 +173,6 @@ pub trait Shape<I>: Index<I> {
/// Thus, this is the same as the `I` trait but without the syntactic sugar and with a method /// Thus, this is the same as the `I` trait but without the syntactic sugar and with a method
/// to write to a specific index. /// to write to a specific index.
pub trait Indexable<I, N>: Shape<I> + IndexMut<I, Output = N> { pub trait Indexable<I, N>: Shape<I> + IndexMut<I, Output = N> {
#[deprecated = "use the Index `[]` overloaded operator instead"]
/// Reads the `i`-th element of `self`.
fn at(&self, i: I) -> N;
#[deprecated = "use the IndexMut `[]` overloaded operator instead"]
/// Writes to the `i`-th element of `self`.
fn set(&mut self, i: I, N);
/// Swaps the `i`-th element of `self` with its `j`-th element. /// Swaps the `i`-th element of `self` with its `j`-th element.
fn swap(&mut self, i: I, j: I); fn swap(&mut self, i: I, j: I);
@ -211,16 +205,6 @@ pub trait IterableMut<N> {
/* /*
* Vec related traits. * Vec related traits.
*/ */
/// Trait that relates a point of an affine space to a vector of the associated vector space.
#[deprecated = "This will be removed in the future. Use point + vector operations instead."]
pub trait VecAsPnt<P> {
/// Converts this point to its associated vector.
fn to_pnt(self) -> P;
/// Converts a reference to this point to a reference to its associated vector.
fn as_pnt<'a>(&'a self) -> &'a P;
}
/// Trait grouping most common operations on vectors. /// Trait grouping most common operations on vectors.
pub trait NumVec<N>: Dim + pub trait NumVec<N>: Dim +
Sub<Self, Output = Self> + Add<Self, Output = Self> + Sub<Self, Output = Self> + Add<Self, Output = Self> +