本文整理汇总了C++中eigen::PlainObjectBase类的典型用法代码示例。如果您正苦于以下问题:C++ PlainObjectBase类的具体用法?C++ PlainObjectBase怎么用?C++ PlainObjectBase使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了PlainObjectBase类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: flipped_triangles
IGL_INLINE void igl::flipped_triangles(
const Eigen::PlainObjectBase<DerivedV> & V,
const Eigen::PlainObjectBase<DerivedF> & F,
Eigen::PlainObjectBase<DerivedX> & X)
{
assert(V.cols() == 2 && "V should contain 2D positions");
std::vector<typename DerivedX::Scalar> flip_idx;
for (int i = 0; i < F.rows(); i++)
{
// https://www.cs.cmu.edu/~quake/robust.html
typedef Eigen::Matrix<typename DerivedV::Scalar,1,2> RowVector2S;
RowVector2S v1_n = V.row(F(i,0));
RowVector2S v2_n = V.row(F(i,1));
RowVector2S v3_n = V.row(F(i,2));
Eigen::Matrix<typename DerivedV::Scalar,3,3> T2_Homo;
T2_Homo.col(0) << v1_n(0),v1_n(1),1.;
T2_Homo.col(1) << v2_n(0),v2_n(1),1.;
T2_Homo.col(2) << v3_n(0),v3_n(1),1.;
double det = T2_Homo.determinant();
assert(det == det && "det should not be NaN");
if (det < 0)
{
flip_idx.push_back(i);
}
}
igl::list_to_matrix(flip_idx,X);
}
示例2: cylinder
IGL_INLINE void igl::cylinder(
const int axis_devisions,
const int height_devisions,
Eigen::PlainObjectBase<DerivedV> & V,
Eigen::PlainObjectBase<DerivedF> & F)
{
V.resize(axis_devisions*height_devisions,3);
F.resize(2*(axis_devisions*(height_devisions-1)),3);
int f = 0;
typedef typename DerivedV::Scalar Scalar;
for(int th = 0;th<axis_devisions;th++)
{
Scalar x = cos(2.*igl::PI*Scalar(th)/Scalar(axis_devisions));
Scalar y = sin(2.*igl::PI*Scalar(th)/Scalar(axis_devisions));
for(int h = 0;h<height_devisions;h++)
{
Scalar z = Scalar(h)/Scalar(height_devisions-1);
V(th+h*axis_devisions,0) = x;
V(th+h*axis_devisions,1) = y;
V(th+h*axis_devisions,2) = z;
if(h > 0)
{
F(f,0) = ((th+0)%axis_devisions)+(h-1)*axis_devisions;
F(f,1) = ((th+1)%axis_devisions)+(h-1)*axis_devisions;
F(f,2) = ((th+0)%axis_devisions)+(h+0)*axis_devisions;
f++;
F(f,0) = ((th+1)%axis_devisions)+(h-1)*axis_devisions;
F(f,1) = ((th+1)%axis_devisions)+(h+0)*axis_devisions;
F(f,2) = ((th+0)%axis_devisions)+(h+0)*axis_devisions;
f++;
}
}
}
assert(f == F.rows());
}
示例3: assembleP
inline void igl::PlanarizerShapeUp<DerivedV, DerivedF>::planarize(Eigen::PlainObjectBase<DerivedV> &Vout)
{
Eigen::Matrix<typename DerivedV::Scalar, Eigen::Dynamic, 1> planarity;
Vout = Vin;
for (int iter =0; iter<maxIter; ++iter)
{
igl::quad_planarity(Vout, Fin, planarity);
typename DerivedV::Scalar nonPlanarity = planarity.cwiseAbs().maxCoeff();
//std::cerr<<"iter #"<<iter<<": max non-planarity: "<<nonPlanarity<<std::endl;
if (nonPlanarity<threshold)
break;
assembleP();
Vv = solver.solve(Q.transpose()*P);
if(solver.info()!=Eigen::Success)
{
std::cerr << "Linear solve failed - PlanarizerShapeUp.cpp" << std::endl;
assert(0);
}
for (int i =0;i<numV;++i)
Vout.row(i) << Vv.segment(3*i,3).transpose();
}
// set the mean of Vout to the mean of Vin
Eigen::Matrix<typename DerivedV::Scalar, 1, 3> oldMean, newMean;
oldMean = Vin.colwise().mean();
newMean = Vout.colwise().mean();
Vout.rowwise() += (oldMean - newMean);
};
示例4: sort_vectors_ccw
IGL_INLINE void igl::sort_vectors_ccw(
const Eigen::PlainObjectBase<DerivedS>& P,
const Eigen::PlainObjectBase<DerivedS>& N,
Eigen::PlainObjectBase<DerivedI> &order)
{
int half_degree = P.cols()/3;
//local frame
Eigen::Matrix<typename DerivedS::Scalar,1,3> e1 = P.head(3).normalized();
Eigen::Matrix<typename DerivedS::Scalar,1,3> e3 = N.normalized();
Eigen::Matrix<typename DerivedS::Scalar,1,3> e2 = e3.cross(e1);
Eigen::Matrix<typename DerivedS::Scalar,3,3> F; F<<e1.transpose(),e2.transpose(),e3.transpose();
Eigen::Matrix<typename DerivedS::Scalar,Eigen::Dynamic,1> angles(half_degree,1);
for (int i=0; i<half_degree; ++i)
{
Eigen::Matrix<typename DerivedS::Scalar,1,3> Pl = F.colPivHouseholderQr().solve(P.segment(i*3,3).transpose()).transpose();
// assert(fabs(Pl(2))/Pl.cwiseAbs().maxCoeff() <1e-5);
angles[i] = atan2(Pl(1),Pl(0));
}
igl::sort( angles, 1, true, angles, order);
//make sure that the first element is always at the top
while (order[0] != 0)
{
//do a circshift
int temp = order[0];
for (int i =0; i< half_degree-1; ++i)
order[i] = order[i+1];
order(half_degree-1) = temp;
}
}
示例5: is_orientable
bool is_orientable(
const Eigen::PlainObjectBase<DerivedF>& F,
const Eigen::PlainObjectBase<DeriveduE>& uE,
const std::vector<std::vector<uE2EType> >& uE2E) {
const size_t num_faces = F.rows();
const size_t num_edges = uE.rows();
auto edge_index_to_face_index = [&](size_t ei) {
return ei % num_faces;
};
auto is_consistent = [&](size_t fid, size_t s, size_t d) {
if ((size_t)F(fid, 0) == s && (size_t)F(fid, 1) == d) return true;
if ((size_t)F(fid, 1) == s && (size_t)F(fid, 2) == d) return true;
if ((size_t)F(fid, 2) == s && (size_t)F(fid, 0) == d) return true;
if ((size_t)F(fid, 0) == d && (size_t)F(fid, 1) == s) return false;
if ((size_t)F(fid, 1) == d && (size_t)F(fid, 2) == s) return false;
if ((size_t)F(fid, 2) == d && (size_t)F(fid, 0) == s) return false;
throw "Invalid face!!";
};
for (size_t i=0; i<num_edges; i++) {
const size_t s = uE(i,0);
const size_t d = uE(i,1);
int count=0;
for (const auto& ei : uE2E[i]) {
const size_t fid = edge_index_to_face_index(ei);
if (is_consistent(fid, s, d)) count++;
else count--;
}
if (count != 0) {
return false;
}
}
return true;
}
示例6: list_to_matrix
IGL_INLINE bool igl::list_to_matrix(const std::vector<std::vector<T > > & V,Eigen::PlainObjectBase<Derived>& M)
{
// number of rows
int m = V.size();
if(m == 0)
{
M.resize(0,0);
return true;
}
// number of columns
int n = igl::min_size(V);
if(n != igl::max_size(V))
{
return false;
}
assert(n != -1);
// Resize output
M.resize(m,n);
// Loop over rows
for(int i = 0;i<m;i++)
{
// Loop over cols
for(int j = 0;j<n;j++)
{
M(i,j) = V[i][j];
}
}
return true;
}
示例7: volume
IGL_INLINE void igl::volume(
Eigen::PlainObjectBase<DerivedL>& L,
Eigen::PlainObjectBase<Derivedvol>& vol)
{
using namespace Eigen;
const int m = L.rows();
typedef typename Derivedvol::Scalar ScalarS;
vol.resize(m,1);
for(int t = 0;t<m;t++)
{
const ScalarS u = L(t,0);
const ScalarS v = L(t,1);
const ScalarS w = L(t,2);
const ScalarS U = L(t,3);
const ScalarS V = L(t,4);
const ScalarS W = L(t,5);
const ScalarS X = (w - U + v)*(U + v + w);
const ScalarS x = (U - v + w)*(v - w + U);
const ScalarS Y = (u - V + w)*(V + w + u);
const ScalarS y = (V - w + u)*(w - u + V);
const ScalarS Z = (v - W + u)*(W + u + v);
const ScalarS z = (W - u + v)*(u - v + W);
const ScalarS a = sqrt(x*Y*Z);
const ScalarS b = sqrt(y*Z*X);
const ScalarS c = sqrt(z*X*Y);
const ScalarS d = sqrt(x*y*z);
vol(t) = sqrt(
(-a + b + c + d)*
( a - b + c + d)*
( a + b - c + d)*
( a + b + c - d))/
(192.*u*v*w);
}
}
示例8: face_areas
IGL_INLINE void igl::face_areas(
const Eigen::MatrixBase<DerivedL>& L,
const typename DerivedL::Scalar doublearea_nan_replacement,
Eigen::PlainObjectBase<DerivedA>& A)
{
using namespace Eigen;
assert(L.cols() == 6);
const int m = L.rows();
// (unsigned) face Areas (opposite vertices: 1 2 3 4)
Matrix<typename DerivedA::Scalar,Dynamic,1>
A0(m,1), A1(m,1), A2(m,1), A3(m,1);
Matrix<typename DerivedA::Scalar,Dynamic,3>
L0(m,3), L1(m,3), L2(m,3), L3(m,3);
L0<<L.col(1),L.col(2),L.col(3);
L1<<L.col(0),L.col(2),L.col(4);
L2<<L.col(0),L.col(1),L.col(5);
L3<<L.col(3),L.col(4),L.col(5);
doublearea(L0,doublearea_nan_replacement,A0);
doublearea(L1,doublearea_nan_replacement,A1);
doublearea(L2,doublearea_nan_replacement,A2);
doublearea(L3,doublearea_nan_replacement,A3);
A.resize(m,4);
A.col(0) = 0.5*A0;
A.col(1) = 0.5*A1;
A.col(2) = 0.5*A2;
A.col(3) = 0.5*A3;
}
示例9: internal_angles
IGL_INLINE void igl::internal_angles(
const Eigen::PlainObjectBase<DerivedL>& L,
Eigen::PlainObjectBase<DerivedK> & K)
{
typedef typename DerivedL::Index Index;
assert(L.cols() == 3 && "Edge-lengths should come from triangles");
const Index m = L.rows();
K.resize(m,3);
//for(int d = 0;d<3;d++)
//{
// const auto & s1 = L.col(d).array();
// const auto & s2 = L.col((d+1)%3).array();
// const auto & s3 = L.col((d+2)%3).array();
// K.col(d) = ((s3.square() + s2.square() - s1.square())/(2.*s3*s2)).acos();
//}
// Minimum number of iterms per openmp thread
#ifndef IGL_OMP_MIN_VALUE
# define IGL_OMP_MIN_VALUE 1000
#endif
#pragma omp parallel for if (m>IGL_OMP_MIN_VALUE)
for(Index f = 0;f<m;f++)
{
for(size_t d = 0;d<3;d++)
{
const auto & s1 = L(f,d);
const auto & s2 = L(f,(d+1)%3);
const auto & s3 = L(f,(d+2)%3);
K(f,d) = acos((s3*s3 + s2*s2 - s1*s1)/(2.*s3*s2));
}
}
}
示例10: mat_min
IGL_INLINE void igl::mat_min(
const Eigen::DenseBase<DerivedX> & X,
const int dim,
Eigen::PlainObjectBase<DerivedY> & Y,
Eigen::PlainObjectBase<DerivedI> & I)
{
assert(dim==1||dim==2);
// output size
int n = (dim==1?X.cols():X.rows());
// resize output
Y.resize(n);
I.resize(n);
// loop over dimension opposite of dim
for(int j = 0;j<n;j++)
{
typename DerivedX::Index PHONY,i;
typename DerivedX::Scalar m;
if(dim==1)
{
m = X.col(j).minCoeff(&i,&PHONY);
}else
{
m = X.row(j).minCoeff(&PHONY,&i);
}
Y(j) = m;
I(j) = i;
}
}
示例11: crouzeix_raviart_massmatrix
void igl::crouzeix_raviart_massmatrix(
const Eigen::PlainObjectBase<DerivedV> & V,
const Eigen::PlainObjectBase<DerivedF> & F,
const Eigen::PlainObjectBase<DerivedE> & E,
const Eigen::PlainObjectBase<DerivedEMAP> & EMAP,
Eigen::SparseMatrix<MT> & M)
{
using namespace Eigen;
using namespace std;
assert(F.cols() == 3);
// Mesh should be edge-manifold
assert(is_edge_manifold(F));
// number of elements (triangles)
int m = F.rows();
// Get triangle areas
VectorXd TA;
doublearea(V,F,TA);
vector<Triplet<MT> > MIJV(3*m);
for(int f = 0;f<m;f++)
{
for(int c = 0;c<3;c++)
{
MIJV[f+m*c] = Triplet<MT>(EMAP(f+m*c),EMAP(f+m*c),TA(f)*0.5);
}
}
M.resize(E.rows(),E.rows());
M.setFromTriplets(MIJV.begin(),MIJV.end());
}
示例12: project_to_line_segment
IGL_INLINE void igl::project_to_line_segment(
const Eigen::PlainObjectBase<DerivedP> & P,
const Eigen::PlainObjectBase<DerivedS> & S,
const Eigen::PlainObjectBase<DerivedD> & D,
Eigen::PlainObjectBase<Derivedt> & t,
Eigen::PlainObjectBase<DerivedsqrD> & sqrD)
{
project_to_line(P,S,D,t,sqrD);
const int np = P.rows();
// loop over points and fix those that projected beyond endpoints
#pragma omp parallel for if (np>10000)
for(int p = 0;p<np;p++)
{
const Eigen::PlainObjectBase<DerivedS> Pp = P.row(p);
if(t(p)<0)
{
sqrD(p) = (Pp-S).squaredNorm();
t(p) = 0;
}else if(t(p)>1)
{
sqrD(p) = (Pp-D).squaredNorm();
t(p) = 1;
}
}
}
示例13: slice_into
IGL_INLINE void igl::slice_into(
const Eigen::PlainObjectBase<DerivedX> & X,
const Eigen::Matrix<int,Eigen::Dynamic,1> & R,
const Eigen::Matrix<int,Eigen::Dynamic,1> & C,
Eigen::PlainObjectBase<DerivedX> & Y)
{
int xm = X.rows();
int xn = X.cols();
assert(R.size() == xm);
assert(C.size() == xn);
#ifndef NDEBUG
int ym = Y.size();
int yn = Y.size();
assert(R.minCoeff() >= 0);
assert(R.maxCoeff() < ym);
assert(C.minCoeff() >= 0);
assert(C.maxCoeff() < yn);
#endif
// Build reindexing maps for columns and rows, -1 means not in map
Eigen::Matrix<int,Eigen::Dynamic,1> RI;
RI.resize(xm);
for(int i = 0;i<xm;i++)
{
for(int j = 0;j<xn;j++)
{
Y(R(i),C(j)) = X(i,j);
}
}
}
示例14: slice
IGL_INLINE void igl::slice(
const MatX& X,
const Eigen::PlainObjectBase<DerivedR> & R,
const int dim,
MatY& Y)
{
Eigen::Matrix<typename DerivedR::Scalar,Eigen::Dynamic,1> C;
switch(dim)
{
case 1:
// boring base case
if(X.cols() == 0)
{
Y.resize(R.size(),0);
return;
}
igl::colon(0,X.cols()-1,C);
return slice(X,R,C,Y);
case 2:
// boring base case
if(X.rows() == 0)
{
Y.resize(0,R.size());
return;
}
igl::colon(0,X.rows()-1,C);
return slice(X,C,R,Y);
default:
assert(false && "Unsupported dimension");
return;
}
}
示例15: writeOBJ
IGL_INLINE bool igl::writeOBJ(
const std::string str,
const Eigen::PlainObjectBase<DerivedV>& V,
const Eigen::PlainObjectBase<DerivedF>& F)
{
std::ofstream s(str.c_str());
if(!s.is_open())
{
fprintf(stderr,"IOError: writeOBJ() could not open %s\n",str.c_str());
return false;
}
for(int i=0;i<(int)V.rows();++i)
{
s << "v " << V(i,0) << " " << V(i,1) << " " << V(i,2) << std::endl;
}
for(int i=0;i<(int)F.rows();++i)
{
s << "f " << F(i,0)+1 << " " << F(i,1)+1 << " " << F(i,2)+1 << std::endl;
}
s.close();
return true;
}