1354081891 发表于 2018-4-2 11:44:07

出现无法读取内存情况怎么办?

这个程序做的是一个逾渗的程序,请问一下各位大佬,这种的情况改怎么找到错误出现的地方呀?
#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]
查看完整版本: 出现无法读取内存情况怎么办?