/* * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * Copyright 2015-2017 Danny Robson */ #include "aabb.hpp" #include "iostream.hpp" #include "../coord/iostream.hpp" #include "../debug.hpp" using util::geom::aabb; /////////////////////////////////////////////////////////////////////////////// template <> std::array< util::point3f,8 > aabb<3,float>::vertices (void) const noexcept { return {{ { lo.x, lo.y, lo.z }, { lo.x, lo.y, hi.z }, { lo.x, hi.y, lo.z }, { lo.x, hi.y, hi.z }, { hi.x, lo.y, lo.z }, { hi.x, lo.y, hi.z }, { hi.x, hi.y, lo.z }, { hi.x, hi.y, hi.z }, }}; } /////////////////////////////////////////////////////////////////////////////// namespace util::debug { template struct validator> { static bool is_valid (const aabb &b) { return all (b.lo <= b.hi); } }; } //----------------------------------------------------------------------------- template std::ostream& util::geom::operator<< (std::ostream &os, util::geom::aabb b) { return os << "[ " << b.lo << ", " << b.hi << " ]"; } //----------------------------------------------------------------------------- #define INSTANTIATE_S_T(S,T) \ namespace util::geom { template struct aabb; } \ template bool util::debug::is_valid (const aabb&); \ template std::ostream& util::geom::operator<< (std::ostream&, aabb); #define INSTANTIATE(T) \ INSTANTIATE_S_T(2,T) \ INSTANTIATE_S_T(3,T) INSTANTIATE( int32_t) INSTANTIATE( int64_t) INSTANTIATE(uint32_t) INSTANTIATE(uint64_t) INSTANTIATE(float) INSTANTIATE(double)