本文整理汇总了C++中Skeleton::potentiel方法的典型用法代码示例。如果您正苦于以下问题:C++ Skeleton::potentiel方法的具体用法?C++ Skeleton::potentiel怎么用?C++ Skeleton::potentiel使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Skeleton
的用法示例。
在下文中一共展示了Skeleton::potentiel方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
int main(int argc,char **argv) {
int line1Blocks=500,line2Blocks=450,armLength=15;
int maxTimeSimulation=30000,iAngle=90;
double angle;
if (argc>1) {
line1Blocks = atoi(argv[1]);
cout << "line1Blocks=" << line1Blocks << endl;
}
if (argc>2) {
line2Blocks = atoi(argv[2]);
cout << "line2Blocks=" << line2Blocks << endl;
}
if (argc>3) {
armLength = atoi(argv[3]);
cout << "armLength=" << armLength << endl;
}
if (argc>4) {
iAngle = atoi(argv[4]);
cout << "iangle=" << iAngle << endl;
}
angle = iAngle*M_PI/180.0;
if (argc>5) {
maxTimeSimulation = atoi(argv[5]);
cout << "maxTimeSimulation=" << maxTimeSimulation << endl;
}
int areaLx = 32+2*armLength,
areaLy = areaLx;
int cameraDist = 25.0*sqrt(areaLx*areaLx+areaLy*areaLy)/tan(50.0*M_PI/180.0);
int srcDist = 25.0*sqrt(areaLx*areaLx+areaLy*areaLy)/tan(45.0*M_PI/180.0);
Vecteur Origine(areaLx/2.0-armLength,areaLy/2.0+armLength,0);
Vecteur P(Origine[0]+2*armLength,Origine[1],0);
Vecteur Q(areaLx/2.0,P[1]-5,0);
Vecteur R(Q[0]-(2*armLength-5)*cos(angle),Q[1]-(2*armLength-5)*sin(angle),0);
cout << "O=" << Origine << endl;
cout << "P=" << P << endl;
cout << "Q=" << Q << endl;
Skeleton *S = new SkelLine(Origine,P,3,-0.2);
float *grid = new float[areaLx * areaLy], *ptr=grid;
int i=areaLx*areaLy;
while (i--) {
*ptr++=0.0f;
}
int ix,iy;
for (iy=0; iy<areaLy; iy++) {
for (ix=0; ix<areaLx; ix++) {
Origine.set(ix,iy,0);
grid[iy*areaLx+ix] = S->potentiel(Origine);
}
}
float maxi=0,s;
int xmaxi,ymaxi;
for (i=0; i<line1Blocks; i++) {
maxi=0;
for (iy=0; iy<areaLy; iy++) {
for (ix=0; ix<areaLx; ix++) {
s=grid[iy*areaLx+ix];
if (s>=maxi) {
xmaxi = ix;
ymaxi = iy;
maxi = s;
}
}
}
grid[ymaxi*areaLx+xmaxi]=-1;
}
cout << maxi << endl;
char titre[1024];
sprintf(titre,"configMakeLine%d_%d_%d.xml",line1Blocks,line2Blocks,armLength);
ofstream fout;
fout.open(titre);
fout << "<?xml version=\"1.0\" standalone=\"no\" ?>"<< endl;
fout << "<world gridSize=\""<< areaLx << "," << areaLy << "\" windowSize=\"1800,900\" maxSimulationTime=\"" << maxTimeSimulation << "mn\">" << endl;
fout << "<camera target=\""<< areaLx*25.0/2.0 << "," << areaLy*25.0/2.0 << ",0\" directionSpherical=\"0,38," << cameraDist << "\" angle=\"50\"/>" << endl;
fout << "<spotlight target=\""<< areaLx*25.0/2.0 << "," << areaLy*25.0/2.0 << ",0\" directionSpherical=\"-30,50," << srcDist << "\" angle=\"45\"/>" << endl;
fout << "<blockList color=\"0,255,0\" blocksize=\"25.0,25.0,11.0\">" << endl;
for (iy=0; iy<areaLy; iy++) {
fout << "<blocksLine line=\"" << areaLy+1-iy << "\" values=\"";
for (ix=0; ix<areaLx; ix++) {
fout << (grid[ix+iy*areaLx]==-1)?1:0 ;
//fout << grid[ix+iy*areaLx];
}
fout << "\"/>" << endl;
}
fout << "</blockList>\n<targetGrid>" << endl;
delete S;
S = new SkelLine(Q,R,3,-0.2);
ptr=grid;
i=areaLx*areaLy;
//.........这里部分代码省略.........