CN113946926A - 一种s3d高能管道破损影响分析的系统和实现方法 - Google Patents

一种s3d高能管道破损影响分析的系统和实现方法 Download PDF

Info

Publication number
CN113946926A
CN113946926A CN202111315419.2A CN202111315419A CN113946926A CN 113946926 A CN113946926 A CN 113946926A CN 202111315419 A CN202111315419 A CN 202111315419A CN 113946926 A CN113946926 A CN 113946926A
Authority
CN
China
Prior art keywords
entering
influence
path
space
position set
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202111315419.2A
Other languages
English (en)
Inventor
沈杰
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shanghai Nuclear Engineering Research and Design Institute Co Ltd
Original Assignee
Shanghai Nuclear Engineering Research and Design Institute Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shanghai Nuclear Engineering Research and Design Institute Co Ltd filed Critical Shanghai Nuclear Engineering Research and Design Institute Co Ltd
Priority to CN202111315419.2A priority Critical patent/CN113946926A/zh
Publication of CN113946926A publication Critical patent/CN113946926A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/10Geometric CAD
    • G06F30/18Network design, e.g. design based on topological or interconnect aspects of utility systems, piping, heating ventilation air conditioning [HVAC] or cabling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T17/00Three dimensional [3D] modelling, e.g. data description of 3D objects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2113/00Details relating to the application field
    • G06F2113/14Pipes

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Geometry (AREA)
  • Theoretical Computer Science (AREA)
  • Computational Mathematics (AREA)
  • Software Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Computer Graphics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Evolutionary Computation (AREA)
  • General Engineering & Computer Science (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

本发明涉及高能管道破损影响分析相关领域,具体为一种S3D高能管道破损影响分析的系统和实现方法,通过编写高能管道输入模块、高能管道路径分析模块、影响空间生成模块、影响分析模块以及报告生成模块,实现能够根据用户设定好的高能管道以及其影响范围,自动计算出一旦高能管道破裂后会影响到的所有相关元件,并能够自动生成对应的影响清单,免去了分析人员手动进行创建高能管道影响空间并且手动进行高能管道影响分析的过程,大幅提高了工作效率,同时自动化的计算过程避免了人为因素的干扰,使分析结果更加精确。

Description

一种S3D高能管道破损影响分析的系统和实现方法
技术领域
本发明涉及高能管道破损影响分析相关领域,具体为一种S3D高能管道破损影响分析的系统和实现方法。
背景技术
S3D(Smart 3D)是一款广泛运用的三维设计软件。S3D软件作为一个集成化的、多专业参与的三维工厂建模软件,能够快速帮助各专业设计人员进行三维建模以及设计检查,大大提高了工作效率和设计质量。在化工及能源行业,S3D软件得到了广泛的应用并且已经有了无数成功的案例。
高能管道断裂是设计过程中必须考虑的工况。由于高能管道断裂后甩击能量高,所以其可能造成的危害极大,甚至影响核安全。以前设计过程中为此设置了大量的构件和结构用来防止高能管道断裂危害。随着破先漏(leak before break)技术的应用,高能管道不必考虑完全断裂的工况,取消了防甩击的构件和结构,因此高能管道断裂后的影响分析对工程的安全至关重要。针对上述情况,提出了一种S3D高能管道破损影响分析的系统和实现方法。
发明内容
本发明的目的在于提供一种S3D高能管道破损影响分析的系统和实现方法,以解决上述背景技术中提出的问题。
为实现上述目的,本发明提供如下技术方案:一种S3D高能管道破损影响分析系统,包括高能管道输入模块、高能管道路径分析模块、影响空间生成模块、影响分析计算模块和影响报告生成模块,其特征在于:所述高能管道输入模块用于用户指定需要进行分析的高能管道范围以及破损影响区间值,其中高能管道范围可以是单根管道输入也可以是通过清单指定的多跟管道输入;
所述高能管道路径分析模块用于根据用户输入的高能管道范围识别出需要分析的高能管道,同时对高能管道进行路径识别,将涉及的所有管道抽象成空间中以线表示的路径;
所述影响空间生成模块用于根据高能管道路径分析模块识别出的路径,按照用户输入的影响范围自动生成对应的影响空间模型;
所述影响分析模块用于通过碰撞检查识别影响空间内除了生成该空间的高能管道外的一些对象并记录到对应数据库中,同时在分析结束以后自动删除生成的影响分析空间;
所述报告生成模块用于将高能管道影响分析结果以报表形式输出给用户后续的安全分析计算工作。
优选的,一种S3D高能管道破损影响分析系统的实现方法,其特征在于:包括以下步骤:
S1、用户通过高能管道输入模块输入高能管道对应的管线号以及影响范围,进入S2;
S2、根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及管道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,进入S3;
S3、根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,进入S4;
S4、定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件,进入S5;
S5、将S4中的结果通过界面反馈给用户,如果用户需要生成对应报表进入S6,否则进入S7;
S6、将结果生成Excel形式报表输入给用户,进入S7;
S7、结束。
优选的,所述S2的根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及官道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,其构成步骤如下;
S2.1、验证用户输入的高能管道范围是否为空,如为空,报错直接进入S2.17,否则进入S2.2;
S2.2、根据输入的管线范围,进入S3D项目寻找是否存在对应的管线。如果有进入获取管线集合进入S2.3,如果没有则报错后进入S2.17;
S2.3、循环遍历管线集合,如果存在未遍历到的管线,进入S2.4,否则进入S.8;
S2.4、找到管线对应的PipeRun集合,进入S2.5;
S2.5、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.6,否则返回S2.3;
S2.6、确认当前PipeRun是否已经存在对应的影响空间,如果存在进入S2.7,否则返回S2.5;
S2.7、删除当前PipeRun生成的影响空间,返回S2.5;
S2.8、定义路径集合,路径由一条线段和当前路径所属的PipeRun的名称组成,线段由点构成,点由坐标、类别以及对应的Feature构成,进入S2.9;
S2.9、循环遍历S2.2的管线集合,获取所有的PipeRun集合,进入S2.10;
S2.10、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.11;否则进入S2.14;
S2.11、找到当前PipeRun下的所有feature,将feature根据其类别和坐标转换为点,进入S2.12;
S2.12、根据不同feature之间的连接关系,将不同的点串联成线,进入S2.13;
S2.13、根据线之间的关系串联成当前PipeRun下的路径,存入路径集合,返回S2.10;
S2.14、从路径集合中找出所有路径的端点和变径点,这些点如果存在连接关系,则代表连接,可以找出对应这些点的路径,去除相连的两个点,将两个路径合并为一个路径,进入S2.15;
S2.15、从路径集合中找到路径中存在的分支端点和三通点,如果分支端点和三通点存在连接关系却在互不相连的路径中,则需要将这些路径中对应分支端点的路径延伸到对应三通点的路径,使其形成通路,进入S2.16;
S2.16、找到具有完全不和其他路径相连的端点的路径作为起始路径,将所有路径依次排序成为带有分支的有向路径网络,形成后续步骤需要的高能管道共同构成的网络路径图,进入S2.17;
S2.17、结束。
优选的,所述S3的根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,其构建影响空间包含如下步骤:
S3.1、构建S3D的Position集合,进入S3.2;
S3.2、根据S2形成的路径网络图,遍历所有路径,如果存在未访问到的路径,进入S3.3,否则进入S3.62;
S3.3、获得当前路径的起点和终点,将当前路径的终点定义为currentPos,当前终点对应的feature定义为currentFeature,起点对应的feature定义为aboveFeature,进入S3.4;
S3.4、如果当前路径是有向路径网络的第一条路径,进入S3.5,否则进入S3.14;
S3.5、获取当前路径的影响范围作为radius,如果aboveFeature的类型不是弯头,进入S3.6,否则进入S3.12;
S3.6、将终点坐标放入Position集合,进入S3.14;
S3.7、找到aboveFeature的端点中距离currentPos更近的点设为shortPos,另一个端点设为longPos,进入S3.8;
S3.8、如果aboveFeature的转弯半径是影响范围的半径的两倍以上,进入S3.9,否则进入S3.12;
S3.9、在此情况下,弯头的影响范围应该是一个圆环的一部分,首先获得从longPos指向currentPos的向量originV,然后获得从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.10;
S3.10、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,aboveFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,aboveFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.11;
S3.11、将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S3.14;
S3.12、在此情况下,弯头的影响范围近似为从longPos到currentPos的直段以及从currentPos到shortPos的直段的组合,因此分别将longPos、currentPos以及shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.13;
S3.13、清除Position集合后,将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S3.14;
S3.14、如果当前路径不是有向路径网络的最后一条路径,进入S3.15,否则进入S3.45;
S3.15、获取当前路径的影响范围作为radius,如果Position集合不包含currentPos,进入S3.16,否则进入S3.43;
S3.16、如果currentFeature的类型不是弯头,进入S3.17,否则进入S3.18;
S3.17、将currentPos放入Position集合,进入S3.28;
S3.18、找到currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.19;
S3.19、如果currentFeature已被标记为已存在,将shortPos放入Position集合,进入S3.28,否则进入S3.20;
S3.20、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.21,否则进入S3.24;
S3.21、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.22;
S3.22、清空Position集合,按顺序将shortPos、currentPos以及longPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.23;
S3.23、清空Position集合,将longPos放入Position集合,将currentFeature标记为已存在,进入S3.28;
S3.24、在此情况下,弯头的影响范围应该是一个圆环的一部分。将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.25;
S3.25、清空Position集合,算出从shortPos指向currentPos的向量originV,然后算出从longPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.26;
S3.26、以shortPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.27;
S3.27、将aboveFeature标记已存在,防止重复绘制影响空间,然后将longPos放入Position集合,进入S3.28;
S3.28、如果下一条路径的名称和前一条路径的名称不一致或者下一条路径的起点与上一条路径的终点不一致,代表重新开始一条和前面所有路径不相连的路径,进入S3.29,否则返回S3.2;
S3.29、如果Position集合中有点,进入S3.30,否则进入S3.31;
S3.30、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.31;
S3.31、清空Position集合,获得当前路径下一条路径的起点对应的feature标记为nextFeature,进入S3.32;
S3.32、如果nextFeature类型不为弯头,进入S3.33,否则进入S3.34;
S3.33、将下一条路径的起点坐标放入Position集合,返回S3.2;
S3.34、获取下一条路径的影响范围标记为radius,将下一条路径的终点标记为refPos,进入S3.35;
S3.35、将nextFeature的端点中距离refPos更近的点设为shortPos,另一个端点设为longPos,进入S3.36;
S3.36、如果nextFeature被标记为已存在,将shortPos放入Position集合,返回S3.2,否则进入S3.37;
S3.37、如果nextFeature的转弯半径不到影响范围的半径的两倍,进入S3.38,否则进入S3.40;
S3.38、将longPos、下一条路径的起点以及shortPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为下一条路径的名字,绘制完成后进入S3.39;
S3.39、清空Position集合,将shortPos放入Position集合,将nextFeature标记为已存在,返回S3.2;
S3.40、算出从longPos指向下一条路径的起点的向量originV,然后算出从shortPos指向下一条路径的终点的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.41;
S3.41、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,nextFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,nextFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为下一条路径的名字,绘制完成后进入S3.42;
S3.42、将nextFeature标记为已存在,将shortPos放入Position集合,返回S3.2;
S3.43、路径中不能有重复的点,因此发现重复点就断开,分两条路径。绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.44;
S3.44、清空Position集合,将当前路径的起点坐标放入Position集合,将游标后退一格,返回S3.2;
S3.45、如果Position集合不包含currentPos,进入S3.46,否则进入S3.59;
S3.46、获取当前路径的影响范围作为radius,如果currentFeature的类型不是弯头,进入S3.47,否则进入S3.49;
S3.47、将currentPos放入Position集合,进入S3.48;
S3.48、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.49、将currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.50;
S3.50、如果currentFeature被标记为已存在,将shortPos放入Position集合,返回S3.48,否则进入S3.51;
S3.51、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.52,否则进入S3.55;
S3.52、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.53;
S3.53、清空Position集合,将shortPos、currentPos以及longPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,进入S3.54;
S3.54、将currentFeature标记为已存在,返回S3.2;
S3.55、将shortPos放入Position集合,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.56;
S3.56、算出从longPos指向currentPos的向量originV,然后算出从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.57;
S3.57、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.58;
S3.58、将currentFeature标记为已存在,返回S3.2;
S3.59、如果Position集合不为空,进入S3.60,否则返回S3.2;
S3.60、获取当前路径的影响范围作为radius,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后清空Position集合,进入S3.61;
S3.61、将当前路径的起点坐标放入Position集合,然后将currentPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.62、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S3.63;
S3.63、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S3.64;
S3.64、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S3.65;
S3.65、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S3.66;否则进入S3.69;
S3.66、从LBB_INFO_1寻找当前PipeRun的数据条目,如果存在进入S3.67,否则进入S3.68;
S3.67、更新当前条目的相关属性,删除LBB_INFO_2中当前条目的所有影响范围,返回S3.65;
S3.68、向LBB_INFO_1中插入PipeRun对应的影响空间信息如名字、影响范围等,返回S3.65;
S3.69、结束。
优选的,所述S4的定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件包含以下步骤;
S4.1、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S4.2;
S4.2、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S4.3;
S4.3、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S4.4;
S4.4、查找LBB_INFO_1中是否存在尚未完成影响空间碰撞分析的PipeRun,获取对应的数据条目,完成后进入S4.5;
S4.5、循环遍历S4.4获得的条目,如果存在尚未遍历的条目,进入S4.6,否则进入S4.21;
S4.6、设置碰撞检查是否完成标志位flag为否,找到当前PipeRun下的所有Parts存储入Part集合,设置一个当前碰撞的去除集合PartCol,进入S4.7;
S4.7、循环遍历Part集合,如果存在尚未遍历的Part,进入S4.8,否则进入S4.11;
S4.8、将Part放入PartCol,找到当前Part的连接点Connection集合,进入S4.9;
S4.9、循环遍历Connection集合,如果存在尚未遍历的Connection,进入S4.10,否则返回S4.7:
S4.10、找到当前Connection对象的连接对象,找到连接对象中除了当前Part的另一个Part,如果该Part不在PartCol中,将其放入PartCol,返回S4.9;
S4.11、根据当前条目的名称从模型中找到对应的碰撞影响空间对象,进入S4.12;
S4.12、找到碰撞影响空间对应的所有碰撞点对象集合,进入S4.13;
S4.13、循环遍历S4.12获得的所有碰撞点,如果存在尚未遍历的碰撞点,进入S4.14,否则进入S4.16:
S4.14、找到当前碰撞点关联的碰撞对象,查看是否存在既不是焊点又不是碰撞影响空间且不是碰撞影响空间对象,如果存在进入S4.15,否则返回S4.13;
S4.15、如果该对象不存在于PartCol,则当前对象为影响空间内受到影响的真实对象,将其存放入LBB_INFO_2表中,同时将碰撞检查标志位flag设为真,返回S4.13,否则直接返回S4.13;
S4.16、查看flag的值,如果为真,进入S4.17,否则进入S4.18;
S4.17、将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.18、查找LBB_INFO_1中当前影响空间的生成时间,如果现在时间相比生成时间已超过1小时,进入S4.19,否则进入4.20;
S4.19、当前影响分析已完成,只是没有任何影响对象,将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.20、当前影响空间对应的碰撞检查尚未完成,等待,直接返回S4.5;
S4.21、结束。
与现有技术相比,本发明的有益效果是:
1.本发明提供了一种根据管道布置路径自动生成管道影响空间的方法,免去了分析人员手动进行影响空间建模的工作,大幅提升了工作效率和质量;
2.本发提供了一种通过碰撞检查实现影响空间内受影响对象识别的方法,免去了设计人员手动分析影响对象的过程,大幅提升了工作效率和质量;
3.本发明实现了对分析结果的自动导出,方便使用人员将分析结果使用到后续的计算分析环节中;
4.本发明支持单根管道以及多跟管道两种分析模式,通用性更强;
5.本发明支持对用户输入对象和分析结果对象的高亮居中显示,提高用户的使用体验。
附图说明
图1为本发明的S3D高能管道破损影响分析系统的结构示意图;
图2为本发明的S3D高能管道破损影响分析的实现方法流程图;
图3为本发明的构建S3D高能管道网络路径图的流程示意图;
图4为本发明的根据生成的影响空间分析高能管道影响范围的流程示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
在本发明的描述中,还需要说明的是,除非另有明确的规定和限定,术语“设置”、“安装”、“相连”、“连接”应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或一体地连接;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通。对于本领域的普通技术人员而言,可以根据具体情况理解上述术语在本发明中的具体含义。
请参阅图1-4,本发明提供一种技术方案:一种S3D高能管道破损影响分析系统,包括高能管道输入模块、高能管道路径分析模块、影响空间生成模块、影响分析计算模块和影响报告生成模块,其特征在于:所述高能管道输入模块用于用户指定需要进行分析的高能管道范围以及破损影响区间值,其中高能管道范围可以是单根管道输入也可以是通过清单指定的多跟管道输入;
所述高能管道路径分析模块用于根据用户输入的高能管道范围识别出需要分析的高能管道,同时对高能管道进行路径识别,将涉及的所有管道抽象成空间中以线表示的路径;
所述影响空间生成模块用于根据高能管道路径分析模块识别出的路径,按照用户输入的影响范围自动生成对应的影响空间模型;
所述影响分析模块用于通过碰撞检查识别影响空间内除了生成该空间的高能管道外的一些对象并记录到对应数据库中,同时在分析结束以后自动删除生成的影响分析空间;
所述报告生成模块用于将高能管道影响分析结果以报表形式输出给用户后续的安全分析计算工作。
进一步的,一种S3D高能管道破损影响分析系统的实现方法,其特征在于:包括以下步骤:
S1、用户通过高能管道输入模块输入高能管道对应的管线号以及影响范围,进入S2;
S2、根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及管道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,进入S3;
S3、根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,进入S4;
S4、定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件,进入S5;
S5、将S4中的结果通过界面反馈给用户,如果用户需要生成对应报表进入S6,否则进入S7;
S6、将结果生成Excel形式报表输入给用户,进入S7;
S7、结束。
进一步的,所述S2的根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及官道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,其构成步骤如下;
S2.1、验证用户输入的高能管道范围是否为空,如为空,报错直接进入S2.17,否则进入S2.2;
S2.2、根据输入的管线范围,进入S3D项目寻找是否存在对应的管线。如果有进入获取管线集合进入S2.3,如果没有则报错后进入S2.17;
S2.3、循环遍历管线集合,如果存在未遍历到的管线,进入S2.4,否则进入S.8;
S2.4、找到管线对应的PipeRun集合,进入S2.5;
S2.5、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.6,否则返回S2.3;
S2.6、确认当前PipeRun是否已经存在对应的影响空间,如果存在进入S2.7,否则返回S2.5;
S2.7、删除当前PipeRun生成的影响空间,返回S2.5;
S2.8、定义路径集合,路径由一条线段和当前路径所属的PipeRun的名称组成,线段由点构成,点由坐标、类别以及对应的Feature构成,进入S2.9;
S2.9、循环遍历S2.2的管线集合,获取所有的PipeRun集合,进入S2.10;
S2.10、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.11;否则进入S2.14;
S2.11、找到当前PipeRun下的所有feature,将feature根据其类别和坐标转换为点,进入S2.12;
S2.12、根据不同feature之间的连接关系,将不同的点串联成线,进入S2.13;
S2.13、根据线之间的关系串联成当前PipeRun下的路径,存入路径集合,返回S2.10;
S2.14、从路径集合中找出所有路径的端点和变径点,这些点如果存在连接关系,则代表连接,可以找出对应这些点的路径,去除相连的两个点,将两个路径合并为一个路径,进入S2.15;
S2.15、从路径集合中找到路径中存在的分支端点和三通点,如果分支端点和三通点存在连接关系却在互不相连的路径中,则需要将这些路径中对应分支端点的路径延伸到对应三通点的路径,使其形成通路,进入S2.16;
S2.16、找到具有完全不和其他路径相连的端点的路径作为起始路径,将所有路径依次排序成为带有分支的有向路径网络,形成后续步骤需要的高能管道共同构成的网络路径图,进入S2.17;
S2.17、结束。
进一步的,所述S3的根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,其构建影响空间包含如下步骤:
S3.1、构建S3D的Position集合,进入S3.2;
S3.2、根据S2形成的路径网络图,遍历所有路径,如果尚有未访问到的路径,进入S3.3,否则进入S3.62;
S3.3、获得当前路径的起点和终点,将当前路径的终点定义为currentPos,当前终点对应的feature定义为currentFeature,起点对应的feature定义为aboveFeature,进入S3.4;
S3.4、如果当前路径是有向路径网络的第一条路径,进入S3.5,否则进入S3.14;
S3.5、获取当前路径的影响范围作为radius,如果aboveFeature的类型不是弯头,进入S3.6,否则进入S3.12;
S3.6、将终点坐标放入Position集合,进入S3.14;
S3.7、找到aboveFeature的端点中距离currentPos更近的点设为shortPos,另一个端点设为longPos,进入S3.8;
S3.8、如果aboveFeature的转弯半径是影响范围的半径的两倍以上,进入S3.9,否则进入S3.12;
S3.9、在此情况下,弯头的影响范围应该是一个圆环的一部分,首先获得从longPos指向currentPos的向量originV,然后获得从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.10;
S3.10、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,aboveFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,aboveFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.11;
S3.11、将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S.14;
S3.12、在此情况下,弯头的影响范围近似为从longPos到currentPos的直段以及从currentPos到shortPos的直段的组合,因此分别将longPos、currentPos以及shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.13;
S3.13、清除Position集合后,将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S3.14;
S3.14、如果当前路径不是有向路径网络的最后一条路径,进入S3.15,否则进入S3.45;
S3.15、获取当前路径的影响范围作为radius,如果Position集合不包含currentPos,进入S3.16,否则进入S3.43;
S3.16、如果currentFeature的类型不是弯头,进入S3.17,否则进入S3.18;
S3.17、将currentPos放入Position集合,进入S3.28;
S3.18、找到currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.19;
S3.19、如果currentFeature已被标记为已存在,将shortPos放入Position集合,进入S3.28,否则进入S3.20;
S3.20、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.21,否则进入S3.24;
S3.21、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.22;
S3.22、清空Position集合,按顺序将shortPos、currentPos以及longPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.23;
S3.23、清空Position集合,将longPos放入Position集合,将currentFeature标记为已存在,进入S3.28;
S3.24、在此情况下,弯头的影响范围应该是一个圆环的一部分。将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.25;
S3.25、清空Position集合,算出从shortPos指向currentPos的向量originV,然后算出从longPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.26;
S3.26、以shortPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.27;
S3.27、将aboveFeature标记已存在,防止重复绘制影响空间,然后将longPos放入Position集合,进入S3.28;
S3.28、如果下一条路径的名称和前一条路径的名称不一致或者下一条路径的起点与上一条路径的终点不一致,代表重新开始一条和前面所有路径不相连的路径,进入S3.29,否则返回S3.2;
S3.29、如果Position集合中有点,进入S3.30,否则进入S3.31;
S3.30、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.31;
S3.31、清空Position集合,获得当前路径下一条路径的起点对应的feature标记为nextFeature,进入S3.32;
S3.32、如果nextFeature类型不为弯头,进入S3.33,否则进入S3.34;
S3.33、将下一条路径的起点坐标放入Position集合,返回S3.2;
S3.34、获取下一条路径的影响范围标记为radius,将下一条路径的终点标记为refPos,进入S3.35;
S3.35、将nextFeature的端点中距离refPos更近的点设为shortPos,另一个端点设为longPos,进入S3.36;
S3.36、如果nextFeature被标记为已存在,将shortPos放入Position集合,返回S3.2,否则进入S3.37;
S3.37、如果nextFeature的转弯半径不到影响范围的半径的两倍,进入S3.38,否则进入S3.40;
S3.38、将longPos、下一条路径的起点以及shortPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为下一条路径的名字,绘制完成后进入S3.39;
S3.39、清空Position集合,将shortPos放入Position集合,将nextFeature标记为已存在,返回S3.2;
S3.40、算出从longPos指向下一条路径的起点的向量originV,然后算出从shortPos指向下一条路径的终点的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.41;
S3.41、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,nextFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,nextFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为下一条路径的名字,绘制完成后进入S3.42;
S3.42、将nextFeature标记为已存在,将shortPos放入Position集合,返回S3.2;
S3.43、路径中不能有重复的点,因此发现重复点就断开,分两条路径。绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.44;
S3.44、清空Position集合,将当前路径的起点坐标放入Position集合,将游标后退一格,返回S3.2;
S3.45、如果Position集合不包含currentPos,进入S3.46,否则进入S3.59;
S3.46、获取当前路径的影响范围作为radius,如果currentFeature的类型不是弯头,进入S3.47,否则进入S3.49;
S3.47、将currentPos放入Position集合,进入S3.48;
S3.48、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.49、将currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.50;
S3.50、如果currentFeature被标记为已存在,将shortPos放入Position集合,返回S3.48,否则进入S3.51;
S3.51、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.52,否则进入S3.55;
S3.52、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.53;
S3.53、清空Position集合,将shortPos、currentPos以及longPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,进入S3.54;
S3.54、将currentFeature标记为已存在,返回S3.2;
S3.55、将shortPos放入Position集合,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.56;
S3.56、算出从longPos指向currentPos的向量originV,然后算出从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.57;
S3.57、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.58;
S3.58、将currentFeature标记为已存在,返回S3.2;
S3.59、如果Position集合不为空,进入S3.60,否则返回S3.2;
S3.60、获取当前路径的影响范围作为radius,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后清空Position集合,进入S3.61;
S3.61、将当前路径的起点坐标放入Position集合,然后将currentPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.62、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S3.63;
S3.63、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S3.64;
S3.64、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S3.65;
S3.65、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S3.66;否则进入S3.69;
S3.66、从LBB_INFO_1寻找当前PipeRun的数据条目,如果存在进入S3.67,否则进入S3.68;
S3.67、更新当前条目的相关属性,删除LBB_INFO_2中当前条目的所有影响范围,返回S3.65;
S3.68、向LBB_INFO_1中插入PipeRun对应的影响空间信息如名字、影响范围等,返回S3.65;
S3.69、结束。
进一步的,所述S4的定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件包含以下步骤;
S4.1、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S4.2;
S4.2、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S4.3;
S4.3、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S4.4;
S4.4、查找LBB_INFO_1中是否存在尚未完成影响空间碰撞分析的PipeRun,获取对应的数据条目,完成后进入S4.5;
S4.5、循环遍历S4.4获得的条目,如果存在尚未遍历的条目,进入S4.6,否则进入S4.21;
S4.6、设置碰撞检查是否完成标志位flag为否,找到当前PipeRun下的所有Parts存储入Part集合,设置一个当前碰撞的去除集合PartCol,进入S4.7;
S4.7、循环遍历Part集合,如果存在尚未遍历的Part,进入S4.8,否则进入S4.11;
S4.8、将Part放入PartCol,找到当前Part的连接点Connection集合,进入S4.9;
S4.9、循环遍历Connection集合,如果存在尚未遍历的Connection,进入S4.10,否则返回S4.7:
S4.10、找到当前Connection对象的连接对象,找到连接对象中除了当前Part的另一个Part,如果该Part不在PartCol中,将其放入PartCol,返回S4.9;
S4.11、根据当前条目的名称从模型中找到对应的碰撞影响空间对象,进入S4.12;
S4.12、找到碰撞影响空间对应的所有碰撞点对象集合,进入S4.13;
S4.13、循环遍历S4.12获得的所有碰撞点,如果存在尚未遍历的碰撞点,进入S4.14,否则进入S4.16:
S4.14、找到当前碰撞点关联的碰撞对象,查看是否存在既不是焊点又不是碰撞影响空间且不是碰撞影响空间对象,如果存在进入S4.15,否则返回S4.13;
S4.15、如果该对象不存在于PartCol,则当前对象为影响空间内受到影响的真实对象,将其存放入LBB_INFO_2表中,同时将碰撞检查标志位flag设为真,返回S4.13,否则直接返回S4.13;
S4.16、查看flag的值,如果为真,进入S4.17,否则进入S4.18;
S4.17、将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.18、查找LBB_INFO_1中当前影响空间的生成时间,如果现在时间相比生成时间已超过1小时,进入S4.19,否则进入4.20;
S4.19、当前影响分析已完成,只是没有任何影响对象,将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.20、当前影响空间对应的碰撞检查尚未完成,等待,直接返回S4.5;
S4.21、结束。
本发明提供了一种根据管道布置路径自动生成管道影响空间的方法,免去了分析人员手动进行影响空间建模的工作,大幅提升了工作效率和质量;本发提供了一种通过碰撞检查实现影响空间内受影响对象识别的方法,免去了设计人员手动分析影响对象的过程,大幅提升了工作效率和质量;本发明实现了对分析结果的自动导出,方便使用人员将分析结果使用到后续的计算分析环节中;本发明支持单根管道以及多跟管道两种分析模式,通用性更强;本发明支持对用户输入对象和分析结果对象的高亮居中显示,提高用户的使用体验。
尽管已经示出和描述了本发明的实施例,对于本领域的普通技术人员而言,可以理解在不脱离本发明的原理和精神的情况下可以对这些实施例进行多种变化、修改、替换和变型,本发明的范围由所附权利要求及其等同物限定。

Claims (5)

1.一种S3D高能管道破损影响分析系统,包括高能管道输入模块、高能管道路径分析模块、影响空间生成模块、影响分析计算模块和影响报告生成模块,其特征在于:所述高能管道输入模块用于用户指定需要进行分析的高能管道范围以及破损影响区间值,其中高能管道范围可以是单根管道输入也可以是通过清单指定的多跟管道输入;
所述高能管道路径分析模块用于根据用户输入的高能管道范围识别出需要分析的高能管道,同时对高能管道进行路径识别,将涉及的所有管道抽象成空间中以线表示的路径;
所述影响空间生成模块用于根据高能管道路径分析模块识别出的路径,按照用户输入的影响范围自动生成对应的影响空间模型;
所述影响分析模块用于通过碰撞检查识别影响空间内除了生成该空间的高能管道外的一些对象并记录到对应数据库中,同时在分析结束以后自动删除生成的影响分析空间;
所述报告生成模块用于将高能管道影响分析结果以报表形式输出给用户后续的安全分析计算工作。
2.一种S3D高能管道破损影响分析系统的实现方法,其特征在于:包括以下步骤:
S1、用户通过高能管道输入模块输入高能管道对应的管线号以及影响范围,进入S2;
S2、根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及管道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,进入S3;
S3、根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,进入S4;
S4、定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件,进入S5;
S5、将S4中的结果通过界面反馈给用户,如果用户需要生成对应报表进入S6,否则进入S7;
S6、将结果生成Excel形式报表输入给用户,进入S7;
S7、结束。
3.根据权利要求2所述的一种S3D高能管道破损影响分析系统的实现方法,其特征在于:所述S2的根据用户输入范围定位到模型中的具体管道,识别范围内每根管道的具体布置路径以及官道之间的连接关系,最终形成所有高能管道共同构成的网络路径图,其构成步骤如下;
S2.1、验证用户输入的高能管道范围是否为空,如为空,报错直接进入S2.17,否则进入S2.2;
S2.2、根据输入的管线范围,进入S3D项目寻找是否存在对应的管线。如果有进入获取管线集合进入S2.3,如果没有则报错后进入S2.17;
S2.3、循环遍历管线集合,如果存在未遍历到的管线,进入S2.4,否则进入S.8;
S2.4、找到管线对应的PipeRun集合,进入S2.5;
S2.5、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.6,否则返回S2.3;
S2.6、确认当前PipeRun是否已经存在对应的影响空间,如果存在进入S2.7,否则返回S2.5;
S2.7、删除当前PipeRun生成的影响空间,返回S2.5;
S2.8、定义路径集合,路径由一条线段和当前路径所属的PipeRun的名称组成,线段由点构成,点由坐标、类别以及对应的Feature构成,进入S2.9;
S2.9、循环遍历S2.2的管线集合,获取所有的PipeRun集合,进入S2.10;
S2.10、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S2.11,否则进入S2.14;
S2.11、找到当前PipeRun下的所有feature,将feature根据其类别和坐标转换为点,进入S2.12;
S2.12、根据不同feature之间的连接关系,将不同的点串联成线,进入S2.13;
S2.13、根据线之间的关系串联成当前PipeRun下的路径,存入路径集合,返回S2.10;
S2.14、从路径集合中找出所有路径的端点和变径点,这些点如果存在连接关系,则代表连接,可以找出对应这些点的路径,去除相连的两个点,将两个路径合并为一个路径,进入S2.15;
S2.15、从路径集合中找到路径中存在的分支端点和三通点,如果分支端点和三通点存在连接关系却在互不相连的路径中,则需要将这些路径中对应分支端点的路径延伸到对应三通点的路径,使其形成通路,进入S2.16;
S2.16、找到具有完全不和其他路径相连的端点的路径作为起始路径,将所有路径依次排序成为带有分支的有向路径网络,形成后续步骤需要的高能管道共同构成的网络路径图,进入S2.17;
S2.17、结束。
4.根据权利要求2所述的一种S3D高能管道破损影响分析系统的实现方法,其特征在于:所述S3的根据S2获得的路径图加上S1中输入的影响范围自动在S3D中构建影响空间,其构建影响空间包含如下步骤:
S3.1、构建S3D的Position集合,进入S3.2;
S3.2、根据S2形成的路径网络图,遍历所有路径,如果存在未访问到的路径,进入S3.3,否则进入S3.62;
S3.3、获得当前路径的起点和终点,将当前路径的终点定义为currentPos,当前终点对应的feature定义为currentFeature,起点对应的feature定义为aboveFeature,进入S3.4;
S3.4、如果当前路径是有向路径网络的第一条路径,进入S3.5,否则进入S3.14;
S3.5、获取当前路径的影响范围作为radius,如果aboveFeature的类型不是弯头,进入S3.6,否则进入S3.12;
S3.6、将终点坐标放入Position集合,进入S3.14;
S3.7、找到aboveFeature的端点中距离currentPos更近的点设为shortPos,另一个端点设为longPos,进入S3.8;
S3.8、如果aboveFeature的转弯半径是影响范围的半径的两倍以上,进入S3.9,否则进入S3.12;
S3.9、在此情况下,弯头的影响范围应该是一个圆环的一部分,首先获得从longPos指向currentPos的向量originV,然后获得从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.10;
S3.10、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,aboveFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,aboveFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.11;
S3.11、将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S3.14;
S3.12、在此情况下,弯头的影响范围近似为从longPos到currentPos的直段以及从currentPos到shortPos的直段的组合,因此分别将longPos、currentPos以及shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.13;
S3.13、清除Position集合后,将aboveFeature标记已存在,防止重复绘制影响空间,然后将shortPos放入Position集合,进入S3.14;
S3.14、如果当前路径不是有向路径网络的最后一条路径,进入S3.15,否则进入S3.45;
S3.15、获取当前路径的影响范围作为radius,如果Position集合不包含currentPos,进入S3.16,否则进入S3.43;
S3.16、如果currentFeature的类型不是弯头,进入S3.17,否则进入S3.18;
S3.17、将currentPos放入Position集合,进入S3.28;
S3.18、找到currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.19;
S3.19、如果currentFeature已被标记为已存在,将shortPos放入Position集合,进入S3.28,否则进入S3.20;
S3.20、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.21,否则进入S3.24;
S3.21、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.22;
S3.22、清空Position集合,按顺序将shortPos、currentPos以及longPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.23;
S3.23、清空Position集合,将longPos放入Position集合,将currentFeature标记为已存在,进入S3.28;
S3.24、在此情况下,弯头的影响范围应该是一个圆环的一部分。将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.25;
S3.25、清空Position集合,算出从shortPos指向currentPos的向量originV,然后算出从longPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.26;
S3.26、以shortPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.27;
S3.27、将aboveFeature标记已存在,防止重复绘制影响空间,然后将longPos放入Position集合,进入S3.28;
S3.28、如果下一条路径的名称和前一条路径的名称不一致或者下一条路径的起点与上一条路径的终点不一致,代表重新开始一条和前面所有路径不相连的路径,进入S3.29,否则返回S3.2;
S3.29、如果Position集合中有点,进入S3.30,否则进入S3.31;
S3.30、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.31;
S3.31、清空Position集合,获得当前路径下一条路径的起点对应的feature标记为nextFeature,进入S3.32;
S3.32、如果nextFeature类型不为弯头,进入S3.33,否则进入S3.34;
S3.33、将下一条路径的起点坐标放入Position集合,返回S3.2;
S3.34、获取下一条路径的影响范围标记为radius,将下一条路径的终点标记为refPos,进入S3.35;
S3.35、将nextFeature的端点中距离refPos更近的点设为shortPos,另一个端点设为longPos,进入S3.36;
S3.36、如果nextFeature被标记为已存在,将shortPos放入Position集合,返回S3.2,否则进入S3.37;
S3.37、如果nextFeature的转弯半径不到影响范围的半径的两倍,进入S3.38,否则进入S3.40;
S3.38、将longPos、下一条路径的起点以及shortPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为下一条路径的名字,绘制完成后进入S3.39;
S3.39、清空Position集合,将shortPos放入Position集合,将nextFeature标记为已存在,返回S3.2;
S3.40、算出从longPos指向下一条路径的起点的向量originV,然后算出从shortPos指向下一条路径的终点的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.41;
S3.41、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,nextFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,nextFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为下一条路径的名字,绘制完成后进入S3.42;
S3.42、将nextFeature标记为已存在,将shortPos放入Position集合,返回S3.2;
S3.43、路径中不能有重复的点,因此发现重复点就断开,分两条路径。绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.44;
S3.44、清空Position集合,将当前路径的起点坐标放入Position集合,将游标后退一格,返回S3.2;
S3.45、如果Position集合不包含currentPos,进入S3.46,否则进入S3.59;
S3.46、获取当前路径的影响范围作为radius,如果currentFeature的类型不是弯头,进入S3.47,否则进入S3.49;
S3.47、将currentPos放入Position集合,进入S3.48;
S3.48、绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.49、将currentFeature的端点中距离Position集合中最后的点更近的点设为shortPos,另一个端点设为longPos,进入S3.50;
S3.50、如果currentFeature被标记为已存在,将shortPos放入Position集合,返回S3.48,否则进入S3.51;
S3.51、如果currentFeature的转弯半径不到影响范围的半径的两倍,进入S3.52,否则进入S3.55;
S3.52、将shortPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.53;
S3.53、清空Position集合,将shortPos、currentPos以及longPos按顺序放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,进入S3.54;
S3.54、将currentFeature标记为已存在,返回S3.2;
S3.55、将shortPos放入Position集合,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后进入S3.56;
S3.56、算出从longPos指向currentPos的向量originV,然后算出从shortPos指向currentPos的向量tempV,求两个向量的叉乘方向verticalV,此方向就是当前弯头影响空间的部分圆环对应的平面的法向量,同时用verticalV叉乘originV,获得需要生成的弯头影响空间的部分圆环的次轴方向secondaryV,进入S3.57;
S3.57、以longPos作为部分圆环的起点,originV作为圆环的主轴,secondaryV作为圆环的次轴,radius作为圆环的半径,currentFeature的BendAngle与2倍的Pi的比例来确定需要的影响空间为圆环的几分之几,currentFeature的BendRadius作为圆环截面的半径进行影响空间的绘制,影响空间的名字为当前路径的名字,绘制完成后进入S3.58;
S3.58、将currentFeature标记为已存在,返回S3.2;
S3.59、如果Position集合不为空,进入S3.60,否则返回S3.2;
S3.60、获取当前路径的影响范围作为radius,绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为影响范围的圆,影响空间的名字为当前路径的名字,绘制完成后清空Position集合,进入S3.61;
S3.61、将当前路径的起点坐标放入Position集合,然后将currentPos放入Position集合,然后绘制按顺序遍历Position集合的多段直线段构成的影响空间,其中影响空间的截面为半径为radius的圆,影响空间的名字为当前路径的名字,绘制完成后返回S3.2;
S3.62、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S3.63;
S3.63、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S3.64;
S3.64、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S3.65;
S3.65、循环遍历PipeRun集合,如果存在未遍历到的PipeRun,进入S3.66;否则进入S3.69;
S3.66、从LBB_INFO_1寻找当前PipeRun的数据条目,如果存在进入S3.67,否则进入S3.68;
S3.67、更新当前条目的相关属性,删除LBB_INFO_2中当前条目的所有影响范围,返回S3.65;
S3.68、向LBB_INFO_1中插入PipeRun对应的影响空间信息如名字、影响范围等,返回S3.65;
S3.69、结束。
5.根据权利要求2所述的一种S3D高能管道破损影响分析系统的实现方法,其特征在于:所述S4的定时扫描S3中生成的影响空间对应的碰撞干涉对象,去除生成影响空间的管道以及管道正常连接的对象后作为结果输入到数据库中,删除生成的影响控件包含以下步骤;
S4.1、查看是否存在存储高能管道数据的db文件,如果不存在创建对应db文件,完成后进入S4.2;
S4.2、查看db文件是否存在用于存储PipeRun的影响空间的数据表,如果不存在创建数据表LBB_INFO_1,完成后进入S4.3;
S4.3、查看db文件中是否存在用于存储影响分析结果的数据表LBB_INFO_2,如果不存在创建该表,完成后进入S4.4;
S4.4、查找LBB_INFO_1中是否存在尚未完成影响空间碰撞分析的PipeRun,获取对应的数据条目,完成后进入S4.5;
S4.5、循环遍历S4.4获得的条目,如果存在尚未遍历的条目,进入S4.6,否则进入S4.21;
S4.6、设置碰撞检查是否完成标志位flag为否,找到当前PipeRun下的所有Parts存储入Part集合,设置一个当前碰撞的去除集合PartCol,进入S4.7;
S4.7、循环遍历Part集合,如果存在尚未遍历的Part,进入S4.8,否则进入S4.11;
S4.8、将Part放入PartCol,找到当前Part的连接点Connection集合,进入S4.9;
S4.9、循环遍历Connection集合,如果存在尚未遍历的Connection,进入S4.10,否则返回S4.7:
S4.10、找到当前Connection对象的连接对象,找到连接对象中除了当前Part的另一个Part,如果该Part不在PartCol中,将其放入PartCol,返回S4.9;
S4.11、根据当前条目的名称从模型中找到对应的碰撞影响空间对象,进入S4.12;
S4.12、找到碰撞影响空间对应的所有碰撞点对象集合,进入S4.13;
S4.13、循环遍历S4.12获得的所有碰撞点,如果存在尚未遍历的碰撞点,进入S4.14,否则进入S4.16:
S4.14、找到当前碰撞点关联的碰撞对象,查看是否存在既不是焊点又不是碰撞影响空间且不是碰撞影响空间对象,如果存在进入S4.15,否则返回S4.13;
S4.15、如果该对象不存在于PartCol,则当前对象为影响空间内受到影响的真实对象,将其存放入LBB_INFO_2表中,同时将碰撞检查标志位flag设为真,返回S4.13,否则直接返回S4.13;
S4.16、查看flag的值,如果为真,进入S4.17,否则进入S4.18;
S4.17、将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.18、查找LBB_INFO_1中当前影响空间的生成时间,如果现在时间相比生成时间已超过1小时,进入S4.19,否则进入4.20;
S4.19、当前影响分析已完成,只是没有任何影响对象,将碰撞影响空间删除,更新LBB_INFO_1中对应条目的影响空间状态为已完成影响分析,返回S4.5;
S4.20、当前影响空间对应的碰撞检查尚未完成,等待,直接返回S4.5;
S4.21、结束。
CN202111315419.2A 2021-11-08 2021-11-08 一种s3d高能管道破损影响分析的系统和实现方法 Pending CN113946926A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111315419.2A CN113946926A (zh) 2021-11-08 2021-11-08 一种s3d高能管道破损影响分析的系统和实现方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111315419.2A CN113946926A (zh) 2021-11-08 2021-11-08 一种s3d高能管道破损影响分析的系统和实现方法

Publications (1)

Publication Number Publication Date
CN113946926A true CN113946926A (zh) 2022-01-18

Family

ID=79337757

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111315419.2A Pending CN113946926A (zh) 2021-11-08 2021-11-08 一种s3d高能管道破损影响分析的系统和实现方法

Country Status (1)

Country Link
CN (1) CN113946926A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114896730A (zh) * 2022-05-16 2022-08-12 上海核工程研究设计院有限公司 一种s3d风管支架恒荷载自动分析计算的系统与方法
CN114912221A (zh) * 2022-05-16 2022-08-16 上海核工程研究设计院有限公司 一种s3d模型中建立管道和贯穿件物项关联关系的方法

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114896730A (zh) * 2022-05-16 2022-08-12 上海核工程研究设计院有限公司 一种s3d风管支架恒荷载自动分析计算的系统与方法
CN114912221A (zh) * 2022-05-16 2022-08-16 上海核工程研究设计院有限公司 一种s3d模型中建立管道和贯穿件物项关联关系的方法
CN114896730B (zh) * 2022-05-16 2024-05-14 上海核工程研究设计院股份有限公司 一种s3d风管支架恒荷载自动分析计算的系统与方法

Similar Documents

Publication Publication Date Title
CN113946926A (zh) 一种s3d高能管道破损影响分析的系统和实现方法
KR100969613B1 (ko) Cad 시스템, 그 제어 방법 및 제어 프로그램을 기록한기록 매체
CN109272571B (zh) 一种PDS三维数据转换为Flowmaster模型的系统和方法
CN110109999B (zh) 一种SMART 3D三维模型转Flowmaster模型的系统和转换方法
CN110389898A (zh) 测试策略的获取方法、装置、终端及计算机可读存储介质
US9158866B2 (en) Layout-design support system and layout-design support program
CN102567565B (zh) 一种电缆参数的处理方法和系统
CN107122524B (zh) 一种将管道力学分析结果转换成三维模型的方法
CN105468869B (zh) 一种pds模型的拓扑关系解析方法
CN112182871B (zh) 一种三维管道模型转换为MapGIS模型的系统和方法
CN109271697B (zh) 基于VBA处理AutoCAD中断面数据处理系统及方法、计算机程序
WO2024114077A1 (zh) 排程数据的处理方法和设备
CN112597603B (zh) 基于关键点的pdms管道自动建模方法和计算机终端
CN112733234B (zh) 一种基于电缆信息传递的三维桥架自动计算及生成的装置
CN109117564B (zh) 一种pds三维模型转换relap5模型的系统和方法
CN110222050B (zh) 用于核电厂三维数据库仪表关联物项的调取方法和系统
CN107958108B (zh) 焊缝生成方法、装置、存储介质和计算机设备
US7844419B1 (en) Method of detecting potential topology problems in a network
CN116186951A (zh) 一种三维管道模型连接关系的检查方法及装置
CN111798564B (zh) 一种pds三维模型转换的系统及其实现方法
CN114139257B (zh) 一种s3d元件的房间号自动计算的系统和方法
CN113157551B (zh) 一种面向ros的差分模糊测试方法
CN202074961U (zh) 一种钉桩放线与工程建设规划监督测量一体机
CN116227306B (zh) 用于有限元网格划分的零件连接结构自动识别方法
KR20150021866A (ko) 파이프 블록 결합 검사 방법 및 이를 저장한 기록매체

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
CB02 Change of applicant information
CB02 Change of applicant information

Address after: No. 29 Hong Cao Road, Xuhui District, Shanghai

Applicant after: Shanghai Nuclear Engineering Research and Design Institute Co.,Ltd.

Address before: No. 29 Hong Cao Road, Xuhui District, Shanghai

Applicant before: SHANGHAI NUCLEAR ENGINEERING RESEARCH & DESIGN INSTITUTE Co.,Ltd.