当前位置: 首页>>代码示例>>C++>>正文


C++ Pos::FlipV方法代码示例

本文整理汇总了C++中Pos::FlipV方法的典型用法代码示例。如果您正苦于以下问题:C++ Pos::FlipV方法的具体用法?C++ Pos::FlipV怎么用?C++ Pos::FlipV使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Pos的用法示例。


在下文中一共展示了Pos::FlipV方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: findHalfStencil

void ModButterfly::findHalfStencil(RgbVertexC& v, Pos& pos, vector<RgbVertexC>& stencil)
{
	assert(v.vp() == pos.v);
	
	Pos p;
	p = pos;
	p.FlipV();
	RgbVertexC v2 = RgbVertexC(*v.m,*v.rgbInfo,p.v);
	
	int maxlevel = v.getLevel();
	if (maxlevel < v2.getLevel()) 
		maxlevel = v2.getLevel();
	
	p = pos;
	rotate(v,p,2);
	RgbVertexC vtemp = move(v,p,maxlevel); 
	stencil.push_back(vtemp);

#ifndef NDEBUG
	Pos ptemp;
	ptemp = pos;
	ptemp.FlipV();
	rotate(v2,ptemp,2);
	RgbVertexC vtemp2 = move(v2,ptemp,maxlevel);
	assert(vtemp.index == vtemp2.index);
#endif

	p = pos;
	rotate(v,p,4);
	stencil.push_back(move(v,p,maxlevel));

	p = pos;
	p.FlipV();
	rotate(v2,p,4);
	stencil.push_back(move(v2,p,maxlevel));
}
开发者ID:Booley,项目名称:nbis,代码行数:36,代码来源:modButterfly.cpp

示例2: move

ModButterfly::RgbVertexC ModButterfly::move(RgbVertexC& v, Pos& pos, int level)
{
	assert(v.vp() == pos.v);
	assert(level >= v.getLevel());
	int vl = level;
	RgbVertexC lastv;
	do 
	{
		pos.FlipV();
		lastv = RgbVertexC(*v.m,*v.rgbInfo,pos.v);
		if (lastv.getLevel() <= vl)
			break; // no need to continue, in fact a rotation of exactly 6 can be impossible in some cases
		rotate(lastv,pos,6);
		pos.FlipF();
		
		assert(lastv.getLevel() > vl);
	} while (lastv.getLevel() > vl);
	
	return RgbVertexC(*v.m,*v.rgbInfo,pos.v);
}
开发者ID:Booley,项目名称:nbis,代码行数:20,代码来源:modButterfly.cpp

示例3: computeExtraordinary

ModButterfly::Point ModButterfly::computeExtraordinary(RgbVertexC& v, Pos& pos)
{
	int rank;
	if (v.getLevel() == 0) 
		rank = baseArity(v);
	else
		rank = 4;
	
	vector<Point> points;
	vector<double> coeff;
	computeExtraordinaryPattern(coeff,rank);
	points.reserve(rank+1);
	points.push_back(v.getCoord());
	
	if (!v.getIsBorder())
	{
		int angle = rank * 2;
		do
		{
			pos.FlipV();
			points.push_back(pos.v->P());
			assert(pos.v != v.vp());
			pos.FlipV();
			rotate(v,pos,2);
			angle -= 2;
			assert (angle >= 0);
		} 
		while (angle != 0);
	}
	else
	{
		Pos pos2 = pos;
		// Border
		int angle = (rank-1) * 2;
		do
		{
			pos.FlipV();
			points.push_back(pos.v->P());
			assert(pos.v != v.vp());
			pos.FlipV();
			assert(pos.v == v.vp());
			rotate(v,pos,2);
			angle -= 2;
			assert (angle >= 0);
		} 
		while ((!pos.IsBorder()) && (angle != 0));
		
		pos.FlipV();
		points.push_back(pos.v->P());
		assert(pos.v != v.vp());
		pos.FlipV();
		
		assert(angle >= 0);
		vector<Point> pointsreverse;

		pos2.FlipF();
		rotate(v,pos2,2);
		angle -= 2;
		if ((!pos2.IsBorder()) && (angle != 0))
		{
			do
			{
				pos2.FlipV();
				pointsreverse.push_back(pos2.v->P());
				assert(pos2.v != v.vp());
				pos2.FlipV();
				assert(pos2.v == v.vp());
				rotate(v,pos2,2);
				angle -= 2;
				assert (angle >= 0);
			} 
			while ((!pos2.IsBorder()) && (angle != 0));
		}
		assert(angle == 0);

		pos.FlipV();
		points.push_back(pos.v->P());
		assert(pos.v != v.vp());
		pos.FlipV();
		
		for(int i=pointsreverse.size()-1;i>= 0; i--)
			points.push_back(pointsreverse[i]);
		
	}

	assert(points.size() == (unsigned int)(rank + 1));
	assert(points.size() == coeff.size());
	
	Point acc = Point(0.0,0.0,0.0);
	
	for (int i=0; i<rank+1; i++)
	{
		Point tmp = points[i] * coeff[i];
		acc += tmp;
	}
	
	return acc;
}
开发者ID:Booley,项目名称:nbis,代码行数:98,代码来源:modButterfly.cpp


注:本文中的Pos::FlipV方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。