27gsMatrix<T> * innerProduct(
const gsBasis<T>& B1,
const gsBasis<T>& B2)
29 gsMatrix<T> * K =
new gsMatrix<T>(B1.size(), B2.size() ) ;
32 int nGauss = int( ceil(
double(B1.degree(0) + B2.degree(0) + 1)/2 ) );
33 if (nGauss<1) nGauss=1;
35 gsGaussRule<T> QuRule(nGauss);
38 gsMatrix<index_t> act1, act2;
39 gsMatrix<T> ev1 , ev2;
41 typename gsBasis<T>::domainIter domIt = B1.makeDomainIterator();
42 for (; domIt->good(); domIt->next())
45 QuRule.mapTo( domIt->lowerCorner(), domIt->upperCorner(), ngrid, wgrid );
47 B1.eval_into(ngrid,ev1);
48 B2.eval_into(ngrid,ev2);
49 B1.active_into(ngrid,act1);
50 B2.active_into(ngrid,act2);
52 for (
index_t k=0; k!= ngrid.cols(); ++k)
53 for (
index_t i=0; i!=act1.rows(); ++i)
54 for (
index_t j=0; j!=act2.rows(); ++j)
55 (*K)( act1(i,k) , act2(j,k) ) += wgrid(k) * ev1(i,k) * ev2(j,k) ;
62gsMatrix<T> * innerProduct1(
const gsBasis<T>& B1,
const gsBasis<T>& B2)
64 gsMatrix<T> * K =
new gsMatrix<T>(B1.size(), B2.size() ) ;
67 int nGauss = int( ceil(
double(B1.degree(0)-1 + B2.degree(0)-1 + 1)/2 ) );
68 if (nGauss<1) nGauss=1;
70 gsGaussRule<T> QuRule(nGauss);
73 gsMatrix<index_t> act1, act2;
74 gsMatrix<T> ev1 , ev2;
76 typename gsBasis<T>::domainIter domIt = B1.makeDomainIterator();
77 for (; domIt->good(); domIt->next())
80 QuRule.mapTo( domIt->lowerCorner(), domIt->upperCorner(), ngrid, wgrid );
82 B1.deriv_into(ngrid,ev1);
83 B2.deriv_into(ngrid,ev2);
84 B1.active_into(ngrid,act1);
85 B2.active_into(ngrid,act2);
87 for (
index_t k=0; k!= ngrid.cols(); ++k)
88 for (
index_t i=0; i!=act1.rows(); ++i)
89 for (
index_t j=0; j!=act2.rows(); ++j)
90 (*K)( act1(i,k) , act2(j,k) ) += wgrid(k) * ev1(i,k) * ev2(j,k) ;
98gsMatrix<T> * innerProduct2(
const gsBasis<T>& B1,
const gsBasis<T>& B2)
100 gsMatrix<T> * K =
new gsMatrix<T>(B1.size(), B2.size() ) ;
103 int nGauss = int( ceil(
double(B1.degree(0)-2 + B2.degree(0)-2 + 1)/2 ) );
104 if (nGauss<1) nGauss=1;
106 gsGaussRule<T> QuRule(nGauss);
109 gsMatrix<index_t> act1, act2;
110 gsMatrix<T> ev1 , ev2;
112 typename gsBasis<T>::domainIter domIt = B1.makeDomainIterator();
113 for (; domIt->good(); domIt->next())
116 QuRule.mapTo( domIt->lowerCorner(), domIt->upperCorner(), ngrid, wgrid );
118 B1.deriv2_into(ngrid,ev1);
119 B2.deriv2_into(ngrid,ev2);
120 B1.active_into(ngrid,act1);
121 B2.active_into(ngrid,act2);
123 for (
index_t k=0; k!= ngrid.cols(); ++k)
124 for (
index_t i=0; i!=act1.rows(); ++i)
125 for (
index_t j=0; j!=act2.rows(); ++j)
126 (*K)( act1(i,k) , act2(j,k) ) += wgrid(k) * ev1(i,k) * ev2(j,k) ;
142 abc1(0) = tangent1(1);
143 abc1(1) = -tangent1(0);
144 abc1(2) = -( abc1(0)*Vert1(0,0) + abc1(1)*Vert1(0,1) );
145 abc2(0) = tangent2(1);
146 abc2(1) = -tangent2(0);
147 abc2(2) = -( abc2(0)*Vert2(0,0) + abc2(1)*Vert2(0,1) );
149 T detMatrixab = abc1(0)*abc2(1)-abc1(1)*abc2(0);
152 unknown(0) = -(1/detMatrixab)*( abc2(1)*abc1(2)-abc1(1)*abc2(2) );
153 unknown(1) = -(1/detMatrixab)*( -abc2(0)*abc1(2)+abc1(0)*abc2(2) );
157 unknown(0) = .5*Vert1(0) + .5*Vert2(0);
158 unknown(1) = .5*Vert1(1) + .5*Vert2(1);
166{ T dotp = vec1.dot(vec2)/( vec1.norm()*vec2.norm() );
169 gsWarn<<
"gsModelingUtils: truncations done for std::acos \n";
171 if ( dotp>1 ) {dotp = 1;
172 gsWarn<<
"gsModelingUtils: truncations done for std::acos \n";
175 T ag = math::acos(dotp);
184 T ag = conditionedAngle<T>(vec1,vec2);
185 T cag = ( normal.dot( vec1.cross( vec2 ) ) >= 0 ) ? ag : (T)(2*EIGEN_PI)-ag;
199 combined.block(0, 0, n, n) = 2*A;
200 combined.block(0, n, n, m) = C.transpose();
201 combined.block(n, 0, m, n) = C;
202 combined.block(n, n, m, m).setZero();
205 longD.head(n).setZero();
208 gsMatrix<T> result = combined.fullPivLu().solve(longD);
209 return result.block(0, 0, n, 1);
223 assert(d.cols()==1 && C.rows()==d.rows());
225 if (b.rows()!=1) bt=b.transpose();
else bt=b;
228 combined.block(0, 0, n, n) = 2*A;
229 combined.block(0, n, n, m) = C.transpose();
230 combined.block(n, 0, m, n) = C;
231 combined.block(n, n, m, m).setZero();
234 longD.head(n) = -bt.transpose();
237 gsMatrix<T> result = combined.fullPivLu().solve(longD);
238 return result.block(0, 0, n, 1);
248 return criticalPointOfQuadratic<T>(A,b,C,d);
256 return criticalPointOfQuadratic<T>( (A.transpose())*A, (-2)*( A.transpose() )*b, C, d);
266 return criticalPointOfQuadratic<T>( w1*(A1.transpose())*A1 + w2*(A2.transpose())*A2,
267 (-2)*w1*( A1.transpose() )*b1 + (-2)*w2*( A2.transpose() )*b2, C, d);
279 return criticalPointOfQuadratic<T>( w1*(A1.transpose())*A1 + w2*(A2.transpose())*A2 + w3*Q,
280 (-2)*w1*( A1.transpose() )*b1 + (-2)*w2*( A2.transpose() )*b2, C, d);
287 return mat.rowwise().reverse();
303 assert(mat1.rows()==3 && mat2.rows()==3);
304 assert(mat1.cols()==mat2.cols());
305 size_t const nr = mat1.rows();
306 size_t const nc = mat1.cols();
307 gsMatrix<T> rcross(nr,mat1.cols()); rcross.setZero();
309 for (
size_t i=0; i<= nc-1; i++)
312 rcross.col(i) = tem / tem.norm();
327 assert(nc1== C2.cols() );
328 assert(nr1==d1.rows());
329 assert(nr2==d2.rows());
330 C.resize(nr1+nr2,nc1);
331 C.block(0,0,nr1,nc1) = C1;
332 C.block(nr1,0,nr2,nc1) = C2;
334 d.block(0,0,nr1,1) = d1;
335 d.block(nr1,0,nr2,1) = d2;
342 T eps=2.220446049250313e-16;
347 for (
int i=0;i!=n1;i++)
349 for (
int j=0;j!=n2;j++)
351 if (math::abs(mat(i,j))< eps) matc(i,j)=0.;
361 assert(removeEnds==1 || removeEnds==2);
362 int nPeriod = mat.cols()/nPoints;
363 assert( nPeriod*nPoints == mat.cols() );
367 for (
int i=nPeriod-1;i>=0;i--)
369 ind2 = i*nPoints + nPoints-1;
375 for (
int i=nPeriod-1;i>=0;i--)
377 ind2 = i*nPoints + nPoints-1;
396 T
const & w_reg,T
const & w_app,
410 int nip = image.cols();
411 int nn=normal.cols();
415 Nu = bs.
eval(preImage.row(0));
416 dNu = bs.
deriv(preImage.row(0));
417 Nu.transposeInPlace();
418 dNu.transposeInPlace();
419 dNu_nm = bs.
deriv(preNormal.row(0));
420 dNu_nm.transposeInPlace();
421 gsMatrix<T> AdN = normal.row(0).asDiagonal() * dNu_nm;
422 gsMatrix<T> BdN = normal.row(1).asDiagonal() * dNu_nm;
425 NuApp = bs.
eval(preImageApp.row(0));
426 NuApp.transposeInPlace();
431 int nss = dimI*ntcp + dimI*nip + nn;
434 Ass.setZero(); bss.setZero();
435 gsMatrix<T> Hess = w_reg*(T)(2)*(*Q) + w_app*(T)(2)*(NuApp.transpose())* NuApp;
437 Ass.block(0,0,ntcp,ntcp) = Hess;
438 Ass.block(0,2*ntcp,ntcp,nip) = Nu.transpose();
439 Ass.block(0,2*ntcp+2*nip,ntcp,nn) = AdN.transpose();
440 bss.block(0,0,ntcp,1) = w_app*(T)(2)*NuApp.transpose()*X0.transpose();
442 Ass.block(ntcp,ntcp,ntcp,ntcp) = Hess;
443 Ass.block(ntcp,2*ntcp+nip,ntcp,nip) = Nu.transpose();
444 Ass.block(ntcp,2*ntcp+2*nip,ntcp,nn) = BdN.transpose();
445 bss.block(ntcp,0,ntcp,1) = w_app*(T)(2)*NuApp.transpose()*Y0.transpose();
447 Ass.block(2*ntcp,0,nip,ntcp) = Nu;
448 bss.block(2*ntcp,0,nip,1) = (image.row(0)).transpose();
450 Ass.block(2*ntcp+nip,ntcp,nip,ntcp) = Nu;
451 bss.block(2*ntcp+nip,0,nip,1) = (image.row(1)).transpose();
453 Ass.block(2*ntcp+2*nip,0,nn,ntcp) = AdN;
454 Ass.block(2*ntcp+2*nip,ntcp,nn,ntcp) = BdN;
457 tcp.col(0) = result.block(0 , 0, ntcp, 1);
458 tcp.col(1) = result.block(ntcp, 0, ntcp, 1);
480 outPointResiduals = (NuApp * tcp).transpose() - imageApp;
481 outNormalResiduals = AdN * tcp.col(0) + BdN * tcp.col(1);
509 T wEdge, T wInt, T wNormal, T wReg,
514 GISMO_ASSERT(exactPoints.rows() == 2 && exactValues.rows() == 3,
"Matrix input has incorrect dimension");
515 GISMO_ASSERT(exactPoints.cols() == exactValues.cols(),
"Matrix input has incorrect dimension");
516 GISMO_ASSERT(appxPointsEdges.rows() == 2 && appxValuesEdges.rows() == 3,
"Matrix input has incorrect dimension");
517 GISMO_ASSERT(appxPointsEdges.cols() == appxValuesEdges.cols(),
"Matrix input has incorrect dimension");
518 GISMO_ASSERT(appxPointsInt.rows() == 2 && appxValuesInt.rows() == 3,
"Matrix input has incorrect dimension");
519 GISMO_ASSERT(appxPointsInt.cols() == appxValuesInt.cols(),
"Matrix input has incorrect dimension");
520 GISMO_ASSERT(appxNormalPoints.rows() == 2 && appxNormals.rows() == 3,
"Matrix input has incorrect dimension");
521 GISMO_ASSERT(appxNormalPoints.cols() == appxNormals.cols(),
"Matrix input has incorrect dimension");
524 int const patchDeg1 = kv1.
degree();
525 int const patchDeg2 = kv2.
degree();
526 int const n1 = kv1.
size() - patchDeg1 - 1;
527 int const n2 = kv2.
size() - patchDeg2 - 1;
538 ident1.setIdentity();
539 ident2.setIdentity();
540 Nu = bs1.
evalFunc(exactPoints.row(0), ident1);
541 Nv = bs2.
evalFunc(exactPoints.row(1), ident2);
542 npts = exactPoints.cols();
545 Ecor.setZero();ecor.setZero();
547 Ecor.block(0,0,npts,n1*n2) = R.transpose();
548 Ecor.block(npts,n1*n2,npts,n1*n2) = R.transpose();
549 Ecor.block(2*npts,2*n1*n2,npts,n1*n2) = R.transpose();
550 ecor.block(0,0,npts,1) = (exactValues.row(0)).transpose();
551 ecor.block(npts,0,npts,1) = (exactValues.row(1)).transpose();
552 ecor.block(2*npts,0,npts,1) = (exactValues.row(2)).transpose();
555 Nu = bs1.
evalFunc(appxPointsEdges.row(0), ident1);
556 Nv = bs2.
evalFunc(appxPointsEdges.row(1), ident2);
557 npts = appxPointsEdges.cols();
560 AappEdge.setZero();bappEdge.setZero();
562 AappEdge.block(0,0,npts,n1*n2) = R.transpose();
563 AappEdge.block(npts,n1*n2,npts,n1*n2) = R.transpose();
564 AappEdge.block(2*npts,2*n1*n2,npts,n1*n2) = R.transpose();
565 bappEdge.block(0,0,npts,1) = (appxValuesEdges.row(0)).transpose();
566 bappEdge.block(npts,0,npts,1) = (appxValuesEdges.row(1)).transpose();
567 bappEdge.block(2*npts,0,npts,1) = (appxValuesEdges.row(2)).transpose();
570 Nu = bs1.
evalFunc(appxPointsInt.row(0), ident1);
571 Nv = bs2.
evalFunc(appxPointsInt.row(1), ident2);
572 npts = appxPointsInt.cols();
575 AappInt.setZero();bappInt.setZero();
577 AappInt.block(0,0,npts,n1*n2) = R.transpose();
578 AappInt.block(npts,n1*n2,npts,n1*n2) = R.transpose();
579 AappInt.block(2*npts,2*n1*n2,npts,n1*n2) = R.transpose();
580 bappInt.block(0,0,npts,1) = (appxValuesInt.row(0)).transpose();
581 bappInt.block(npts,0,npts,1) = (appxValuesInt.row(1)).transpose();
582 bappInt.block(2*npts,0,npts,1) = (appxValuesInt.row(2)).transpose();
585 Nu = bs1.
evalFunc(appxNormalPoints.row(0), ident1);
586 dNu = bs1.
derivFunc(appxNormalPoints.row(0), ident1);
587 Nv = bs2.
evalFunc(appxNormalPoints.row(1), ident2);
588 dNv = bs2.
derivFunc(appxNormalPoints.row(1), ident2);
591 Nx = trNormals.col(0);
592 Ny = trNormals.col(1);
593 Nz = trNormals.col(2);
594 if (force_normal==
true) { Nx.setZero(); Ny.setZero();Nz.setOnes();}
598 dRdu.transposeInPlace();
599 dRdv.transposeInPlace();
600 int nnor = Nx.rows();
604 Anor.block(0,0,nnor,n1*n2) = Nx.asDiagonal()*dRdu;
605 Anor.block(0,n1*n2,nnor,n1*n2) = Ny.asDiagonal()*dRdu;
606 Anor.block(0,2*n1*n2,nnor,n1*n2) = Nz.asDiagonal()*dRdu;
607 Anor.block(nnor,0,nnor,n1*n2) = Nx.asDiagonal()*dRdv;
608 Anor.block(nnor,n1*n2,nnor,n1*n2) = Ny.asDiagonal()*dRdv;
609 Anor.block(nnor,2*n1*n2,nnor,n1*n2) = Nz.asDiagonal()*dRdv;
616 if (kv1==kv2) { N = M; N1 = M1; N2 = M2; }
else
618 N = innerProduct(bs2, bs2);
619 N1 = innerProduct1(bs2, bs2);
620 N2 = innerProduct2(bs2, bs2);
625 Q.block(0,0,n1*n2,n1*n2) = Q1D;
626 Q.block(n1*n2,n1*n2,n1*n2,n1*n2) = Q1D;
627 Q.block(2*n1*n2,2*n1*n2,n1*n2,n1*n2) = Q1D;
630 gsMatrix<T> coefA = wEdge*(AappEdge.transpose())*AappEdge + wInt*(AappInt.transpose())*AappInt + wNormal*(Anor.transpose())*Anor + wReg*Q;
631 gsMatrix<T> coefb = (T)(-2)*wEdge*(AappEdge.transpose())*bappEdge + (T)(-2)*wInt*(AappInt.transpose())*bappInt + (T)(-2)*wNormal*(Anor.transpose())*bnor;
639 cp.resize( cp.rows() / 3, 3);
643 delete M;
delete M1;
delete M2;
644 if (kv1!=kv2) {
delete N;
delete N1;
delete N2;}
647 for(
index_t idxConstr = 0; idxConstr < exactPoints.cols(); idxConstr++)
650 gsMatrix<T> expectVal = exactValues.col(idxConstr);
652 GISMO_ASSERT((expectVal - surfVal).norm() < 0.0001,
"Fit surface did not satisfy exact constraints");
672 result.reservePerColumn(block.nonZeros() / bcols);
674 for(
index_t j = 0; j != bcols; j++)
676 for (
auto it = block.
begin(j); it; ++it)
678 result.
insertTo(it.row(), j, it.value());
679 result.
insertTo(brows+it.row(), bcols+j, it.value());
680 result.
insertTo(2*brows+it.row(), 2*bcols+j, it.value());
683 result.makeCompressed();
691 T p_min = xyz.minCoeff(),
692 p_max = xyz.maxCoeff();
693 T den = p_max - p_min;
695 points.resize(xyz.rows(), xyz.cols());
704 return (t - tMin) / (tMax - tMin);
711 for(
index_t i=0; i<mT.rows(); i++)
712 for(
index_t j=0; j<mT.cols(); j++)
713 mT(i, j) =
scaleTo01(tMin, mT(i, j), tMax);
720 T xyzMin = xyz.minCoeff();
721 T xyzMax = xyz.maxCoeff();
725 gsInfo << std::setprecision(15)
726 <<
"Scaling TO [0, 1]^3 as follows.\n"
727 <<
"min: " << xyzMin <<
"\n"
728 <<
"max: " << xyzMax <<
"\n"
729 <<
"scale: " << T(1.0) / (xyzMax - xyzMin) << std::endl;
737 return (tMax - tMin) * t + tMin;
745 for(
index_t i=0; i<mT.rows(); i++)
746 for(
index_t j=0; j<mT.cols(); j++)
750 gsInfo <<
"Scaling FROM [0, 1]^3.\n"
751 <<
"inverted scale: " << T(1.0) / (tMax - tMin) << std::scientific << std::endl;
768 const std::string& fout,
785 const std::string& fout,
797 fdIn.template getId<gsMatrix<T>>(uvIdIn, uv);
798 fdIn.template getId<gsMatrix<T>>(xyzIdIn, xyz);
809 if(uvIdOut < xyzIdOut)
834 std::vector<index_t> & corners)
838 gsMatrix<T> uv_interiors, uv_south, uv_east, uv_north, uv_west;
839 gsMatrix<T> p_interiors, p_south, p_east, p_north, p_west;
840 std::vector<index_t> interiors, b_west, b_east, b_south, b_north;
843 T u_min = parameters.row(0).minCoeff(),
844 u_max = parameters.row(0).maxCoeff(),
845 v_min = parameters.row(1).minCoeff(),
846 v_max = parameters.row(1).maxCoeff();
849 for(
index_t i=0; i < parameters.cols(); i++)
851 curr_point = parameters.col(i);
852 if( (u_min < curr_point(0)) && (curr_point(0) < u_max) && (v_min < curr_point(1)) && (curr_point(1) < v_max) )
853 interiors.push_back(i);
856 if( (math::abs(curr_point(0) - u_min) < 1e-15) && (curr_point(1) > v_min) )
858 else if( (math::abs(curr_point(0) - u_max) < 1e-15) && curr_point(1) < v_max)
860 else if( (math::abs(curr_point(1) - v_min) < 1e-15) && (curr_point(0) < u_max) )
861 b_south.push_back(i);
863 b_north.push_back(i);
867 corners.push_back(interiors.size());
868 corners.push_back(interiors.size() + b_south.size());
869 corners.push_back(interiors.size() + b_south.size() + b_east.size());
870 corners.push_back(interiors.size() + b_south.size() + b_east.size() + b_north.size());
872 uv_interiors.resize(2, interiors.size());
873 p_interiors.resize(3, interiors.size());
874 for(
size_t i = 0; i < interiors.size(); i++ )
876 uv_interiors.col(i) = parameters.col(interiors[i]);
877 p_interiors.col(i) = points.col(interiors[i]);
880 uv_west.resize(2, b_west.size());
882 for(
size_t i = 0; i < b_west.size(); i++ )
884 uv_west.col(i) = parameters.col(b_west[i]);
885 tmp_west.col(i) = points.col(b_west[i]);
888 uv_east.resize(2, b_east.size());
890 for(
size_t i = 0; i < b_east.size(); i++ )
892 uv_east.col(i) = parameters.col(b_east[i]);
893 tmp_east.col(i) = points.col(b_east[i]);
896 uv_south.resize(2, b_south.size());
898 for(
size_t i = 0; i < b_south.size(); i++ )
900 uv_south.col(i) = parameters.col(b_south[i]);
901 tmp_south.col(i) = points.col(b_south[i]);
904 uv_north.resize(2, b_north.size());
906 for(
size_t i = 0; i < b_north.size(); i++ )
908 uv_north.col(i) = parameters.col(b_north[i]);
909 tmp_north.col(i) = points.col(b_north[i]);
912 uv_south.transposeInPlace();
913 uv_east.transposeInPlace();
914 uv_north.transposeInPlace();
915 uv_west.transposeInPlace();
918 std::vector<index_t> tmp = uv_south.
idxByColumn(0);
919 p_south.resize(tmp_south.rows(), tmp_south.cols());
920 for(
size_t i = 0; i<tmp.size(); i++)
922 p_south.col(i) = tmp_south.col(tmp[i]);
924 uv_south.transposeInPlace();
929 p_east.resize(tmp_east.rows(), tmp_east.cols());
930 for(
size_t i = 0; i<tmp.size(); i++)
932 p_east.col(i) = tmp_east.col(tmp[i]);
934 uv_east.transposeInPlace();
939 std::reverse(tmp.begin(),tmp.end());
941 uv_north.col(0) = tcol;
942 tcol = uv_north.col(1).reverse();
943 uv_north.col(1) = tcol;
945 p_north.resize(tmp_north.rows(), tmp_north.cols());
946 for(
size_t i = 0; i<tmp.size(); i++)
948 p_north.col(i) = tmp_north.col(tmp[i]);
950 uv_north.transposeInPlace();
954 tcol = uv_west.col(0).reverse();
955 uv_west.col(0) = tcol;
956 tcol = uv_west.col(1).reverse();
957 uv_west.col(1) = tcol;
958 std::reverse(tmp.begin(),tmp.end());
960 p_west.resize(tmp_west.rows(), tmp_west.cols());
961 for(
size_t i = 0; i<tmp.size(); i++)
963 p_west.col(i) = tmp_west.col(tmp[i]);
965 uv_west.transposeInPlace();
969 parameters.resize(uv_interiors.rows(), points.cols());
970 parameters << uv_interiors.row(0), uv_south.row(0), uv_east.row(0), uv_north.row(0), uv_west.row(0),
971 uv_interiors.row(1), uv_south.row(1), uv_east.row(1), uv_north.row(1), uv_west.row(1);
973 points.resize(p_interiors.rows(), parameters.cols());
974 points << p_interiors.row(0), p_south.row(0), p_east.row(0), p_north.row(0), p_west.row(0),
975 p_interiors.row(1), p_south.row(1), p_east.row(1), p_north.row(1), p_west.row(1),
976 p_interiors.row(2), p_south.row(2), p_east.row(2), p_north.row(2), p_west.row(2);
996 GISMO_ASSERT( numPatch <= mp.nPatches()-1 ,
"Patch number not found, quitting.");
1001 numPtsVec<<numSamples,numSamples;
1026 GISMO_ASSERT( numPatch <= mp.nPatches()-1 ,
"Patch number not found, quitting.");
1033 numPtsVec<<numSamples,numSamples;
1037 T urange= b(0)-a(0);
1043 T vrange= b(1)-a(1);
1049 uv_interiors << mu, mv;
1053 numBdr = math::ceil(math::sqrt(numSamples)) + 2;
1061 for (
index_t pace=0; pace < 4; pace++)
1085 b_2 << b(0), mu.reverse();
1093 b_3 << b(1), mu.reverse();
1105 uv_boundary << b_0, v_ones, b_2, v_zeros, u_zeros, b_1, u_ones, b_3;
1107 params.resize(2, numSamples + numBdr*4-4);
1108 params << uv_interiors, uv_boundary;
A univariate B-spline basis.
Definition gsBSplineBasis.h:700
A B-spline function of one argument, with arbitrary target dimension.
Definition gsBSpline.h:51
gsMatrix< T > derivFunc(const gsMatrix< T > &u, const gsMatrix< T > &coefs) const
Evaluate the derivatives of the function described by coefs at points u.
Definition gsBasis.h:215
gsMatrix< T > evalFunc(const gsMatrix< T > &u, const gsMatrix< T > &coefs) const
Evaluate the function described by coefs at points u.
Definition gsBasis.h:184
This class represents an XML data tree which can be read from or written to a (file) stream.
Definition gsFileData.h:34
void dump(String const &fname="dump") const
Dump file contents to an xml file.
Definition gsFileData.hpp:86
gsMatrix< T > eval(const gsMatrix< T > &u) const
Evaluate the function,.
Definition gsFunctionSet.hpp:120
gsMatrix< T > deriv(const gsMatrix< T > &u) const
Evaluate the derivatives,.
Definition gsFunctionSet.hpp:129
Abstract base class representing a geometry map.
Definition gsGeometry.h:93
gsMatrix< T > & coefs()
Definition gsGeometry.h:340
memory::unique_ptr< gsGeometry > uPtr
Unique pointer for gsGeometry.
Definition gsGeometry.h:100
void eval_into(const gsMatrix< T > &u, gsMatrix< T > &result) const
Evaluate the function at points u into result.
Definition gsGeometry.hpp:166
gsMatrix< T > support() const
Returns the range of parameters (same as parameterRange())
Definition gsGeometry.hpp:193
Class for representing a knot vector.
Definition gsKnotVector.h:80
size_t size() const
Number of knots (including repetitions).
Definition gsKnotVector.h:242
int degree() const
Returns the degree of the knot vector.
Definition gsKnotVector.hpp:700
A matrix with arbitrary coefficient type and fixed or dynamic size.
Definition gsMatrix.h:41
gsAsMatrix< T, Dynamic, Dynamic > reshape(index_t n, index_t m)
Returns the matrix resized to n x m matrix (data is not copied) This function assumes that the matrix...
Definition gsMatrix.h:221
gsMatrix khatriRao(const gsEigen::MatrixBase< OtherDerived > &other) const
Returns the Khatri-Rao product of this with other.
Definition gsMatrix.h:537
void sortByColumn(const index_t j)
Sorts rows of matrix by column j.
Definition gsMatrix.h:388
std::vector< index_t > idxByColumn(const index_t j)
Returns the vector permutation of the rows of the matrix by column j.
Definition gsMatrix.h:415
gsMatrix kron(const gsEigen::MatrixBase< OtherDerived > &other) const
Returns the Kronecker product of this with other.
Definition gsMatrix.h:524
Container class for a set of geometry patches and their topology, that is, the interface connections ...
Definition gsMultiPatch.h:100
Sparse matrix class, based on gsEigen::SparseMatrix.
Definition gsSparseMatrix.h:139
iterator begin(const index_t outer) const
Returns an iterator to the first non-zero elemenent of column \ a outer (or row outer if the matrix i...
Definition gsSparseMatrix.h:256
void insertTo(_Index i, _Index j, const T val)
Definition gsSparseMatrix.h:289
A tensor product of d B-spline functions, with arbitrary target dimension.
Definition gsTensorBSpline.h:45
memory::shared_ptr< gsTensorBSpline > Ptr
Shared pointer for gsTensorBSpline.
Definition gsTensorBSpline.h:59
A fixed-size, statically allocated 3D vector.
Definition gsVector.h:219
A vector with arbitrary coefficient type and fixed or dynamic size.
Definition gsVector.h:37
gsMatrix< T > gsPointGrid(gsVector< T > const &a, gsVector< T > const &b, gsVector< unsigned > const &np)
Construct a Cartesian grid of uniform points in a hypercube, using np[i] points in direction i.
Definition gsPointGrid.hpp:82
#define short_t
Definition gsConfig.h:35
#define index_t
Definition gsConfig.h:32
#define gsWarn
Definition gsDebug.h:50
#define GISMO_UNUSED(x)
Definition gsDebug.h:112
#define gsInfo
Definition gsDebug.h:43
#define GISMO_ASSERT(cond, message)
Definition gsDebug.h:89
Utility class which holds I/O XML data to read/write to/from files.
Provides the Gauss-Legendre quadrature rule.
This is the main header file that collects wrappers of Eigen for linear algebra.
Represents a tensor-product B-spline patch.
The G+Smo namespace, containing all definitions for the library.
void sampleScatteredGeometry(const gsMultiPatch< T > &mp, const index_t &numPatch, const index_t &numSamples, index_t &numBdr, gsMatrix< T > ¶ms, gsMatrix< T > &points)
sampleScatteredGeometry: samples a scattered point cloud from a given geometry
Definition gsModelingUtils.hpp:1019
void removeCol(gsMatrix< T > &mat, int const &removeEnds, int const &nPoints)
remove columes 0, nPoints, 2*nPoints,.. of a given matrix
Definition gsModelingUtils.hpp:359
void scalePoints(const gsMatrix< T > &xyz, gsMatrix< T > &points)
Function to scale the input points xyz in [0,1]^D and saves it to points.
Definition gsModelingUtils.hpp:688
gsMatrix< T > flipLR(const gsMatrix< T > &mat)
Flip columes from left to right and vice versa.
Definition gsModelingUtils.hpp:285
gsMatrix< T > crossNorm2Mat(gsMatrix< T > const &mat1, gsMatrix< T > const &mat2)
Definition gsModelingUtils.hpp:301
void addConstraints(gsMatrix< T > const &C1, gsMatrix< T > const &d1, gsMatrix< T > const &C2, gsMatrix< T > const &d2, gsMatrix< T > &C, gsMatrix< T > &d)
addConstraints
Definition gsModelingUtils.hpp:319
void scalePts(const std::string &fin, const std::string &fout, index_t uvIdIn, index_t uvIdOut, index_t xyzIdIn, index_t xyzIdOut, T tMin, T tMax, bool verbose)
Scale the points contained in file fin from [0, 1]^D to [tMin, tMax]^D and save it to fout.
Definition gsModelingUtils.hpp:784
void threeOnDiag(const gsSparseMatrix< T > &block, gsSparseMatrix< T > &result)
Definition gsModelingUtils.hpp:664
gsTensorBSpline< 2, T >::Ptr gsInterpolateSurface(const gsMatrix< T > &exactPoints, const gsMatrix< T > &exactValues, const gsMatrix< T > &appxPointsEdges, const gsMatrix< T > &appxValuesEdges, const gsMatrix< T > &appxPointsInt, const gsMatrix< T > &appxValuesInt, const gsMatrix< T > &appxNormalPoints, const gsMatrix< T > &appxNormals, T wEdge, T wInt, T wNormal, T wReg, const gsKnotVector< T > &kv1, const gsKnotVector< T > &kv2, bool force_normal)
Definition gsModelingUtils.hpp:504
T conditionedAngle(gsVector3d< T > vec1, gsVector3d< T > vec2)
Angle between two vector: 0 <= angle <= pi.
Definition gsModelingUtils.hpp:165
gsBSpline< T > gsInterpolate(gsKnotVector< T > &kv, const gsMatrix< T > &preImage, const gsMatrix< T > &image, const gsMatrix< T > &preNormal, const gsMatrix< T > &normal, const gsMatrix< T > &preImageApp, const gsMatrix< T > &imageApp, T const &w_reg, T const &w_app, gsMatrix< T > &outPointResiduals, gsMatrix< T > &outNormalResiduals)
Definition gsModelingUtils.hpp:392
T scaleTo01(T tMin, T t, T tMax)
Scale the interval [tMin, tMax] to [0, 1].
Definition gsModelingUtils.hpp:702
gsVector< T > criticalPointOfQuadratic(gsMatrix< T > &A, gsMatrix< T > &C, gsVector< T > &d)
Definition gsModelingUtils.hpp:193
void sortPointCloud(gsMatrix< T > ¶meters, gsMatrix< T > &points, std::vector< index_t > &corners)
sortPointCloud: sorts the point cloud into interior and boundary points. parameters and points ordere...
Definition gsModelingUtils.hpp:832
gsMatrix< T > convert2Zero(gsMatrix< T > const &mat)
convert a with abs(a) < eps=2.220446049250313e-16 into 0
Definition gsModelingUtils.hpp:340
gsVector< T > vectorIntersect(gsVector< T > const &tangent1, gsVector< T > const &tangent2, gsMatrix< T > const &Vert1, gsMatrix< T > const &Vert2)
intersection of two vectors
Definition gsModelingUtils.hpp:135
T scaleFrom01(T tMin, T t, T tMax)
Scale the inteval [0,1] to [tMin, tMax].
Definition gsModelingUtils.hpp:735
S give(S &x)
Definition gsMemory.h:266
gsMatrix< T > optQuadratic(gsMatrix< T > const &A, gsMatrix< T > const &b, gsMatrix< T > const &C, gsMatrix< T > const &d)
Find X which solves: min (AX-b)^T (AX-b), s.t. CX=d.
Definition gsModelingUtils.hpp:253
void sampleGridGeometry(const gsMultiPatch< T > &mp, const index_t &numPatch, const index_t &numSamples, gsMatrix< T > ¶ms, gsMatrix< T > &points)
sampleGridGeometry: samples a grid point cloud from a given geometry
Definition gsModelingUtils.hpp:990
void scaleGeo(const std::string &fin, const std::string &fout, T tMin, T tMax, bool verbose)
Scale the geometry contained in file fin from [0, 1]^D to [tMin, tMax]^D and save it to fout.
Definition gsModelingUtils.hpp:767