+ case FIXED_POINTS_1D: {
+ const std::vector<double>& aPnts = _fpHyp->GetPoints();
+ const std::vector<int>& nbsegs = _fpHyp->GetNbSegments();
+ int i = 0;
+ TColStd_SequenceOfReal Params;
+ for(; i<aPnts.size(); i++) {
+ if( aPnts[i]<0.0001 || aPnts[i]>0.9999 ) continue;
+ int j=1;
+ bool IsExist = false;
+ for(; j<=Params.Length(); j++) {
+ if( fabs(aPnts[i]-Params.Value(j)) < 1e-4 ) {
+ IsExist = true;
+ break;
+ }
+ if( aPnts[i]<Params.Value(j) ) break;
+ }
+ if(!IsExist) Params.InsertBefore(j,aPnts[i]);
+ }
+ double pf, pl, par2, par1, psize;
+ if (theReverse) {
+ pf = l;
+ pl = f;
+ }
+ else {
+ pf = f;
+ pl = l;
+ }
+ psize = pl - pf;
+ par1 = pf;
+ //cout<<"aPnts.size() = "<<aPnts.size()<<" Params.Length() = "
+ // <<Params.Length()<<" nbsegs.size() = "<<nbsegs.size()<<endl;
+ for(i=0; i<Params.Length(); i++) {
+ par2 = pf + Params.Value(i+1)*psize;
+ int nbseg = ( i > nbsegs.size()-1 ) ? nbsegs[0] : nbsegs[i];
+ double dp = (par2-par1)/nbseg;
+ int j = 1;
+ for(; j<=nbseg; j++) {
+ double param = par1 + dp*j;
+ theParams.push_back( param );
+ }
+ par1 = par2;
+ }
+ // add for last
+ int nbseg = ( nbsegs.size() > Params.Length() ) ? nbsegs[Params.Length()] : nbsegs[0];
+ double dp = (pl-par1)/nbseg;
+ int j = 1;
+ for(; j<nbseg; j++) {
+ double param = par1 + dp*j;
+ theParams.push_back( param );
+ }
+ if (theReverse) {
+ theParams.reverse(); // NPAL18025
+ }
+ return true;
+ }
+