extern crate nalgebra as na;

use na::{Scalar, Vector3};
use simba::scalar::RealField;

fn print_vector<T: Scalar>(m: &Vector3<T>) {
    println!("{:?}", m)
}

fn print_norm<T: RealField>(v: &Vector3<T>) {
    // NOTE: alternatively, nalgebra already defines `v.norm()`.
    let norm = v.dot(v).sqrt();

    // The RealField bound implies that T is Display so we can
    // use "{}" instead of "{:?}" for the format string.
    println!("{}", norm)
}

fn main() {
    let v1 = Vector3::new(1, 2, 3);
    let v2 = Vector3::new(1.0, 2.0, 3.0);

    print_vector(&v1);
    print_norm(&v2);
}