#include "mm/mmvec.hpp" #include #include int main(int argc, char *argv[]) { // N dimensional vectors std::cout << "N dimensional (int) vectors" << std::endl; mm::vec u {3, 2, 1, 0, 1}; mm::vec v {1, 2, 3, 4, 5}; std::cout << "u = " << u << std::endl; std::cout << "v = " << v << std::endl; std::cout << std::endl; // basic operations std::cout << "u + v = " << u + v << std::endl; std::cout << "u - v = " << u - v << std::endl; std::cout << "2 * v = " << 2 * v << std::endl; std::cout << "v * 2 = " << v * 2 << std::endl; std::cout << "u * v = " << u * v << std::endl; std::cout << std::endl; u += v; // three dimensional vectors std::cout << "three dimensional (double) vectors" << std::endl; mm::vec3 a {1, 2, 3}; mm::vec3 b {3, 2, 1}; std::cout << "a = " << a << std::endl; std::cout << "b = " << b << std::endl; std::cout << std::endl; std::cout << "a x b = " << mm::vec3::cross(a, b) << std::endl; std::cout << "zenith(a) = " << a.zenith() << std::endl; std::cout << "azimuth(a) = " << a.azimuth() << std::endl; std::cout << "spherical(a) = " << a.spherical() << std::endl; std::cout << std::endl; a -= b; // two dimensional vector std::cout << "two dimensional (complex) vectors" << std::endl; mm::vec2> j {{1, 2}, {3, -1}}; mm::vec2> k { 5, {-2, 1}}; std::cout << "j = " << j << std::endl; std::cout << "k = " << k << std::endl; std::cout << std::endl; std::cout << "j x k = " << mm::vec2>::cross(j, k) << std::endl; std::cout << "angle(j) = " << j.angle() << std::endl; std::cout << "polar(j) = " << j.polar() << std::endl; std::cout << std::endl; j *= 10; return 0; }