2013-09-22 16:58:21 +08:00
|
|
|
//! Vectors with dimensions known at compile-time.
|
|
|
|
|
2014-11-01 00:40:47 +08:00
|
|
|
#![allow(missing_docs)] // we allow missing to avoid having to document the dispatch traits.
|
2013-09-15 03:11:43 +08:00
|
|
|
|
2015-01-04 16:37:56 +08:00
|
|
|
use std::ops::{Add, Sub, Mul, Div, Neg, Index, IndexMut};
|
2015-02-21 07:02:27 +08:00
|
|
|
use std::marker::PhantomData;
|
2014-05-12 07:31:22 +08:00
|
|
|
use std::mem;
|
2014-12-24 02:01:49 +08:00
|
|
|
use std::slice::{Iter, IterMut};
|
2015-02-21 07:02:27 +08:00
|
|
|
use std::iter::{Iterator, FromIterator, IntoIterator};
|
2015-02-17 20:32:54 +08:00
|
|
|
use rand::{Rand, Rng};
|
2014-11-19 19:11:32 +08:00
|
|
|
use traits::operations::{ApproxEq, POrd, POrdering, Axpy, ScalarAdd, ScalarSub, ScalarMul,
|
2014-11-06 21:20:59 +08:00
|
|
|
ScalarDiv, Absolute};
|
2013-10-06 22:54:09 +08:00
|
|
|
use traits::geometry::{Transform, Rotate, FromHomogeneous, ToHomogeneous, Dot, Norm,
|
|
|
|
Translation, Translate};
|
2014-10-26 22:04:47 +08:00
|
|
|
use traits::structure::{Basis, Cast, Dim, Indexable, Iterable, IterableMut, VecAsPnt, Shape,
|
2014-11-16 21:04:15 +08:00
|
|
|
NumVec, FloatVec, BaseFloat, BaseNum, Zero, One, Bounded};
|
2014-10-10 17:23:52 +08:00
|
|
|
use structs::pnt::{Pnt1, Pnt2, Pnt3, Pnt4, Pnt5, Pnt6};
|
2013-09-07 14:23:09 +08:00
|
|
|
|
2015-01-10 08:36:13 +08:00
|
|
|
#[cfg(feature="arbitrary")]
|
|
|
|
use quickcheck::{Arbitrary, Gen};
|
|
|
|
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 0.
|
2015-02-21 07:02:27 +08:00
|
|
|
#[derive(Eq, PartialEq, Clone, Debug, Copy)]
|
|
|
|
pub struct Vec0<N>(pub PhantomData<N>);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2014-09-16 09:30:36 +08:00
|
|
|
impl<N> Vec0<N> {
|
|
|
|
/// Creates a new vector.
|
|
|
|
#[inline]
|
|
|
|
pub fn new() -> Vec0<N> {
|
2015-02-21 07:02:27 +08:00
|
|
|
Vec0(PhantomData)
|
2014-09-16 09:30:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Creates a new vector. The parameter is not taken in account.
|
|
|
|
#[inline]
|
|
|
|
pub fn new_repeat(_: N) -> Vec0<N> {
|
2015-02-21 07:02:27 +08:00
|
|
|
Vec0(PhantomData)
|
2014-09-16 09:30:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 1.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec1<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N
|
2013-07-24 22:50:40 +08:00
|
|
|
}
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec1, x);
|
2015-01-10 05:34:57 +08:00
|
|
|
ord_impl!(Vec1, x,);
|
2014-12-19 22:33:01 +08:00
|
|
|
vec_axis_impl!(Vec1, x);
|
|
|
|
vec_cast_impl!(Vec1, x);
|
|
|
|
as_array_impl!(Vec1, 1);
|
|
|
|
index_impl!(Vec1);
|
|
|
|
indexable_impl!(Vec1, 1);
|
|
|
|
at_fast_impl!(Vec1, 1);
|
|
|
|
new_repeat_impl!(Vec1, val, x);
|
|
|
|
dim_impl!(Vec1, 1);
|
|
|
|
container_impl!(Vec1);
|
|
|
|
// (specialized); basis_impl!(Vec1, 1);
|
|
|
|
add_impl!(Vec1, x);
|
|
|
|
sub_impl!(Vec1, x);
|
|
|
|
mul_impl!(Vec1, x);
|
|
|
|
div_impl!(Vec1, x);
|
|
|
|
scalar_add_impl!(Vec1, x);
|
|
|
|
scalar_sub_impl!(Vec1, x);
|
|
|
|
scalar_mul_impl!(Vec1, x);
|
|
|
|
scalar_div_impl!(Vec1, x);
|
|
|
|
neg_impl!(Vec1, x);
|
|
|
|
dot_impl!(Vec1, x);
|
|
|
|
scalar_ops_impl!(Vec1, x);
|
|
|
|
translation_impl!(Vec1);
|
|
|
|
norm_impl!(Vec1, x);
|
|
|
|
approx_eq_impl!(Vec1, x);
|
|
|
|
zero_one_impl!(Vec1, x);
|
|
|
|
from_iterator_impl!(Vec1, iterator);
|
|
|
|
bounded_impl!(Vec1, x);
|
|
|
|
axpy_impl!(Vec1, x);
|
|
|
|
iterable_impl!(Vec1, 1);
|
|
|
|
iterable_mut_impl!(Vec1, 1);
|
|
|
|
vec_to_homogeneous_impl!(Vec1, Vec2, y, x);
|
|
|
|
vec_from_homogeneous_impl!(Vec1, Vec2, y, x);
|
|
|
|
translate_impl!(Vec1, Pnt1);
|
|
|
|
rotate_impl!(Vec1);
|
|
|
|
rotate_impl!(Pnt1);
|
|
|
|
transform_impl!(Vec1, Pnt1);
|
|
|
|
vec_as_pnt_impl!(Vec1, Pnt1, x);
|
|
|
|
num_float_vec_impl!(Vec1);
|
|
|
|
absolute_vec_impl!(Vec1, x);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec1, x);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec1, x);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 2.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec2<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Second component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub y: N
|
2013-07-22 16:26:20 +08:00
|
|
|
}
|
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec2, x, y);
|
|
|
|
ord_impl!(Vec2, x, y);
|
|
|
|
vec_axis_impl!(Vec2, x, y);
|
|
|
|
vec_cast_impl!(Vec2, x, y);
|
|
|
|
as_array_impl!(Vec2, 2);
|
|
|
|
index_impl!(Vec2);
|
|
|
|
indexable_impl!(Vec2, 2);
|
|
|
|
at_fast_impl!(Vec2, 2);
|
|
|
|
new_repeat_impl!(Vec2, val, x, y);
|
|
|
|
dim_impl!(Vec2, 2);
|
|
|
|
container_impl!(Vec2);
|
|
|
|
// (specialized); basis_impl!(Vec2, 1);
|
|
|
|
add_impl!(Vec2, x, y);
|
|
|
|
sub_impl!(Vec2, x, y);
|
|
|
|
mul_impl!(Vec2, x, y);
|
|
|
|
div_impl!(Vec2, x, y);
|
|
|
|
scalar_add_impl!(Vec2, x, y);
|
|
|
|
scalar_sub_impl!(Vec2, x, y);
|
|
|
|
scalar_mul_impl!(Vec2, x, y);
|
|
|
|
scalar_div_impl!(Vec2, x, y);
|
|
|
|
neg_impl!(Vec2, x, y);
|
|
|
|
dot_impl!(Vec2, x, y);
|
|
|
|
scalar_ops_impl!(Vec2, x, y);
|
|
|
|
translation_impl!(Vec2);
|
|
|
|
norm_impl!(Vec2, x, y);
|
|
|
|
approx_eq_impl!(Vec2, x, y);
|
|
|
|
zero_one_impl!(Vec2, x, y);
|
|
|
|
from_iterator_impl!(Vec2, iterator, iterator);
|
|
|
|
bounded_impl!(Vec2, x, y);
|
|
|
|
axpy_impl!(Vec2, x, y);
|
|
|
|
iterable_impl!(Vec2, 2);
|
|
|
|
iterable_mut_impl!(Vec2, 2);
|
|
|
|
vec_to_homogeneous_impl!(Vec2, Vec3, z, x, y);
|
|
|
|
vec_from_homogeneous_impl!(Vec2, Vec3, z, x, y);
|
|
|
|
translate_impl!(Vec2, Pnt2);
|
|
|
|
rotate_impl!(Vec2);
|
|
|
|
rotate_impl!(Pnt2);
|
|
|
|
transform_impl!(Vec2, Pnt2);
|
|
|
|
vec_as_pnt_impl!(Vec2, Pnt2, x, y);
|
|
|
|
num_float_vec_impl!(Vec2);
|
|
|
|
absolute_vec_impl!(Vec2, x, y);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec2, x, y);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec2, x, y);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 3.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec3<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Second component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub y: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Third component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub z: N
|
2013-07-22 16:26:20 +08:00
|
|
|
}
|
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec3, x, y, z);
|
|
|
|
ord_impl!(Vec3, x, y, z);
|
|
|
|
vec_axis_impl!(Vec3, x, y, z);
|
|
|
|
vec_cast_impl!(Vec3, x, y, z);
|
|
|
|
as_array_impl!(Vec3, 3);
|
|
|
|
index_impl!(Vec3);
|
|
|
|
indexable_impl!(Vec3, 3);
|
|
|
|
at_fast_impl!(Vec3, 3);
|
|
|
|
new_repeat_impl!(Vec3, val, x, y, z);
|
|
|
|
dim_impl!(Vec3, 3);
|
|
|
|
container_impl!(Vec3);
|
|
|
|
// (specialized); basis_impl!(Vec3, 1);
|
|
|
|
add_impl!(Vec3, x, y, z);
|
|
|
|
sub_impl!(Vec3, x, y, z);
|
|
|
|
mul_impl!(Vec3, x, y, z);
|
|
|
|
div_impl!(Vec3, x, y, z);
|
|
|
|
scalar_add_impl!(Vec3, x, y, z);
|
|
|
|
scalar_sub_impl!(Vec3, x, y, z);
|
|
|
|
scalar_mul_impl!(Vec3, x, y, z);
|
|
|
|
scalar_div_impl!(Vec3, x, y, z);
|
|
|
|
neg_impl!(Vec3, x, y, z);
|
|
|
|
dot_impl!(Vec3, x, y, z);
|
|
|
|
scalar_ops_impl!(Vec3, x, y, z);
|
|
|
|
translation_impl!(Vec3);
|
|
|
|
norm_impl!(Vec3, x, y ,z);
|
|
|
|
approx_eq_impl!(Vec3, x, y, z);
|
|
|
|
zero_one_impl!(Vec3, x, y, z);
|
|
|
|
from_iterator_impl!(Vec3, iterator, iterator, iterator);
|
|
|
|
bounded_impl!(Vec3, x, y, z);
|
|
|
|
axpy_impl!(Vec3, x, y, z);
|
|
|
|
iterable_impl!(Vec3, 3);
|
|
|
|
iterable_mut_impl!(Vec3, 3);
|
|
|
|
vec_to_homogeneous_impl!(Vec3, Vec4, w, x, y, z);
|
|
|
|
vec_from_homogeneous_impl!(Vec3, Vec4, w, x, y, z);
|
|
|
|
translate_impl!(Vec3, Pnt3);
|
|
|
|
rotate_impl!(Vec3);
|
|
|
|
rotate_impl!(Pnt3);
|
|
|
|
transform_impl!(Vec3, Pnt3);
|
|
|
|
vec_as_pnt_impl!(Vec3, Pnt3, x, y, z);
|
|
|
|
num_float_vec_impl!(Vec3);
|
|
|
|
absolute_vec_impl!(Vec3, x, y, z);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec3, x, y, z);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec3, x, y, z);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-08-31 17:11:46 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 4.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec4<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Second component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub y: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Third component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub z: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Fourth component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub w: N
|
2013-07-22 16:26:20 +08:00
|
|
|
}
|
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec4, x, y, z, w);
|
|
|
|
ord_impl!(Vec4, x, y, z, w);
|
|
|
|
vec_axis_impl!(Vec4, x, y, z, w);
|
|
|
|
vec_cast_impl!(Vec4, x, y, z, w);
|
|
|
|
as_array_impl!(Vec4, 4);
|
|
|
|
index_impl!(Vec4);
|
|
|
|
indexable_impl!(Vec4, 4);
|
|
|
|
at_fast_impl!(Vec4, 4);
|
|
|
|
new_repeat_impl!(Vec4, val, x, y, z, w);
|
|
|
|
dim_impl!(Vec4, 4);
|
|
|
|
container_impl!(Vec4);
|
|
|
|
basis_impl!(Vec4, 4);
|
|
|
|
add_impl!(Vec4, x, y, z, w);
|
|
|
|
sub_impl!(Vec4, x, y, z, w);
|
|
|
|
mul_impl!(Vec4, x, y, z, w);
|
|
|
|
div_impl!(Vec4, x, y, z, w);
|
|
|
|
scalar_add_impl!(Vec4, x, y, z, w);
|
|
|
|
scalar_sub_impl!(Vec4, x, y, z, w);
|
|
|
|
scalar_mul_impl!(Vec4, x, y, z, w);
|
|
|
|
scalar_div_impl!(Vec4, x, y, z, w);
|
|
|
|
neg_impl!(Vec4, x, y, z, w);
|
|
|
|
dot_impl!(Vec4, x, y, z, w);
|
|
|
|
scalar_ops_impl!(Vec4, x, y, z, w);
|
|
|
|
translation_impl!(Vec4);
|
|
|
|
norm_impl!(Vec4, x, y, z, w);
|
|
|
|
approx_eq_impl!(Vec4, x, y, z, w);
|
|
|
|
zero_one_impl!(Vec4, x, y, z, w);
|
|
|
|
from_iterator_impl!(Vec4, iterator, iterator, iterator, iterator);
|
|
|
|
bounded_impl!(Vec4, x, y, z, w);
|
|
|
|
axpy_impl!(Vec4, x, y, z, w);
|
|
|
|
iterable_impl!(Vec4, 4);
|
|
|
|
iterable_mut_impl!(Vec4, 4);
|
|
|
|
vec_to_homogeneous_impl!(Vec4, Vec5, a, x, y, z, w);
|
|
|
|
vec_from_homogeneous_impl!(Vec4, Vec5, a, x, y, z, w);
|
|
|
|
translate_impl!(Vec4, Pnt4);
|
|
|
|
rotate_impl!(Vec4);
|
|
|
|
rotate_impl!(Pnt4);
|
|
|
|
transform_impl!(Vec4, Pnt4);
|
|
|
|
vec_as_pnt_impl!(Vec4, Pnt4, x, y, z, w);
|
|
|
|
num_float_vec_impl!(Vec4);
|
|
|
|
absolute_vec_impl!(Vec4, x, y, z, w);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec4, x, y, z, w);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec4, x, y, z, w);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 5.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec5<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Second component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub y: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Third component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub z: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Fourth component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub w: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Fifth of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub a: N
|
2013-07-22 16:26:20 +08:00
|
|
|
}
|
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec5, x, y, z, w, a);
|
|
|
|
ord_impl!(Vec5, x, y, z, w, a);
|
|
|
|
vec_axis_impl!(Vec5, x, y, z, w, a);
|
|
|
|
vec_cast_impl!(Vec5, x, y, z, w, a);
|
|
|
|
as_array_impl!(Vec5, 5);
|
|
|
|
index_impl!(Vec5);
|
|
|
|
indexable_impl!(Vec5, 5);
|
|
|
|
at_fast_impl!(Vec5, 5);
|
|
|
|
new_repeat_impl!(Vec5, val, x, y, z, w, a);
|
|
|
|
dim_impl!(Vec5, 5);
|
|
|
|
container_impl!(Vec5);
|
|
|
|
basis_impl!(Vec5, 5);
|
|
|
|
add_impl!(Vec5, x, y, z, w, a);
|
|
|
|
sub_impl!(Vec5, x, y, z, w, a);
|
|
|
|
mul_impl!(Vec5, x, y, z, w, a);
|
|
|
|
div_impl!(Vec5, x, y, z, w, a);
|
|
|
|
scalar_add_impl!(Vec5, x, y, z, w, a);
|
|
|
|
scalar_sub_impl!(Vec5, x, y, z, w, a);
|
|
|
|
scalar_mul_impl!(Vec5, x, y, z, w, a);
|
|
|
|
scalar_div_impl!(Vec5, x, y, z, w, a);
|
|
|
|
neg_impl!(Vec5, x, y, z, w, a);
|
|
|
|
dot_impl!(Vec5, x, y, z, w, a);
|
|
|
|
scalar_ops_impl!(Vec5, x, y, z, w, a);
|
|
|
|
translation_impl!(Vec5);
|
|
|
|
norm_impl!(Vec5, x, y, z, w, a);
|
|
|
|
approx_eq_impl!(Vec5, x, y, z, w, a);
|
|
|
|
zero_one_impl!(Vec5, x, y, z, w, a);
|
|
|
|
from_iterator_impl!(Vec5, iterator, iterator, iterator, iterator, iterator);
|
|
|
|
bounded_impl!(Vec5, x, y, z, w, a);
|
|
|
|
axpy_impl!(Vec5, x, y, z, w, a);
|
|
|
|
iterable_impl!(Vec5, 5);
|
|
|
|
iterable_mut_impl!(Vec5, 5);
|
|
|
|
vec_to_homogeneous_impl!(Vec5, Vec6, b, x, y, z, w, a);
|
|
|
|
vec_from_homogeneous_impl!(Vec5, Vec6, b, x, y, z, w, a);
|
|
|
|
translate_impl!(Vec5, Pnt5);
|
|
|
|
rotate_impl!(Vec5);
|
|
|
|
rotate_impl!(Pnt5);
|
|
|
|
transform_impl!(Vec5, Pnt5);
|
|
|
|
vec_as_pnt_impl!(Vec5, Pnt5, x, y, z, w, a);
|
|
|
|
num_float_vec_impl!(Vec5);
|
|
|
|
absolute_vec_impl!(Vec5, x, y, z, w, a);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec5, x, y, z, w, a);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec5, x, y, z, w, a);
|
2013-07-22 16:26:20 +08:00
|
|
|
|
2013-07-24 22:50:40 +08:00
|
|
|
/// Vector of dimension 6.
|
2015-02-17 20:32:54 +08:00
|
|
|
#[derive(Eq, PartialEq, RustcEncodable, RustcDecodable, Clone, Hash, Debug, Copy)]
|
2013-08-05 16:13:44 +08:00
|
|
|
pub struct Vec6<N> {
|
2013-08-05 15:44:56 +08:00
|
|
|
/// First component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub x: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Second component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub y: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Third component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub z: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Fourth component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub w: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Fifth of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub a: N,
|
2013-08-05 15:44:56 +08:00
|
|
|
/// Sixth component of the vector.
|
2014-04-02 04:58:06 +08:00
|
|
|
pub b: N
|
2013-07-22 16:26:20 +08:00
|
|
|
}
|
|
|
|
|
2014-12-19 22:33:01 +08:00
|
|
|
new_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
ord_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
vec_axis_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
vec_cast_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
as_array_impl!(Vec6, 6);
|
|
|
|
index_impl!(Vec6);
|
|
|
|
indexable_impl!(Vec6, 6);
|
|
|
|
at_fast_impl!(Vec6, 6);
|
|
|
|
new_repeat_impl!(Vec6, val, x, y, z, w, a, b);
|
|
|
|
dim_impl!(Vec6, 6);
|
|
|
|
container_impl!(Vec6);
|
|
|
|
basis_impl!(Vec6, 6);
|
|
|
|
add_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
sub_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
mul_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
div_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
scalar_add_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
scalar_sub_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
scalar_mul_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
scalar_div_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
neg_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
dot_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
scalar_ops_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
translation_impl!(Vec6);
|
|
|
|
norm_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
approx_eq_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
zero_one_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
from_iterator_impl!(Vec6, iterator, iterator, iterator, iterator, iterator, iterator);
|
|
|
|
bounded_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
axpy_impl!(Vec6, x, y, z, w, a, b);
|
|
|
|
iterable_impl!(Vec6, 6);
|
|
|
|
iterable_mut_impl!(Vec6, 6);
|
|
|
|
translate_impl!(Vec6, Pnt6);
|
|
|
|
rotate_impl!(Vec6);
|
|
|
|
rotate_impl!(Pnt6);
|
|
|
|
transform_impl!(Vec6, Pnt6);
|
|
|
|
vec_as_pnt_impl!(Vec6, Pnt6, x, y, z, w, a, b);
|
|
|
|
num_float_vec_impl!(Vec6);
|
|
|
|
absolute_vec_impl!(Vec6, x, y, z, w, a, b);
|
2015-01-10 08:36:13 +08:00
|
|
|
arbitrary_impl!(Vec6, x, y, z, w, a, b);
|
2015-02-17 20:32:54 +08:00
|
|
|
rand_impl!(Vec6, x, y, z, w, a, b);
|