出现无法读取内存情况怎么办?
这个程序做的是一个逾渗的程序,请问一下各位大佬,这种的情况改怎么找到错误出现的地方呀?#include<iostream>
#include<ctime>
#include<cstdlib>
#include<fstream>
#include<cmath>
#include<iomanip>
#include<time.h>
#define DELFLAG -1//用来标记已经删除的粒子位置
using namespace std;
const double PI=3.14;
const int N=8;//非凸多边形的边数
const double L=50.0;//容器边长
ofstream outfile("F:\\全局坐标系下多边形的顶点坐标");
ofstream outfile1("F:\\Density-probility非周期边界条件");
ofstream outfile2("F:\\Density-probility周期边界条件");
ofstream outfile3("F:\\T-Density-probility非周期边界条件");
ofstream outfile4("F:\\T-Density-probility周期边界条件");
class point
{
public:
double x,y,z;
point()
:x(0),y(0),z(0)
{
}
};
class trianle//三角形类
{
public:
point *vertexs;//三角形顶点类
point *ProjectionVertexs;//三角形顶点的投影
trianle();
~trianle();
};
class polygon
{
public:
point polar_center;//极心坐标
double *polar_radius;//极径
double *polar_angle;//极角
point *PolygonVertexs;//多边形的顶点
trianle *DivideTriangles;//从多边形划分出的三角形
double a_fa,bei_ta,ga_ma;
point NoramalVector;//平面法向量;
polygon();
~polygon();
};
trianle::trianle()
{
vertexs=new point;
ProjectionVertexs=new point;//三角形顶点的投影
}
trianle::~trianle()
{
delete[] vertexs;
delete[] ProjectionVertexs;
}
polygon::polygon()
{
polar_center.x=0;polar_center.y=0;polar_center.z=0;
polar_angle=new double;
polar_radius=new double;
PolygonVertexs=new point;
DivideTriangles=new trianle;
a_fa=0.0;
bei_ta=0.0;
ga_ma=0.0;
NoramalVector.x=0.0;
NoramalVector.y=0.0;
NoramalVector.z=0.0;
}
polygon::~polygon()
{
delete[] polar_angle;
delete[] polar_radius;
delete[] PolygonVertexs;
delete[] DivideTriangles;
}
class PolygonsPercalation
{
private:
enum {num_rows=1};//表示粒子的密度组数
int N1;//不同粒子密度下的粒子数
double density;//每组粒子数对应的密度
double unperiodpercolationprobability; //每组density下对应非周期边界的percolation概率=T1/T;
double periodpercolationprobability;//每组Vf下对应周期边界的percolation概率=T2/T;
polygon* A;//在给定的体积分数下的原始球的类,记为A类
polygon* B;//将A类中与容器边壁相交的粒子记录到B类中,B类是一个活动的类,以后粒子间相交,也记录到B类中
polygon* A1;//A1=A-B;即将A类中与B类相同的粒子删除,剩下A类中的粒子记为A1类,也为活动的类
polygon* AuxB;//从A类中找出与其中一个边壁相交的B类粒子的周期性补偿粒子,记为AuxB
public:
PolygonsPercalation();
~PolygonsPercalation();
void GetDate();//获取相关数据
void GeneratePolygon(polygon&);//生成非凸多边形
void GetTheLocatedCoordinate(polygon&);//计算局部坐标系下的坐标
bool delete_convex_polygon(polygon&);//剔除凸多边形
void RandomDispersion(int&);//将获取的N个多边形随机分布在容器中
void DividePolygonToTriangles(polygon&);//将多边形划分成三角形的函数
void extrapolate_the_polygon_to_3_D(polygon&);//将非凸多边形扩展至三维空间中,并确定平面的法向量
void PercolationSimulation();//逾渗的模拟
bool IntersectParticleToPlane(polygon&, double, double, double, double); //判断粒子与容器的面相交
void DetectPercolation_CurrplaneToParticles(int&, double, double, double, double, bool&, bool&); //考察当前的三个(左,上,前)面和粒子相交问题
void PeriodAux(polygon&, int&);
bool PercolationDectect(double, double, double, double, polygon*, polygon*, int&, int&, int&, bool&); //检测粒子间是否percolation,以及B类粒子和对应的面是否有相交
bool IntersectParticlesJudegmentInaccurately(polygon&, polygon&); //判断两个粒子相交粗糙判定
bool IntersectParticlesJudegementAccurately(polygon&, polygon&);//两不共面三角形相交精确判定
};
PolygonsPercalation::PolygonsPercalation()
{
A=new polygon;
B=new polygon;
A1=new polygon;
AuxB=new polygon;
}
PolygonsPercalation::~PolygonsPercalation()
{
delete [] A;
delete [] B;
delete [] A1;
delete [] AuxB;
}
void PolygonsPercalation::GetTheLocatedCoordinate(polygon& P)//计算局部坐标系下的顶点坐标
{
//***********************************************************************计算在局部坐标系下多边形的顶点坐标
for(int t=0;t<N;t++)
{
P.PolygonVertexs.x= P.polar_radius*cos( P.polar_angle);
P.PolygonVertexs.y= P.polar_radius*sin( P.polar_angle);
P.PolygonVertexs.z=0;
}
}
bool PolygonsPercalation::delete_convex_polygon(polygon& P)//排除凸多边形
{
double flag;//用于判定多边形凹凸性的参数
for(int i=0;i<N;i++)
{
int a=i+1,b=i+2;
if(i!=(N-2)&&i!=(N-1))
{
flag=( P.PolygonVertexs.x- P.PolygonVertexs.x)*( P.PolygonVertexs.y- P.PolygonVertexs.y)-
( P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y);
}
if(i==(N-2))
{
flag=(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y)-
(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y);
}
if(i==(N-1))
{
flag=(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y)-
(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y);
}
}
if(flag<0||flag<0||flag<0||flag<0||flag<0||flag<0||flag<0||flag<0||flag<0)
return (1);//多边形为非凸时返回为1
else
return 0;//为凸边形时返回为0
}
void PolygonsPercalation::GeneratePolygon(polygon& P)
{
double min_L,max_L;//容器边的最小,最大值
double max_yita=1,min_yita=0,min_A=0.5,average_A=1;//min_A,average_A是粒子的最小和平均粒径
double max_yita1=1,min_yita1=0;//生成极角和极径的参数yita
double temp;
min_L=-0.5*L;max_L=0.5*L;
P.polar_center.x=((((float)rand()/RAND_MAX))*(max_L-min_L)+min_L);//随机生成在x轴的极心坐标
P.polar_center.y=((((float)rand()/RAND_MAX))*(max_L-min_L)+min_L);//随机生成在y轴的极心坐标
P.polar_center.z=((((float)rand()/RAND_MAX))*(max_L-min_L)+min_L);//随机生成在z轴的极心坐标
for(int i=0;i<N;i++)//生成极心和极角
{
P.polar_angle=((((float)rand()/RAND_MAX))*(max_yita-min_yita)+min_yita)*(2*PI);
P.polar_radius=average_A+(2*((((float)rand()/RAND_MAX))*(max_yita-min_yita)+min_yita)-1)+min_A;
}
for(int i=0;i<N;i++)//将随机生成的极角按照从小到大的顺序排列
{
for(int j=0;j<N-i-1;j++)
{
if(P.polar_angle>P.polar_angle)
{temp=P.polar_angle;P.polar_angle=P.polar_angle;P.polar_angle=temp;}
}
}
//**********************************************************************随机地生成三个欧拉角
double max_a_fa=PI,min_a_fa=-PI;
double max_ga_ma=PI,min_ga_ma=-PI;
double max_bei_ta=PI,min_bei_ta=0;
P.a_fa=((((float)rand()/RAND_MAX))*(max_a_fa-min_a_fa)+min_a_fa);
P.ga_ma=((((float)rand()/RAND_MAX))*(max_ga_ma-min_ga_ma)+min_ga_ma);
P.bei_ta=((((float)rand()/RAND_MAX))*(max_bei_ta-min_bei_ta)+min_bei_ta);
}
void PolygonsPercalation::DividePolygonToTriangles(polygon& P)
{
for(int i=0;i<N;i++)
{
int a=i+1;
if(i!=(N-1))
{
P.DivideTriangles.vertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.vertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.vertexs.z=P.PolygonVertexs.z;
P.DivideTriangles.vertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.vertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.vertexs.z=P.PolygonVertexs.z;
P.DivideTriangles.vertexs.x=P.polar_center.x;
P.DivideTriangles.vertexs.y=P.polar_center.y;
P.DivideTriangles.vertexs.z=P.polar_center.z;
//向XOY面投影的三角形顶点坐标
P.DivideTriangles.ProjectionVertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.ProjectionVertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.ProjectionVertexs.z=0;
P.DivideTriangles.ProjectionVertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.ProjectionVertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.ProjectionVertexs.z=0;
P.DivideTriangles.ProjectionVertexs.x=P.polar_center.x;
P.DivideTriangles.ProjectionVertexs.y=P.polar_center.y;
P.DivideTriangles.ProjectionVertexs.z=0;
}
if(i==(N-1))
{
P.DivideTriangles.vertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.vertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.vertexs.z=P.PolygonVertexs.z;
P.DivideTriangles.vertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.vertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.vertexs.z=P.PolygonVertexs.z;
P.DivideTriangles.vertexs.x=P.polar_center.x;
P.DivideTriangles.vertexs.y=P.polar_center.y;
P.DivideTriangles.vertexs.z=P.polar_center.z;
//向XOY面投影的三角形顶点坐标
P.DivideTriangles.ProjectionVertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.ProjectionVertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.ProjectionVertexs.z=0;
P.DivideTriangles.ProjectionVertexs.x=P.PolygonVertexs.x;
P.DivideTriangles.ProjectionVertexs.y=P.PolygonVertexs.y;
P.DivideTriangles.ProjectionVertexs.z=0;
P.DivideTriangles.ProjectionVertexs.x=P.polar_center.x;
P.DivideTriangles.ProjectionVertexs.y=P.polar_center.y;
P.DivideTriangles.ProjectionVertexs.z=0;
}
}
}
void PolygonsPercalation::extrapolate_the_polygon_to_3_D(polygon& P)//将局部坐标系下的顶点坐标外推到三维空间中
{
//***********************************************************************计算在全局坐标系下的坐标,并将其输出到文件中"
for(int k=0;k<N;k++)
{
P.PolygonVertexs.x=(cos(P.ga_ma)*cos(P.bei_ta))*P.PolygonVertexs.x+((-sin(P.ga_ma)*cos(P.a_fa))-cos(P.ga_ma)*sin(P.bei_ta)*sin(P.a_fa))*P.PolygonVertexs.y
+(sin(P.ga_ma)*sin(P.a_fa)-cos(P.ga_ma)*sin(P.bei_ta)*cos(P.a_fa))*P.PolygonVertexs.z+P.polar_center.x;
//**********************************************************************************计算在全局坐标系下的x坐标
P.PolygonVertexs.y=(sin(P.ga_ma)*cos(P.bei_ta))*P.PolygonVertexs.x+(cos(P.ga_ma)*cos(P.ga_ma)-sin(P.ga_ma)*sin(P.bei_ta)*sin(P.a_fa))*P.PolygonVertexs.y+
(-cos(P.ga_ma)*sin(P.a_fa)-sin(P.ga_ma)*sin(P.bei_ta)*cos(P.a_fa))*P.PolygonVertexs.z+P.polar_center.y;
//**********************************************************************************计算在全局坐标系下的y坐标
P.PolygonVertexs.z=sin(P.bei_ta)*P.PolygonVertexs.x+(cos(P.bei_ta)*sin(P.a_fa))*P.PolygonVertexs.y+
(cos(P.bei_ta)*cos(P.a_fa))*P.PolygonVertexs.z+P.polar_center.z;
//**********************************************************************************计算在全局坐标系下的z坐标
}
/*
for(int k=0;k<N;k++)
{
int a=k+1;
if(a==N)
{
outfile<<"polygon{3,<"<<PolygonVertexs.x<<","<<PolygonVertexs.y<<","<<PolygonVertexs.z<<">, <"
<<polar_center.x<<","<<polar_center.y<<","<<polar_center.z<<">, <"
<<PolygonVertexs.x<<","<<PolygonVertexs.y<<","<<PolygonVertexs.z<<">}"<<endl;
}
else if(a!=N)
{
outfile<<"polygon{3,<"<<PolygonVertexs.x<<","<<PolygonVertexs.y<<","<<PolygonVertexs.z<<">, <"
<<polar_center.x<<","<<polar_center.y<<","<<polar_center.z<<">, <"
<<PolygonVertexs.x<<","<<PolygonVertexs.y<<","<<PolygonVertexs.z<<">}"<<endl;
}
}*/
double mo_liang;
//*********************************************************************获取平面的法向量
P.NoramalVector.x=(P.PolygonVertexs.y-P.PolygonVertexs.y)*(P.PolygonVertexs.z-P.PolygonVertexs.z)-
(P.PolygonVertexs.z-P.PolygonVertexs.z)*(P.PolygonVertexs.y-P.PolygonVertexs.y);
P.NoramalVector.y=(P.PolygonVertexs.z-P.PolygonVertexs.z)*(P.PolygonVertexs.x-P.PolygonVertexs.x)-
(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.z-P.PolygonVertexs.z);
P.NoramalVector.z=(P.PolygonVertexs.x-P.PolygonVertexs.x)*(P.PolygonVertexs.y-P.PolygonVertexs.y)-
(P.PolygonVertexs.y-P.PolygonVertexs.y)*(P.PolygonVertexs.x-P.PolygonVertexs.x);
mo_liang=sqrt(pow(P.NoramalVector.x,2)+pow(P.NoramalVector.y,2)+pow(P.NoramalVector.z,2));
P.NoramalVector.x/=mo_liang;
P.NoramalVector.y/=mo_liang;
P.NoramalVector.z/=mo_liang;
}
void PolygonsPercalation::GetDate()
{
cout<<"请输入15组不同的容器中颗粒密度"<<endl;
for(int i=0;i<num_rows;i++)
{
cin>>density;//输入容器中颗粒的密度
}
}
void PolygonsPercalation::PercolationSimulation()
{
for(int i=0;i<num_rows;i++)
{
double T=0.0; //程序循环的次数,主要为了计算percolation probability
double T1=0.0; //记录非周期边界条件下的T次循环中达到percolation的循环次数
double T2=0.0; //记录周期边界条件下的T次循环中达到percolation的循环次数
N1=int(density*pow(L,3));//int()强制类型转换
while(T<200)
{
bool valid_1_rightplane=false; //bool型变量,申明粒子与非周期右边壁不相交
bool valid_2_rightplane=false; //bool型变量,申明粒子与周期右边壁不相交
bool valid_1_upplane=false;//bool型变量,申明粒子与非周期上边壁不相交
bool valid_2_upplane=false;//bool型变量,申明粒子与周期上边壁不相交
bool valid_1_frontplane=false;//bool型变量,申明粒子与非周期前边壁不相交
bool valid_2_frontplane=false;//bool型变量,申明粒子与周期前边壁不相交
RandomDispersion(N1); //先在容器中随机分布粒子,粒子间允许重叠发生
//考察容器的右边面是否有粒子与其构成percolation
DetectPercolation_CurrplaneToParticles(N1,1.0, 0.0, 0.0, -0.5*L, valid_1_rightplane, valid_2_rightplane);
if (valid_2_rightplane==false)//表明右边面无效,则需要考察另外一个面,即上边面
{
//考察容器的上边面是否有粒子与其构成percolation
cout<<"Enter testing UpPlane!!!!!!"<<endl;
DetectPercolation_CurrplaneToParticles(N1, 0.0, 0.0, 1.0,-0.5*L, valid_1_upplane, valid_2_upplane);
}
if(valid_2_rightplane==false && valid_2_upplane==false)
{
//考察容器的前边面是否有粒子与其构成percolation
cout<<"Enter testing FrontPlane!!!!!!"<<endl;
DetectPercolation_CurrplaneToParticles(N1,0.0, 1.0, 0.0,-0.5*L, valid_1_frontplane, valid_2_frontplane);
}
if (valid_1_rightplane==true || valid_1_upplane==true || valid_1_frontplane==true)
{
cout<<"Successful!!!!!!!!"<<endl;
T1++;
}
if (valid_2_rightplane==true || valid_2_upplane==true || valid_2_frontplane==true)
{
cout<<"periodic boundary condtions Successful!!!!!!!!"<<endl;
T2++;
}
cout<<T<<endl;
T++;
if (((int)T%10)==0)//这个条件语句是为了得到模拟次数与渗流概率的对应关系
{
unperiodpercolationprobability=T1/T; //计算非周期边界条件下的percolation概率
periodpercolationprobability=T2/T; //计算周期边界条件下的percolation概率
outfile3<<"T="<<T<<endl<<"density="<<density<<" "<<unperiodpercolationprobability<<endl;
outfile4<<"T="<<T<<endl<<"density="<<density<<" "<<periodpercolationprobability<<endl;
}
}
unperiodpercolationprobability=T1/T; //计算非周期边界条件下的percolation概率
periodpercolationprobability=T2/T; //计算周期边界条件下的percolation概率
outfile1<<density<<" "<<unperiodpercolationprobability<<endl;
outfile2<<density<<" "<<periodpercolationprobability<<endl;
}
}
void PolygonsPercalation::RandomDispersion(int& N1)
{
int T;
for(int k=0;k<N1;k++)
{
do
{
GeneratePolygon(A);
GetTheLocatedCoordinate(A);
}while(delete_convex_polygon(A)==0);
extrapolate_the_polygon_to_3_D(A);
DividePolygonToTriangles(A);
}
}
void PolygonsPercalation::DetectPercolation_CurrplaneToParticles (int& N2, double a0, double b0, double c0, double d0, bool& valplane1, bool& valplane2)
{
int currb_count=0; //记录添加到B类中的粒子
int a1_count=0; //记录添加到A1类中的粒子:A1=A-B
bool currplane=false; //考察当前的面是否有粒子与其相交
bool parperco=false; //bool型变量,申明当前的面与粒子间不发生渗流
int auxb_count=0; //记录添加到AuxB类中的粒子数量
for(int i=0;i<N2;i++)//然后判断A类中粒子是否与容器边壁相交,若相交,记录相交的粒子作为B类
{
if(IntersectParticleToPlane(A,a0,b0,c0,d0)==true)
{
currplane=true; //表面有粒子与当前的面相交,那么该面可以继续考察
B=A;
PeriodAux(B, auxb_count);
currb_count++;
}
else
{
A1=A; //将与边壁不相交的粒子记为A1类
a1_count++;
}
}
if (currplane==true)//表示currB类中存在粒子,即A类中存在粒子与当前的面相交
{
parperco=PercolationDectect(a0, b0, c0, d0+L, B, A1, currb_count, a1_count, auxb_count, valplane1); //判断B类中是否有粒子与当前面的对应面相交,若有则percolation成立,parperco=true;反之,parperco=false.
if (parperco==true)//表示当前的面与粒子间发生percolation,该考察面成立
{
valplane2=true; //记录该面有效
}
else
valplane2=false; //表明当前的考察面无法达到percolation,即无效
}
else
valplane2=false;//表明A类中没有粒子与当前的考察面相交,即无法达到percolation
}
bool PolygonsPercalation::IntersectParticleToPlane(polygon& oc, double a, double b, double c, double d)//判断粒子与面是否相交
{
double DistanceWithDirection;//有方向的距离
if(b==1.0&&a==0&&c==0)
{
for(int i=0;i<N;i++)
{
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y-d)*b+oc.DivideTriangles.vertexs.z*c;
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y-d)*b+oc.DivideTriangles.vertexs.z*c;
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y-d)*b+oc.DivideTriangles.vertexs.z*c;
if(DistanceWithDirection>0&&DistanceWithDirection>0&&DistanceWithDirection>0)
continue;//三角形位于坐标面的同侧,不相交继续执行
if(DistanceWithDirection<0&&DistanceWithDirection<0&&DistanceWithDirection<0)
continue;//三角形位于坐标面的同侧,不相交继续执行
else
return true;//其他情况,即DiStanceWIthDirection三个正负不同,或者全为0,返回为真
}
return false;//所有的多边形与坐标面都不相交返回为假
}
if(a==1&&b==0&&c==0)
{
for(int i=0;i<N;i++)
{
DistanceWithDirection=(oc.DivideTriangles.vertexs.x-d)*a+(oc.DivideTriangles.vertexs.y)*b+oc.DivideTriangles.vertexs.z*c;
DistanceWithDirection=(oc.DivideTriangles.vertexs.x-d)*a+(oc.DivideTriangles.vertexs.y)*b+oc.DivideTriangles.vertexs.z*c;
DistanceWithDirection=(oc.DivideTriangles.vertexs.x-d)*a+(oc.DivideTriangles.vertexs.y)*b+oc.DivideTriangles.vertexs.z*c;
if(DistanceWithDirection>0&&DistanceWithDirection>0&&DistanceWithDirection>0)
continue;
if(DistanceWithDirection<0&&DistanceWithDirection<0&&DistanceWithDirection<0)
continue;
else
return true;
}
return false;
}
if(c==1&&a==0&&b==0)
{
for(int i=0;i<N;i++)
{
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y)*b+(oc.DivideTriangles.vertexs.z-d)*c;
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y)*b+(oc.DivideTriangles.vertexs.z-d)*c;
DistanceWithDirection=oc.DivideTriangles.vertexs.x*a+(oc.DivideTriangles.vertexs.y)*b+(oc.DivideTriangles.vertexs.z-d)*c;
if(DistanceWithDirection>0&&DistanceWithDirection>0&&DistanceWithDirection>0)
continue;
if(DistanceWithDirection<0&&DistanceWithDirection<0&&DistanceWithDirection<0)
continue;
else
return true;
}
return false;
}
}
void PolygonsPercalation::PeriodAux(polygon& oc,int& aux_count)
{
int curraux_count=0; //记录当前考察的粒子需要周期性补偿几个粒子数量
point* curraux; //记录需要周期性补偿的粒子
curraux=new point;
bool I1=1, I2=1, I3=1, I4=1, I5=1, I6=1; //粒子与立方体6个面(1,2,3,4,5,6)相交的变量
I1=IntersectParticleToPlane(oc, 0.0, 1.0, 0.0, 0.5*L);
I2=IntersectParticleToPlane(oc, 0.0, 1.0, 0.0, -0.5*L);
I3=IntersectParticleToPlane(oc, 1.0, 0.0, 0.0, -0.5*L);
I4=IntersectParticleToPlane(oc, 1.0, 0.0, 0.0, 0.5*L);
I5=IntersectParticleToPlane(oc, 0.0, 0.0, 1.0, -0.5*L);
I6=IntersectParticleToPlane(oc, 0.0, 0.0, 1.0, 0.5*L);
if(I2==1 && I3==0 && I4==0 && I5==0 && I6==0)//如果粒子只与面2相交,补偿1个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux_count=1;
}
else if(I3==1 && I1==0 && I2==0 && I5==0 && I6==0)//如果粒子只与面3相交,补偿1个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux_count=1;
}
else if(I5==1 && I1==0 && I2==0 && I3==0 && I4==0)//如果粒子只与面5相交,补偿1个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux_count=1;
}
else if(I1==1 && I3==1 && I5==0 && I6==0)//如果粒子只与面2和面3相交A1E1,补偿3个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux_count=3;
}
else if(I2==1 && I3==1 && I5==0 && I6==0)//如果粒子只与面1和面3相交B1F1,补偿3个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux_count=3;
}
else if(I2==1 && I4==1 && I5==0 && I6==0)//如果粒子只与面2和面4相交C1G1,补偿3个附加球
{
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux_count=3;
}
else if(I1==1 && I5==1 && I3==0 && I4==0)//如果粒子只与面1和面5相交A1D1,补偿3个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z-L;
curraux_count=3;
}
else if(I3==1 && I5==1 && I1==0 && I2==0)//如果粒子只与面3和面5相交A1B1,补偿3个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux_count=3;
}
else if(I2==1 && I5==1 && I3==0 && I4==0)//如果粒子只与面2和面5相交B1C1,补偿3个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z-L;
curraux_count=3;
}
else if(I4==1 && I5==1 && I1==0 && I2==0)//如果粒子只与面4和面5相交C1D1,补偿3个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux_count=3;
}
else if(I3==1 && I6==1 && I1==0 && I2==0)//如果粒子只与面3和面6相交E1F1,补偿3个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux_count=3;
}
else if(I2==1 && I6==1 && I3==0 && I4==0) //如果粒子只与面2和面6相交F1G1,补偿3个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z+L;
curraux_count=3;
}
else if(I1==1 && I3==1 && I5==1)//如果粒子与面1,面3和面5相交类似于角A,补偿7个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.y=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z-L;
curraux_count=7;
}
else if(I2==1 && I3==1 && I5==1)//如果粒子与面2,面3和面5相交类似于角B1,补偿7个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux_count=7;
}
else if(I2==1 && I4==1 && I5==1)//如果粒子与面2,面4和面5相交类似于角C1,补偿7个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z-L;
curraux_count=7;
}
else if(I1==1 && I4==1 && I5==1)//如果粒子与面1,面4和面5相交类似于角D1,补偿7个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z-L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z-L;
curraux_count=7;
}
else if(I1==1 && I3==1 && I6==1)//如果粒子与面1,面3和面6相交类似于角E1,补偿7个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y+L;
curraux.z=oc.polar_center.z+L;
curraux_count=7;
}
else if(I2==1 && I3==1 && I6==1)//如果粒子与面2,面3和面6相交类似于角F1,补偿7个附加球
{
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x-L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z+L;
curraux_count=7;
}
else if(I2==1 && I4==1 && I6==1)//如果粒子与面2,面4和面6相交类似于角G1,补偿7个附加球
{
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y;
curraux.z=oc.polar_center.z+L;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z;
curraux.x=oc.polar_center.x+L;
curraux.y=oc.polar_center.y-L;
curraux.z=oc.polar_center.z+L;
curraux_count=7;
}
for(int k=0;k<curraux_count;k++)
{
AuxB.polar_center.x=curraux.x;
AuxB.polar_center.y=curraux.y;
AuxB.polar_center.z=curraux.z;
AuxB.a_fa=oc.a_fa;
AuxB.bei_ta=oc.bei_ta;
AuxB.ga_ma=oc.ga_ma;
for(int i=0;i<N;i++)
{
AuxB.polar_angle=oc.polar_angle;
AuxB.polar_radius=oc.polar_radius;
}
GetTheLocatedCoordinate(AuxB);
extrapolate_the_polygon_to_3_D(AuxB);
DividePolygonToTriangles(AuxB);
aux_count++;
}
delete[] curraux;
}
bool PolygonsPercalation::PercolationDectect(double a01, double b01, double c01, double d01, polygon* C, polygon* D, int& Ccount, int& Dcount, int& AUXBcount, bool& correspondvalplane)
{
bool validplaneparticle=false; //bool型变量,申明当前考察面的对应的面无效,即validB中没有粒子与之相交
while (1)
{
bool particlesintersect=false; //bool型标示变量,表示在D中已经找不到粒子与C中粒子相交
for (int i=0; i<Dcount; i++)
{
if (D.polar_center.x==DELFLAG && D.polar_center.y==DELFLAG
&& D.polar_center.z==DELFLAG)//表示D已经从D中删除,那么就不需要考察D,进行到下一个D
continue;
for (int j=0; j<Ccount; j++)
{
if (IntersectParticlesJudegmentInaccurately(D, C)==1
&&IntersectParticlesJudegmentInaccurately(C, D)==1)
{
if(IntersectParticlesJudegementAccurately(D,C)==true)
{
particlesintersect=true; //表明在D中存在粒子D与C中粒子相交
C=D; //并且将D成员添加到C中
Ccount++;
D.polar_center.x=DELFLAG; //将D做上标记,表示从D中将此成员删除
D.polar_center.y=DELFLAG;
D.polar_center.z=DELFLAG;
break;
}
}
}
}//for (int i=0; i<Dcount; i++)
if (particlesintersect==false)
break;
}//while (1)
for (int m=0; m<Ccount; m++)//检测validB类中是否有粒子与当前面的对应面相交,若有,则达到percolation
{
if (IntersectParticleToPlane(C, a01, b01, c01, d01)==true)
{
correspondvalplane=true; //表示在validB类中有粒子与当前面的对应面相交
for (int k=0; k<AUXBcount; k++)//判断C类与考察面的对应面相交的粒子是否与附加粒子相交
{
if(IntersectParticlesJudegmentInaccurately(C, AuxB)==1
&&IntersectParticlesJudegmentInaccurately(AuxB,C)==1)
{
if(IntersectParticlesJudegementAccurately(C,AuxB))
{
validplaneparticle=true;
break;
}
}
}
if(validplaneparticle==true)
break;
}
}
return validplaneparticle;
}
bool PolygonsPercalation::IntersectParticlesJudegmentInaccurately(polygon& P1,polygon& P2)//判断两个粒子是否相交的粗糙判定
{
double distance;
////////////////////////////////////////////////////////////////////////////////判定两粒子是否相交
for(int j=0;j<N;j++)
{
for(int k=0;k<3;k++)
{
distance=P2.DivideTriangles.vertexs.x*P1.NoramalVector.x+P2.DivideTriangles.vertexs.y*P1.NoramalVector.y+P2.DivideTriangles.vertexs.z*P1.NoramalVector.z
-P1.polar_center.x*P1.NoramalVector.x-P1.polar_center.y*P1.NoramalVector.y-P1.polar_center.z*P1.NoramalVector.z;
}
if(distance>0&&distance>0&&distance>0)
continue;
if(distance<0&&distance<0&&distance<0)
continue;
else //相交和共面情况返回为1
return 1;
}
return 0;//多边形中没有三角形相交,返回0
}
bool PolygonsPercalation::IntersectParticlesJudegementAccurately(polygon& P1,polygon& P2)
{
point IntersectingLineDirectionVector;//两个平面交线的方向向量
point PointInline;//交线上某点坐标
point PointOfInstersection;//两平面交线与两个三角形边的交点
double a,b,d1,d2;//参数a和b用来计算交线上的某点坐标,d1和d2是两三角形所在平面方程的常数项
double min_x1,max_x1;//用来确定大小的量
double t;//三角形与交线的标量值
double ModulusOfDirectionVector;
double distance;//顶点到平面的有向距离
double p;
double c;//变量c用来存储n1xn2,计算两平面法向量点成
double max_tempt_x=0,min_tempt_x=0,max_tempt_y=0,min_tempt_y=0;//用于比较大小的参数
double max_x,min_x,min_y,max_y;//在坐标面XOY投影的x和y的投影的最小和最大值
double MoudulusN1,MoudulusN2;//计算平面法向量N1和平面法向量N2的模的平方
////////////////////////////////////////////////////////////////////////////////计算两平面交线的方向向量
IntersectingLineDirectionVector.x=P1.NoramalVector.y*P2.NoramalVector.z-P1.NoramalVector.z*P2.NoramalVector.y;
IntersectingLineDirectionVector.y=P1.NoramalVector.z*P2.NoramalVector.x-P1.NoramalVector.x*P2.NoramalVector.z;
IntersectingLineDirectionVector.z=P1.NoramalVector.x*P2.NoramalVector.y-P1.NoramalVector.y*P2.NoramalVector.x;
ModulusOfDirectionVector=sqrt(pow(IntersectingLineDirectionVector.x,2)+pow(IntersectingLineDirectionVector.y,2)+pow(IntersectingLineDirectionVector.z,2));
IntersectingLineDirectionVector.x/=ModulusOfDirectionVector;
IntersectingLineDirectionVector.y/=ModulusOfDirectionVector;
IntersectingLineDirectionVector.z/=ModulusOfDirectionVector;
////////////////////////////////////////////////////////////////////////////////计算两平面交线上任意一点
d1=P1.polar_center.x*P1.NoramalVector.x+P1.polar_center.y*P1.NoramalVector.y+P1.polar_center.z*P1.NoramalVector.z;
d2=P2.polar_center.x*P2.NoramalVector.x+P2.polar_center.y*P2.NoramalVector.y+P2.polar_center.z*P2.NoramalVector.z;
c=P1.NoramalVector.x*P2.NoramalVector.x+P1.NoramalVector.y+P2.NoramalVector.y+P1.NoramalVector.z*P2.NoramalVector.z;//计算两平面法向量点乘
MoudulusN1=pow(P1.NoramalVector.x,2)+pow(P1.NoramalVector.y,2)+pow(P1.NoramalVector.z,2);//计算P1平面法向量的模的平方
MoudulusN2=pow(P2.NoramalVector.x,2)+pow(P2.NoramalVector.y,2)+pow(P2.NoramalVector.z,2);//计算平面N2平面法向量的模的平方
a=(d2*c-d1*MoudulusN2)/(pow(c,2)-MoudulusN1*MoudulusN2);
b=(d1*c-d2*MoudulusN1)/(pow(c,2)-MoudulusN1*MoudulusN2);
PointInline.x=a*P1.NoramalVector.x+b*P2.NoramalVector.x;//交线上一点的坐标
PointInline.y=a*P1.NoramalVector.y+b*P2.NoramalVector.y;
PointInline.z=a*P1.NoramalVector.z+b*P2.NoramalVector.z;
for(int i=0;i<N;i++)
{
for(int j=0;j<N;j++)
{
for(int k=0;k<3;k++)
{
distance=P2.DivideTriangles.vertexs.x*P1.NoramalVector.x+P2.DivideTriangles.vertexs.y*P1.NoramalVector.y+P2.DivideTriangles.vertexs.z*P1.NoramalVector.z
-P1.polar_center.x*P1.NoramalVector.x-P1.polar_center.y*P1.NoramalVector.y-P1.polar_center.z*P1.NoramalVector.z;
p=P2.DivideTriangles.vertexs.x*IntersectingLineDirectionVector.x+P2.DivideTriangles.vertexs.y*IntersectingLineDirectionVector.y+
P2.DivideTriangles.vertexs.z*IntersectingLineDirectionVector.z;
}
//********************************************************当两个三角形共面时
if(distance==0&&distance==0&&distance==0)
{
for(int t=0;t<3;t++)
{
P1.DivideTriangles.ProjectionVertexs.x=P1.DivideTriangles.vertexs.x;
P1.DivideTriangles.ProjectionVertexs.y=P1.DivideTriangles.vertexs.y;
P1.DivideTriangles.ProjectionVertexs.z=0;
P2.DivideTriangles.ProjectionVertexs.x=P2.DivideTriangles.vertexs.x;
P2.DivideTriangles.ProjectionVertexs.y=P2.DivideTriangles.vertexs.y;
P2.DivideTriangles.ProjectionVertexs.z=0;
}
for(int t=0;t<3;t++)
{
if(min_tempt_x<P2.DivideTriangles.ProjectionVertexs.x)
{max_tempt_x=P2.DivideTriangles.ProjectionVertexs.x;}
else if(min_tempt_x>P2.DivideTriangles.ProjectionVertexs.x)
{min_tempt_x=P2.DivideTriangles.ProjectionVertexs.x;}
if(min_tempt_y<P2.DivideTriangles.ProjectionVertexs.y)
{max_tempt_y=P2.DivideTriangles.ProjectionVertexs.y;}
else if(min_tempt_y>P2.DivideTriangles.ProjectionVertexs.y)
{min_tempt_y=P2.DivideTriangles.ProjectionVertexs.y;}
}
min_x=min_tempt_x;max_x=max_tempt_x;min_y=min_tempt_y;max_y=max_tempt_y;
for(int t=0;t<3;t++)
{
if(min_x<P1.DivideTriangles.ProjectionVertexs.x&&max_x>P1.DivideTriangles.ProjectionVertexs.x&&min_y<P1.DivideTriangles.ProjectionVertexs.y&&max_y>P1.DivideTriangles.ProjectionVertexs.y)
{return(true);}//两共面三角形相交,返回1
if(min_x==P1.DivideTriangles.ProjectionVertexs.x&&max_x==P1.DivideTriangles.ProjectionVertexs.x&&min_y==P1.DivideTriangles.ProjectionVertexs.y&&max_y==P1.DivideTriangles.ProjectionVertexs.y)
{return(true);}//两共面三角形相交,返回1
}
}
if(distance>0&&distance<0&&distance<0)//此时两平面交线与三角形边01,02边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance>0&&distance>0)//此时两平面交线与三角形边01,02边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance<0&&distance>0)//此时两平面交线与三角形边02,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance>0&&distance>0&&distance<0)//此时两平面交线与三角形边02,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance>0&&distance>0&&distance<0)//此时两平面交线与三角形01,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance<0&&distance>0)//此时两平面交线与三角形01,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
////////////////////////////////////////////////////////////////////////////////////判定多边形P1与两平面的标量值
for(int k=0;k<3;k++)
{
distance=P1.DivideTriangles.vertexs.x*P2.NoramalVector.x+P1.DivideTriangles.vertexs.y*P2.NoramalVector.y+P1.DivideTriangles.vertexs.z*P2.NoramalVector.z
-P2.polar_center.x*P2.NoramalVector.x-P2.polar_center.y*P2.NoramalVector.y-P2.polar_center.z*P2.NoramalVector.z;
p=P1.DivideTriangles.vertexs.x*IntersectingLineDirectionVector.x+P1.DivideTriangles.vertexs.y*IntersectingLineDirectionVector.y+
P1.DivideTriangles.vertexs.z*IntersectingLineDirectionVector.z;
}
if(distance>0&&distance<0&&distance<0)//此时两平面交线与三角形边01,02边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance>0&&distance>0)//此时两平面交线与三角形边01,02边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance<0&&distance>0)//此时两平面交线与三角形边02,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance>0&&distance>0&&distance<0)//此时两平面交线与三角形边02,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance>0&&distance>0&&distance<0)//此时两平面交线与三角形01,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
if(distance<0&&distance<0&&distance>0)//此时两平面交线与三角形01,12边相交
{
t=p+(p-p)*distance/(distance-distance);
t=p+(p-p)*distance/(distance-distance);
}
for(int r=0;r<4;r++)//计算两平面的交线与两三角形边的交点
{
PointOfInstersection.x=t*IntersectingLineDirectionVector.x+PointInline.x;
PointOfInstersection.y=t*IntersectingLineDirectionVector.y+PointInline.y;
PointOfInstersection.z=t*IntersectingLineDirectionVector.z+PointInline.z;
}
if(PointOfInstersection.x>PointOfInstersection.x)
{
min_x1=PointOfInstersection.x;
max_x1=PointOfInstersection.x;
}
if(PointOfInstersection.x<PointOfInstersection.x)
{
min_x1=PointOfInstersection.x;
max_x1=PointOfInstersection.x;
}
if(PointOfInstersection.x>PointOfInstersection.x)
{
min_x1=PointOfInstersection.x;
max_x1=PointOfInstersection.x;
}
if(PointOfInstersection.x<PointOfInstersection.x)
{
min_x1=PointOfInstersection.x;
max_x1=PointOfInstersection.x;
}
if(min_x1<=max_x1&&max_x1>=max_x1)
{
return true;//此时两不共面三角形相交,返回true
}
else if(min_x1<=min_x1&&min_x1<=max_x1)
{
return true;//此时两不共面三角形相交,返回true
}
else
continue;
}
}
return false;
}
int main()
{
srand((int)time(NULL));
clock_t start, end; //程序执行时间(ms)
double TotalTime;
start=clock();
PolygonsPercalation P;
P.GetDate();
P.PercolationSimulation();
end=clock();
TotalTime=((end-start)*0.001)/3600;
cout<<"TotalTime="<<TotalTime<<" hours"<<endl;
return 0;
}
页:
[1]