當前位置: 首頁>>代碼示例>>C++>>正文


C++ Dist函數代碼示例

本文整理匯總了C++中Dist函數的典型用法代碼示例。如果您正苦於以下問題:C++ Dist函數的具體用法?C++ Dist怎麽用?C++ Dist使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了Dist函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: route_evaluation

FloatType route_evaluation(GlobalGiftData g_data, const Route & r){
    FloatType res = 0.0;
    int test_counter = 0;

    FloatType w = sleigh_base_weight;
    for (int i = 0; i < r.size(); ++i) {
        const auto & gift = g_data[r[i]];
        w += gift.Weight();
        ++test_counter;
    }

    auto w_limit = sleigh_weight_limit + sleigh_base_weight;

    // weight > then limit
    assert(w <= w_limit);

    res += w*Dist(north_pole, g_data[r[0]].Loc() );

    test_counter = 0;
    int __size = r.size();
    for (int i = 0; i < __size-1; ++i) {
        const auto & gift = g_data[r[i]];
        const auto & gift_next = g_data[r[i+1]];

        w -= gift.Weight();

        res += w*Dist(gift.Loc(), gift_next.Loc());
        ++test_counter;
    }

    w = sleigh_base_weight;
    res += w*Dist(north_pole, g_data[r[r.size()-1]].Loc() );

    return res;
}
開發者ID:bubuker,項目名稱:keggle_santa,代碼行數:35,代碼來源:Route.cpp

示例2: qsort

void Graph::sg_knn()
{

	int i,j,l, k;
	k = (int) par;
	std::vector<int> *node;

	if(prepR==0)// if not preprocessed
	{
		if(dbg) Rprintf("%i-nn: ", k);
		int n = pp->size();
		double *dists2_i, *dists2_i2;
		dists2_i = new double[n];
		dists2_i2 = new double[n];
		for(i=0;i<pp->size();i++) //for each point
		{
			for(j=0;j<pp->size();j++) dists2_i2[j]=dists2_i[j]= Dist(&i,&j); //gather the distances to others
			qsort( dists2_i, pp->size(), sizeof(double), compare_doubles); // sort distances, rising
			for(j=1;j <= k;j++) // find the k nearest
				for(l=0;l<pp->size();l++)
					if( dists2_i[j] == dists2_i2[l] ) //with distance comparison
					{
						nodelist[i].push_back(l+1);
						break;
					}

		}
	}
	else{ //preprocessed
		if(dbg) Rprintf("%i-nn (shrinking):", k);
		double *dists2_i, *dists2_i2;
		for(i=0;i<pp->size();i++) //for each point
		{
			node = new std::vector<int>;
			dists2_i = new double [nodelist[i].size()];
			dists2_i2 = new double [nodelist[i].size()];
			if((int)nodelist[i].size()<k){ Rprintf("\n preprocessing R too small, not enough neighbours (point #%i)!!\n",i+1); return;}
			for(l=	0;l< (int)nodelist[i].size();l++)
			{
				j = nodelist[i][l]-1;
				dists2_i2[l]=Dist(&i,&j); //gather the distances to others, given preprocessing
				dists2_i[l]=dists2_i2[l];
			}
			qsort( dists2_i, nodelist[i].size() , sizeof(double),compare_doubles); // sort distances, rising
			for(j=0;j<k;j++) // find the k nearest
				for(l=0;l<(int)nodelist[i].size();l++)
					if( dists2_i[j] == dists2_i2[l] ) //with distance comparison
					{
						node->push_back(nodelist[i][l]);
						break;
					}
			nodelist[i].clear();nodelist[i].resize(0);
			for(j=0;j < (int)node->size();j++) nodelist[i].push_back( (*node)[j] );
			delete node;
			delete[] dists2_i;
			delete[] dists2_i2;
		}
	}
	 if(dbg) Rprintf(" Ok.");
}
開發者ID:cran,項目名稱:SGCS,代碼行數:60,代碼來源:Graph.cpp

示例3: Adjust

double Adjust(){
  int i = 0;
  while (i < n && s[i] == 'T')
    ++i;
  if (i == n)
    return -0.5;
  if (i == 0){
    if (s[i] == 'S')
      return 0;
    else
      return -2 + M_PI / 2;
  }
  double x1 = 0.5;
  double y1 = sqrt(3) / 2;
  if (s[i] == 'S'){
    double x2 = i;
    double y2 = 1.0;
    return -x2 - 1 + Dist(0, 0, x1, y1) + Dist(x1, y1, x2, y2); 
  }
  else{
    double xc    = i + 0.5;
    double yc    = 0.5;
    double h     = Dist(x1, y1, xc, yc);
    double alpha = atan2(y1 - yc, x1 - xc);
    double fi    = acos(0.5 / h);
    double x2    = xc + 0.5 * cos(alpha - fi);
    double y2    = yc + 0.5 * sin(alpha - fi);
    return -xc - 1 + Dist(0, 0, x1, y1) + Dist(x1, y1, x2, y2) + 0.5 * (alpha - fi - M_PI / 2);
  }
}
開發者ID:pocketzeroes,項目名稱:proekt,代碼行數:30,代碼來源:ConvexContour.c

示例4: FillRandomImg

void FillRandomImg(CSimpleImage& Image, int ImageNo)
{
   static bool Initialized = false;
   const static int NbImages = 2;
   static CSimpleImage Images[NbImages];
   static CImage<float> FloatImages[NbImages];

   //assert(ImageNo >= 0 && ImageNo < NbImages);

   if (!Initialized)
   {
      // Random image generation is time consuming
      // So we do it only once

      std::mt19937 Rand;   // Mersenne twister pseudo random number generator

      // Uniform distribution that can set all but the leftmost bit
      std::uniform_int_distribution<int> Dist(0, 0xFF);

      SSize Big = GetBiggestImage();

      for (int i = 0; i < NbImages; i++)
      {
         Images[i].Create(Big.Width, Big.Height, 1, SImage::S32);
         uint uByteWidth = Images[i].BytesWidth();
         for (uint y = 0; y < Images[i].Height; y++)
            for (uint b = 0; b < uByteWidth; b++)
               Images[i].Data(y)[b] = Dist(Rand);
      }


      std::normal_distribution<float> FloatDist(0, 1);

      for (int i = 0; i < NbImages; i++)
      {
         FloatImages[i].Create(Big.Width, Big.Height, 1, SImage::F32);
         for (uint y = 0; y < FloatImages[i].Height; y++)
            for (uint x = 0; x < FloatImages[i].Width; x++)
               FloatImages[i](x, y) = FloatDist(Rand);
      }

      Initialized = true;
   }

   uint uByteWidth = Image.BytesWidth();
   
   if (Image.Type == Image.F32)
   {
      for (uint y = 0; y < Image.Height; y++)
         memcpy(Image.Data(y), FloatImages[ImageNo].Data(y), uByteWidth);

      return;
   }

   for (uint y = 0; y < Image.Height; y++)
      memcpy(Image.Data(y), Images[ImageNo].Data(y), uByteWidth);
}
開發者ID:AntAgna,項目名稱:OpenCLIPP,代碼行數:57,代碼來源:RandomImage.cpp

示例5: GetParamCorner

void  cDistorBilin::Diff(ElMatrix<REAL> & aM,Pt2dr aP) const
{
    // InitEtatFromCorner(ToCoordGrid(aP));

    Pt2dr aPds;
    GetParamCorner(mCurCorner,aPds,ToCoordGrid(aP)); 
    const Pt2dr & aP00 =  Dist(mCurCorner+CamBilinCorn[0] ) ;
    const Pt2dr & aP10 =  Dist(mCurCorner+CamBilinCorn[1] ) ;
    const Pt2dr & aP01 =  Dist(mCurCorner+CamBilinCorn[2] ) ;
    const Pt2dr & aP11 =  Dist(mCurCorner+CamBilinCorn[3] ) ;


    Pt2dr aGx =    ((aP10-aP00)*aPds.y + (aP11-aP01)*(1-aPds.y))  / mStep.x;
    Pt2dr aGy =    ((aP01-aP00)*aPds.x + (aP11-aP10)*(1-aPds.x))  / mStep.y;

    aM.ResizeInside(2,2);
    SetCol(aM,0,aGx);
    SetCol(aM,1,aGy);

    // A conserver, verification par diff std
    if (0)
    {
        ElMatrix<REAL> aM2(2,2);
        DiffByDiffFinies(aM2,aP,euclid(mStep)/1e4);
        static double aDMax = 0;
        double aD = aM.L2(aM2);
        if (aD>aDMax)
        {
            aDMax = aD;
            std::cout << "DDDD " << aD << "\n";
        }
    }
    // InitEtatFromCorner(ToCoordGrid(aP));

}
開發者ID:jakexie,項目名稱:micmac-archeos,代碼行數:35,代碼來源:cCameraBilin.cpp

示例6:

void * LogMem::alloc(ulen len)
 {
  if( !TryAlign(len) ) return 0;
  
  if( ptr<lim )
    {
     ulen s=Dist(lim,mem_lim);
     
     if( len<=s )
       {
        void *ret=lim;
        
        lim+=len;
        
        return ret;
       }
       
     s=Dist(mem,ptr);  
     
     if( len<s )
       {
        cut=lim;
        lim=mem+len;
        
        return mem;
       }
       
     return 0;  
    }
    
  if( ptr>lim )  
    {
     ulen s=Dist(lim,ptr);
     
     if( len<s )
       {
        void *ret=lim;
        
        lim+=len;
        
        return ret;
       }
       
     return 0;  
    }
    
  ulen s=Dist(lim,mem_lim);
     
  if( len<s )
    {
     void *ret=lim;
        
     lim+=len;
        
     return ret;
    }
       
  return 0;  
 }
開發者ID:SergeyStrukov,項目名稱:CCore,代碼行數:59,代碼來源:Log.cpp

示例7: InitEtatFromCorner

Pt2dr cDistorBilin::Direct(Pt2dr aP) const
{
    InitEtatFromCorner(ToCoordGrid(aP));

    return   
             Dist(mCurCorner +CamBilinCorn[0] ) * mPds[0]
           + Dist(mCurCorner +CamBilinCorn[1] ) * mPds[1]
           + Dist(mCurCorner +CamBilinCorn[2] ) * mPds[2]
           + Dist(mCurCorner +CamBilinCorn[3] ) * mPds[3];
}
開發者ID:jakexie,項目名稱:micmac-archeos,代碼行數:10,代碼來源:cCameraBilin.cpp

示例8: Normal

void CBasePoly::Flip()
{
	for(uint32 i=0; i < m_Indices/2; i++ )
	{
		uint32 temp = m_Indices[i];
		m_Indices[i] = m_Indices[m_Indices-i-1];
		m_Indices[m_Indices-i-1] = temp;
	}

	Normal() = -Normal();
	Dist() = -Dist();
}
開發者ID:Joincheng,項目名稱:lithtech,代碼行數:12,代碼來源:BasePoly.cpp

示例9: Dist

void cDistorBilin::V_SetScalingTranslate(const double & aF,const Pt2dr & aPP)
{
   for (int aKY=0 ; aKY<= mNb.y ; aKY++)
   {
       for (int aKX=0 ; aKX<= mNb.x ; aKX++)
       {
           Dist(Pt2di(aKX,aKY)) = ( Dist(Pt2di(aKX,aKY))- aPP) / aF;
       }
   }
   mP0 = (mP0-aPP) / aF;
   mP1 = (mP1-aPP) / aF;
   mStep = mStep / aF;
}
開發者ID:jakexie,項目名稱:micmac-archeos,代碼行數:13,代碼來源:cCameraBilin.cpp

示例10: Normal

void CEditPoly::Flip()
{
	uint32		i, temp;

	for( i=0; i < m_Indices/2; i++ )
	{
		temp = m_Indices[i];
		m_Indices[i] = m_Indices[m_Indices-i-1];
		m_Indices[m_Indices-i-1] = temp;
	}

	Normal() = -Normal();
	Dist() = -Dist();
}
開發者ID:Joincheng,項目名稱:lithtech,代碼行數:14,代碼來源:EditPoly.cpp

示例11: gesture_caculate

//extern int spp_send(char* buf, int count);
static uint16_t gesture_caculate(int index, const int8_t* point)
{
  const int8_t *currentGesture = GestureData[index + gestureoffset];
  uint8_t gestureLength = GestureDataLength[index + gestureoffset];
  uint16_t *distance = distances + (MAX_GESTURES * index);
  // caculate with template
  uint16_t lastvalue = Dist(&currentGesture[0], point);
  
  if (count == MOVE_WINDOW)
  {
    distance[0] = lastvalue;
    for(int tindex = 1; tindex < gestureLength; tindex++)
    {
      distance[tindex] = distance[tindex - 1] + Dist(&currentGesture[tindex * 3], point);
    }
  }
  else
  {
    if (lastvalue > distance[0])
      lastvalue = distance[0];
    for(int tindex = 1; tindex < gestureLength; tindex++)
    {
      uint16_t local = Dist(&currentGesture[tindex * 3], point);
      uint16_t min = lastvalue;
      if (min > distance[tindex])
        min = distance[tindex];
      if (min > distance[tindex - 1])
        min = distance[tindex - 1];
      if (min > lastvalue)
        min = lastvalue;
      distance[tindex - 1] = lastvalue;
      lastvalue = local + min;
    }
    distance[gestureLength - 1] = lastvalue;
  }
#if 0
  for(int i = 0; i < gestureLength; i++)
  {
    PRINTF("%d ",distance[i]);
  }
  PRINTF("\n  ");
  for(int i = 1; i < gestureLength; i++)
  {
    PRINTF("%d ",distance[i] - distance[i-1]);
  }
  PRINTF("\n");
#endif
  return distance[gestureLength - 1]/(gestureLength + count/MOVE_STEP - 1);
}
開發者ID:Sowhat2112,項目名稱:KreyosFirmware,代碼行數:50,代碼來源:gesture.c

示例12: Index

bool CBasePoly::LoadBasePolyTBW( CAbstractIO& InFile )
{
	//load up all the vertices
	uint32 nNumVerts;
	InFile >> nNumVerts;

	m_Indices.SetSize( nNumVerts );

	for(uint32 nCurrVert = 0; nCurrVert < nNumVerts; nCurrVert++)
	{
		uint32 nIndex;
		InFile >> nIndex;

		Index(nCurrVert) = nIndex;
	}

	//now read in the plane data
	InFile >> Normal().x;
	InFile >> Normal().y;
	InFile >> Normal().z;

	InFile >> Dist();

	return true;
}
開發者ID:Joincheng,項目名稱:lithtech,代碼行數:25,代碼來源:BasePoly.cpp

示例13: while

 void PathPlanner::disconnectNodes(Node * path) {
     SearchSpaceNode * S;
     Node * temp;
     double distance;
     if (!path)
         return;
     S = searchspace;
     int numConnections = this->MAXNODES;
     while (S != NULL) {
         temp = path;
         while (temp != NULL) {
             distance = Dist(S->location, temp->pose.p);
             if (distance == 0)//S == temp->pose.p.position.x)// && distance !=0)
             {
                 S->children.pop_back();
                 bool t = removeNode(S->location);
                 numConnections--;
                 delete S;
             }
             temp = temp->next;
         }
         S = S->next;
     }
     searchspace = S;
     std::cout << "\n	--->>> NODES CONNECTED <<<---	" << numConnections;
     this->MAXNODES = numConnections; //searchspace->id;
 }
開發者ID:dhanhani,項目名稱:sspp,代碼行數:27,代碼來源:pathplanner.cpp

示例14: HF1

void cEqHomogFormelle::StdRepondere(ElPackHomologue & aPack,REAL aCoeff)
{
    cElHomographie H1 = HF1().HomCur();
    cElHomographie H2 = HF2().HomCur();
    ElDistRadiale_PolynImpair Dist(1e5,Pt2dr(0,0));
    if (DRF()) 
       Dist = DRF()->DistCur();

    for
    (
         ElPackHomologue::iterator it=aPack.begin();
         it!=aPack.end();
         it++
    )
    {
          Pt2dr aP1 = it->P1();
          Pt2dr aP2 = it->P2();
          if (mDRF)
          {
              aP1 = Dist.Direct(aP1);
              aP2 = Dist.Direct(aP2);
          }
          Pt2dr Ec = H1.Direct(Dist.Direct(it->P1())) - H2.Direct(Dist.Direct(it->P2()));

          REAL D = euclid(Ec);
         
          REAL Pds = 1 / (1 + ElSquare(D/aCoeff));
          it->Pds() = Pds;
    }
}
開發者ID:rpankka,項目名稱:micmac,代碼行數:30,代碼來源:phgr_eqhomog.cpp

示例15: PerfectMatching

GeomPerfectMatching::REAL GeomPerfectMatching::SolveComplete()
{
	if (node_num != node_num_max) { printf("ComputeCost() cannot be called before all points have been added!\n"); exit(1); }

	PointId p, q;
	int e = 0, E = node_num*(node_num-1)/2;
	PerfectMatching* pm = new PerfectMatching(node_num, E);
	for (p=0; p<node_num; p++)
	{
		for (q=p+1; q<node_num; q++)
		{
			pm->AddEdge(p, q, Dist(p, q));
		}
	}
	pm->options = options;
	pm->Solve();
	for (p=0; p<node_num; p++)
	{
		for (q=p+1; q<node_num; q++)
		{
			if (pm->GetSolution(e++))
			{
				matching[p] = q;
				matching[q] = p;
			}
		}
	}
	delete pm;
	return ComputeCost(matching);
}
開發者ID:ChrisWhiten,項目名稱:VideoParser,代碼行數:30,代碼來源:GPMmain.cpp


注:本文中的Dist函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。