- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
Python在气缸垫后处理中的应用
李伟
辉门(中国)有限公司
摘要:使用PYTHON对ABAQUS计算得到的结果进行必要的处理,可以快速得到所需要的变量云图,表格,曲线。同时也可以对计算中所有的输入进行二次检查,从而确保计算的准确性。在需要运算多个任务的情况下,也可以根据当前计算机的使用情况来选择任务运
行的数量与顺序。
关键词:PYTHON,ABAQUS,气缸垫
1.简介
随着市场竞争的日益激励,有限元仿真技术对于缩短产品研发周期,增强产品设计可
靠性等诸多方面有着非常重要的意义。汽车发动机设计作为有限元使用最为活跃的领域之
一,往往对分析周期,数据处理的快捷有效有着更高的要求。
ABAQUS作为国际公认的最先进的大型通用非线性有限元分析软件之一,广泛应用于
机械制造,石油化工等许多工业和科学研究领域。PYTHON是一种面向对象的脚本语言,
因为具有丰富的数据类型,简单有效的面向对象程序设计方法以及强大的扩展性等优点,始终占据程序语言排行榜的前列。因此,使用PYTHON语言基于ABAQUS进行二次开发或者进行数据处理,已经成为了众多仿真分析人员的共识。
辉门公司作为全球性汽车零配件制造供应商,始终致力于设计,制造并销售各种技术
产品,以提高燃油经济性,降低排放并提供车辆安全性。随着公司业务的不断增长,需要在更短的时间内对各种设计方案进行验证,优化,因此,除了必要的经验与实验,分析的
精度以及数据处理效率的快捷准确也就成为了一种必然的要求。
2.PYTHON在气缸垫分析后处理中的应用
气缸垫位于缸盖和缸体之间,用于弥补缸体和缸盖之间的微观孔隙,保证结合面处良好
的密封性,从而保证燃烧室的密封,防止漏气以及水套漏水和油道中机油的渗漏。因此,对于气缸垫而言,在具有高温高压的恶劣环境中,保持足够的密封压力,并且保持气缸垫
不会产生疲劳破坏就成为了其最重要的两个性能指标。因此,对于气缸垫的后处理数据,也大多针对这两个指标来进行处理。
2016SIMULIA中国区用户大会1
2.1模型简化以及应力应变场的处理
为了保证足够的分析精度,通常气缸垫的分析都会要求完整的发动机模型,至少要求
缸盖,缸体,缸套,螺栓,气门座圈,导管等必要部件。因此,模型通常都会很大,但只有缸垫才是主要分析对象。为了更快的对缸垫进行后处理操作,只提取出缸垫模型以及变
量在不同载荷步下的数值就成了一种有效的手段。程序主体部分如下:
#CreateanODB(whichalsocreatestherootAssembly)
gasketOdbName=myTest
gasketOdbTitle=ChecktheSealingperformanceatinstanttemperaturefield
gasketOdbPath=datapath+gasketOdbName+_Gasket_Only.odb
odb=Odb(name=gasketOdbName,analysisTitle=gasketOdbTitle,
description=CopiedGasketModelfromOriginalFull3DModel,
path=gasketOdbPath)
#CreatethePart
part1=odb.Part(name=PART-1,embeddedSpace=THREE_D,type=DEFORMABLE_BODY)
nodeData=tuple(nodeData)
part1.addNodes(nodeData=nodeData,nodeSetName=NGASKT)
elementData=[]
foriinrange(len(elementData_8)):
elementData.append(tuple(elementData_8[i][2]))
elementData=tuple(elementData)
part1.addElements(elementData=elementData,type=GK3D8)
#Instancethepart.
instance1=odb.rootAssembly.Instance(name=PART-1-1,object=part1)
foriinrange(len(ElemSets)):
elLabels=tuple(gskElemSet[i])
elset_1=odb.rootAssembly.instances[PART-1-
1].ElementSetFromElementLabels(name=ElemSets[i],elementLabels
文档评论(0)