CGI/exercise4/include/GridUtils.h

35 lines
835 B
C
Raw Normal View History

2019-01-24 14:38:18 +00:00
// This source code is property of the Computer Graphics and Visualization
// chair of the TU Dresden. Do not distribute!
2018-09-06 12:35:43 +00:00
// Copyright (C) CGV TU Dresden - All Rights Reserved
#pragma once
#include <array>
#include <Eigen/Core>
//converts 3d floating point position pos into 3d integer grid cell index
2019-01-24 14:38:18 +00:00
inline Eigen::Vector3i PositionToCellIndex(const Eigen::Vector3f& pos, const Eigen::Vector3f& cellExtents)
2018-09-06 12:35:43 +00:00
{
Eigen::Vector3i idx;
for(int d = 0; d < 3; ++d)
{
idx[d] = int(pos[d]/cellExtents[d]);
if (pos[d] < 0)
--idx[d];
}
2019-01-24 14:38:18 +00:00
return idx;
2018-09-06 12:35:43 +00:00
}
2019-01-24 14:38:18 +00:00
//returns true if the two Interval [lb1,ub2] and [lb2,ub2] overlap
2018-09-06 12:35:43 +00:00
inline bool OverlapIntervals(float lb1, float ub1, float lb2, float ub2)
{
2019-01-24 14:38:18 +00:00
if(lb1 > ub1)
2018-09-06 12:35:43 +00:00
std::swap(lb1,ub1);
2019-01-24 14:38:18 +00:00
if(lb2 > ub2)
2018-09-06 12:35:43 +00:00
std::swap(lb2,ub2);
if(ub1 < lb2|| lb1 >ub2)
return false;
2019-01-24 14:38:18 +00:00
return true;
2018-09-06 12:35:43 +00:00
}