Simlab python二次开发1-将所有缸套内表面半径加大1mm

news2024/10/5 20:27:49

Simlab python二次开发1-将所有缸套内表面半径加大1mm

  • 1、打开模型文件
  • 2、getBodiesWithSubString()从名字得到Bodies
  • 3、建Body类Group
    • 3.1、定义放入Group中的Bodies
    • 3.2、建Group
  • 4、将缸套内表面建组,并扩半径1mm
    • 4.1、simlab.getBodiesFromGroup()
    • 4.2、选择圆柱特征,建面组
    • 4.3、根据圆柱面(面组名)得到端点坐标和半径
    • 4.4、将圆柱面(面组名)根据端点坐标扩半径1mm

1、打开模型文件

#***************************************************************
#SimLab Version 2020 Beta
#Created at Tue Oct 15 11:22:28 2019
#***************************************************************
#For debugging this python script,Please comment(#) out the line "from hwx import simlab" and uncomment the line "import simlab"
from hwx import simlab
#import simlab


ImportGda=''' <ImportGda UUID="D896F6DF-56FA-4134-9AD1-1010BF292223" gda="" CheckBox="ON">
  <tag Value="1"/>
  <Name Value="./SampleBolck.gda"/>
  <FileName Value="D:/study/CAEpython/getBodiesFromGroup_sample./SampleBolck.gda"/>
  <Units Value="MilliMeter"/>
  <Output/>
 </ImportGda>''';
simlab.execute(ImportGda)

和matlab类似,加;不打印结果
在这里插入图片描述

2、getBodiesWithSubString()从名字得到Bodies

outputBodies=simlab.getBodiesWithSubString("SampleBolck.gda", ["Liners_*"])

结果为元胞类型
在这里插入图片描述

3、建Body类Group

3.1、定义放入Group中的Bodies

CreateGroup=''' <CreateGroup UUID="899db3a6-bd69-4a2d-b30f-756c2b2b1954" CheckBox="OFF" isObject="4">
  <tag Value="-1"/>
  <Name Value="Liner_Bodies" OldValue=""/>
  <SupportEntities>
   <Entities>
    <Model>SampleBolck.gda</Model>
    <Body>'''+str(outputBodies).replace("'",'"').strip('()')+'''</Body>
   </Entities>
  </SupportEntities>
  <Type Value="Body"/>
  <Color Value="255,206,0,"/>
  <Dup Value="1"/>
 </CreateGroup>''';

在这里插入图片描述

3.2、建Group

simlab.execute(CreateGroup)

在这里插入图片描述

4、将缸套内表面建组,并扩半径1mm

4.1、simlab.getBodiesFromGroup()

从Body类Group中取得Bodies的名称(元胞

Liner_Bodies=simlab.getBodiesFromGroup('Liner_Bodies');

在这里插入图片描述

4.2、选择圆柱特征,建面组

i=1;

#下面的for 循环将所有的缸套内表面选择后建组,并扩半径1 mm(45-46):
#本示例只将Liners_2进行处理:
#for LinerBody in Liner_Bodies:
    LinerBody=Liner_Bodies[0] #######
    GroupName="Bore_"+str(i)
    
    SelectFeatures=''' <SelectFeatures UUID="CF82E8FB-9B3E-4c02-BA93-9466C1342C6E" CheckBox="ON">
      <SupportEntities>
       <Entities>
        <Model>SampleBolck.gda</Model>
        <Body>"'''+LinerBody+'''",</Body>
       </Entities>
      </SupportEntities>
      <Arcs MinValue="0.0" MaxValue="0.0" Value="0"/>
      <ArcsAll Value="1"/>
      <Circles MinValue="0.0" MaxValue="5" Value="0"/>
      <CirclesAll Value="0"/>
      <Cones MinValue="0.0" MaxValue="0.0" Value="0"/>
      <ConeAll Value="0"/>
      <FullCone Value="0"/>
      <ClosedPartialCone Value="0"/>
      <OpenPartialCone Value="0"/>
      <Dics MinValue="0.0" MaxValue="0.0" Value="0"/>
      <DicsAll Value="0"/>
      <HollowDics MinValue="0.0" MaxValue="0.0" Value="0"/>
      <HollowDicsAll Value="0"/>
      <Cylinders MinValue="44" MaxValue="45" Value="1"/>
      <CylindersAll Value="0"/>
      <FullCylinder Value="1"/>
      <ClosedPartialCylinder Value="0"/>
      <OpenPartialCylinder Value="0"/>
      <Fillets MinValue="0.0" MaxValue="0.0" Value="0"/>
      <FilletsOption Value="1"/>
      <PlanarFaces Value="0"/>
      <FourEdgedFaces Value="0"/>
      <ConnectedCoaxialFaces Value="0"/>
      <ThroughBoltHole MinValue="0.0" MaxValue="0.0" Value="0"/>
      <BlindBoltHole MinValue="0.0" MaxValue="0.0" Value="0"/>
      <BlindBoltHoleDepth MinValue="0.0" MaxValue="0.0" Value="0"/>
      <CreateGrp Name="'''+GroupName+'''" Value="1"/>
      <ArcLengthBased Value=""/>
     </SelectFeatures>''';
    simlab.execute(SelectFeatures);

在这里插入图片描述

4.3、根据圆柱面(面组名)得到端点坐标和半径

AxPt1,AxPt2,Rad=simlab.getCylindricalFaceAttributes(GroupName)

在这里插入图片描述
可测知面的半径为45mm
在这里插入图片描述

4.4、将圆柱面(面组名)根据端点坐标扩半径1mm

    AlignCylinder=''' <AlignCylinder UUID="5D271AC4-A0CE-411f-9E60-E7B17CB8B1B7" CheckBox="ON">
      <tag Value="-1"/>
      <Name Value=""/>
      <Entities>
       <Group>"'''+GroupName+'''",</Group>
      </Entities>
      <Axis Point1="'''+str(AxPt1).strip('()') + '''" Point2="'''+str(AxPt2).strip('()') + '''" Value="Select"/>
      <Radius Value="46"/>
      <ProjectMidNodes Value="0"/>
      <EntityType Value="1"/>
     </AlignCylinder>''';
    simlab.execute(AlignCylinder);
    
    i=i+1

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1605889.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[生活][杂项] 上班党的注意事项

前言 目前是上班已经接近两年了&#xff0c;目前的状态是&#xff0c;一个人租了一个单间在上班。对于这种情况有以下几点需要注意。 钥匙问题&#xff0c;一定不要陷入钥匙丢失的情况&#xff01;一定不要陷入钥匙丢失的情况&#xff01;一定不要陷入钥匙丢失的情况&#xff…

OpenHarmony多媒体-video_trimmer

简介 videotrimmer是在OpenHarmony环境下&#xff0c;提供视频剪辑能力的三方库。 效果展示&#xff1a; 安装教程 ohpm install ohos/videotrimmerOpenHarmony ohpm环境配置等更多内容&#xff0c;请参考 如何安装OpenHarmony ohpm包 。 使用说明 目前支持MP4格式。 视频…

Flattened Butterfly 扁平蝶形拓扑

Flattened Butterfly 扁平蝶形拓扑 1. 传统蝶形网络 Butterfly Topology2. 扁平蝶形拓扑 Flattened Butterfly3.On-Chip Flattened Butterfly 扁平蝶形拓扑应用于片上网络 Flattened Butterfly 扁平蝶形拓扑 扁平蝶形拓扑是一种经济高效的拓扑&#xff0c;适用于高基数路由器…

Golang入门基础

文章目录 Golang的背景知识Golang的发展历程Golang的特点Golang的应用领域 开发环境搭建下载并安装SDK包设置环境变量Go项目目录结构 注释变量标识符命名输入和输出运算符算术运算符关系运算符逻辑运算符赋值运算符位运算符其他运算符 Golang的背景知识 Golang的发展历程 Gola…

2024年华中杯数学建模竞赛ABC题思路分析

简单分析一下各个题目可能需要用到的方法和模型&#xff0c;完整代码和成品论文见文末 A题 太阳能路灯光伏板的朝向设计问题: 1. 球面几何、天文学相关知识,如赤纬角、太阳高度角、时角等概念和公式 2. 太阳辐射模型,根据太阳能辐射强度、大气衰减系数等计算地表太阳辐射强度…

2.核心概念与安装配置

核心概念与安装配置 文章目录 核心概念与安装配置1、核心概念Docker整体架构及底层通信原理 2、安装DockerCentos安装Docker引擎阿里云镜像加速Docker run的过程 3、Docker相关命令 1、核心概念 镜像&#xff08;image&#xff09; Docker 镜像&#xff08;Image&#xff09;就…

【三维Dvhop定位】基于麻雀搜索算法的多通信半径和跳距加权的三维Dvhop定位算法【Matlab代码#81】

文章目录 【可更换其他算法&#xff0c;获取资源请见文章第6节&#xff1a;资源获取】1. Dvhop定位算法2. 麻雀搜索算法3. 多通信半径和跳距加权策略3.1 多通信半径策略3.2 跳距加权策略 4. 部分代码展示5. 仿真结果展示6. 资源获取 【可更换其他算法&#xff0c;获取资源请见文…

Istio介绍

1.什么是Istio Istio是一个开源的服务网格&#xff08;Service Mesh&#xff09;框架&#xff0c;它提供了一种简单的方式来为部署在Kubernetes等容器编排平台上的微服务应用添加网络功能。Istio的核心功能包括&#xff1a; 服务治理&#xff1a;Istio能够帮助管理服务之间的…

openGauss学习笔记-266 openGauss性能调优-TPCC性能调优测试指导-文件系统配置

文章目录 openGauss学习笔记-266 openGauss性能调优-TPCC性能调优测试指导-文件系统配置266.1 查看当前数据盘的文件系统类型266.2 对于需要修改的磁盘&#xff0c;备份所需的数据至其他磁盘或其他服务器266.3 格式化磁盘为xfs文件系统266.4 执行**步骤一** openGauss学习笔记-…

allure2教程-3-测试报告定制

领取资料&#xff0c;咨询答疑&#xff0c;请➕wei: June__Go 上一小节&#xff0c;我们学习一下pytestallure2生成html测试报告的方法&#xff0c;本小节我们学习一下allure2测试报告的定制。 allure2报告预览 预览网址&#xff1a;https://demo.qameta.io/allure/# allur…

WordPress的全面解析:为什么它是创建博客和网站的首选

在当前的数字化时代&#xff0c;无论是个人博客还是企业网站&#xff0c;都需要一个强大而灵活的平台以支撑其内容和用户交互。WordPress作为全球最流行的内容管理系统&#xff08;CMS&#xff09;&#xff0c;以其强大的功能、灵活的定制性和广泛的用户基础&#xff0c;成为了…

问答营销之官方号问答推广技巧

问答营销作为一种网络推广的重要手段&#xff0c;受到各大品牌企业的关注。实战中&#xff0c;问答营销有新起提问再回答和直接回复老问题两种形式&#xff0c;一般做企业官方号问答营销都是选择后者。这里小马识途营销顾问详细解析下开展老问题回复营销的思路和步骤。 一、分析…

[蓝桥杯 | 暴搜] 学会暴搜之路

虽然会调侃蓝桥杯是暴力求解的&#xff0c;但是本弱弱不会搜&#xff0c;不知道如何搜&#xff0c;于是写下这篇碎碎念&#xff0c;记录看到过的&#xff0c;惊艳自己的暴搜。 小总结 题目特征&#xff1a;很复杂的排列组合 说是暴力&#xff0c;其实就是枚举罢了&#xff0…

如何理解信创产品?成为信创产品?

信创产品是指运用信息技术手段创造的产品&#xff0c;它是数据安全、网络安全的基础&#xff0c;也是新基建的重要组成部分。信创产品包括了IT基础设施如CPU芯片、服务器、存储、交换机、路由器、各种云和相关服务内容&#xff1b;基础软件如数据库、操作系统、中间件&#xff…

FebHost:谁可以注册.CA加拿大域名?

在加拿大&#xff0c;互联网域名的注册管理遵循一套独特的规则。特别是对于代表加拿大身份的顶级域名“.ca”&#xff0c;其申请和注册过程涉及一些严格的条件。这些条件确保了只有符合特定标准的个人或实体才能获得这一具有国家象征意义的网络地址。 首先&#xff0c;想要注册…

初识C++ · 类和对象(中)(1)

目录 1 类的6个默认成员函数 2 构造函数 3 析构函数 3 拷贝构造函数 1 类的6个默认成员函数 class Date { public:private:}; 这是一个空类&#xff0c;试问里面有什么&#xff1f; 可能你会觉得奇怪&#xff0c;明明是一个空类&#xff0c;却问里面有什么。其实一点也不…

PE文件(一)PE结构概述

PE结构简述 Windows操作系统是只能运行以内存4D 5A开头&#xff0c;翻译是MZ的可执行文件&#xff0c;也叫做PE结构文件&#xff0c;是以exe&#xff0c;.sys&#xff0c;.dll等等作为后缀的文件。而不同的操作系统能运行的可执行文件都是各自特有的&#xff0c;比如Linux可运…

zabbix 自定义模板,邮件报警,代理服务器,自动发现与自动添加及snmp

目录 一. 自定义监控内容 1. 在客户端创建自定义 key 2. 在 web 页面创建自定义监控项模块 2.1 创建模板 2.2 创建应用集 2.3 创建监控项 2.4 创建触发器 2.5 创建图形 2.6 将主机与模板关联起来 登录测试 2.7 设置邮件报警 测试邮件报警 3. nginx 服务状况的检测…

2024年腾讯云服务器价格一览表

随着云计算技术的快速发展&#xff0c;越来越多的企业和个人开始选择使用云服务器来满足他们的数据存储和计算需求。腾讯云作为国内领先的云服务提供商&#xff0c;其服务器产品因性能稳定、安全可靠而备受用户青睐。那么&#xff0c;2024年腾讯云服务器的价格情况如何呢&#…

状态压缩DP题单

P1433 吃奶酪&#xff08;最短路&#xff09; dp(i, s) 表示从 i 出发经过的点的记录为 s 的路线距离最小值 #include<bits/stdc.h> #define int long long using namespace std; const int N 20; signed main() { int n; cin >> n;vector<double>x(n 1),…