Gmsh有限元网格剖分(Python)---点、直线、平面的移动

news2024/12/27 6:09:56

Gmsh有限元网格剖分(Python)—点、直线、平面的移动和旋转

最近在学习有限元的网格剖分算法,主要还是要参考老外的开源Gmsh库进行,写一些博客记录下学习过程,方便以后回忆嘞。

Gmsh的官方英文文档可以参考:gmsh.pdf

但咋就说,这里面东西太多了,不太适合初学者去看,因此分享下自己学习的过程吧。

此次记录基于下面博客的内容:

Gmsh有限元网格剖分(Python)—任意点、直线、平面的创建

目录

  • Gmsh有限元网格剖分(Python)---点、直线、平面的移动和旋转
    • 1、点、直线、平面的移动
      • 1.1 点的移动
      • 1.2 线的移动
      • 1.3 面的移动
      • 1.4 总结
    • 2、点、直线、平面的旋转
      • 2.1、点的旋转
      • 2.2、线的旋转
      • 2.3、线的旋转-旋转图形中的线
      • 2.4、面的旋转

1、点、直线、平面的移动

1.1 点的移动

在Gmsh有限元网格剖分(Python)—任意点、直线、平面的创建的代码中额外创建一个点并连线:

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

绘制得到的结果如下:
在这里插入图片描述
使用下面的命令对新创建的点进行平移,其中:

------ [(0, point5_tag)]:0是代表移动的是0维的点,point5_tag是要移动的点的编号
------dx、dy、dz是向各个方向平移的距离

kernel.translate([(0, point5_tag)], dx=1, dy=0, dz=0)

geo引擎
如果我们使用gmsh自带的kernel = gmsh.model.geo引擎,可以看到平移后的线依旧连接,创建的线会和点一起移动:
在这里插入图片描述
occ引擎
如果我们使用Open CASCADE的kernel = gmsh.model.occ引擎,可以看到平移后的线不动,只移动单个点:
在这里插入图片描述
全部代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.translate([(0, point5_tag)], dx=1, dy=0, dz=0)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

1.2 线的移动

线的移动基于同样的函数,其解释和代码如下:

------ [(1, line5_tag)]:1是代表移动的是1维的线,line5_tag是要移动的点的编号
------dx、dy、dz是向各个方向平移的距离

kernel.translate([(1, line5_tag)], dx=1, dy=0, dz=0)

occ引擎
如果我们使用Open CASCADE的kernel = gmsh.model.occ引擎,可以看到实际中线被平移了:
在这里插入图片描述
geo引擎
如果我们使用gmsh自带的kernel = gmsh.model.geo引擎,线的移动会改变原有的和线连接的结构,总之就是结构全部耦合在一块了:
在这里插入图片描述
全部代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.translate([(1, line5_tag)], dx=1, dy=0, dz=0)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

1.3 面的移动

面的移动基于同样的函数,其解释和代码如下(将平面向上移动):

------ [(2, surface_tag)]:2是代表移动的是2维的面,surface_tag是要移动的面的编号
------dx、dy、dz是向各个方向平移的距离

kernel.translate([(2, surface_tag)], dx=0, dy=0, dz=1)

occ引擎
如果我们使用Open CASCADE的kernel = gmsh.model.occ引擎,可以看到实际中单独的这个面被平移了,其余结构没有变化:
在这里插入图片描述
geo引擎
如果我们使用gmsh自带的kernel = gmsh.model.geo引擎,面的移动会改变原有的和线连接的结构:
在这里插入图片描述
代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.translate([(2, surface_tag)], dx=0, dy=0, dz=1)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

1.4 总结

kernel = gmsh.model.geo时对形状的编辑耦合比较严重
kernel = gmsh.model.occ时各个图形隔离度高,推荐使用occ引擎

2、点、直线、平面的旋转

2.1、点的旋转

使用下面的函数进行旋转:

kernel.rotate([(0, point5_tag)], 1, 1, 0, 0, 0, 1, -math.pi / 2)

其中:

------ [(0, point5_tag)]:0是代表移动的是0维的点,point5_tag是要移动的点的编号
------1, 1, 0参数代表旋转选择的中心点在坐标(1,1,0)
------0, 0, 1参数代表选择所绕的轴是Z轴
------(-math.pi / 2)参数表示是顺时针旋转90°

occ引擎
如果我们使用Open CASCADE的kernel = gmsh.model.occ引擎,可以看到只有点被旋转过去了:
在这里插入图片描述
geo引擎
如果我们使用gmsh自带的kernel = gmsh.model.geo引擎,可以看到点和点所在的线全部被旋转了:
在这里插入图片描述
全部代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.rotate([(0, point5_tag)], 1, 1, 0, 0, 0, 1, -math.pi / 2)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")

# 2维网格剖分
gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

2.2、线的旋转

使用下面的函数进行旋转:

kernel.rotate([(1, line5_tag)], 1, 1, 0, 0, 0, 1, -math.pi / 2)

其中:

------ [(1, line5_tag)]:1是代表移动的是1维的线,line5_tag是要移动的线的编号
------1, 1, 0参数代表旋转选择的中心点在坐标(1,1,0)
------0, 0, 1参数代表选择所绕的轴是Z轴
------(-math.pi / 2)参数表示是顺时针旋转90°

occ引擎
如果我们使用Open CASCADE的kernel = gmsh.model.occ引擎,可以看到线和线上的点被成功旋转90°:
在这里插入图片描述
geo引擎
如果我们使用gmsh自带的kernel = gmsh.model.geo引擎,可以看到线和线上的点被成功旋转90°,此时使用两个3维引擎效果是一致的:
在这里插入图片描述
全部代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.rotate([(1, line5_tag)], 1, 1, 0, 0, 0, 1, -math.pi / 2)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

2.3、线的旋转-旋转图形中的线

但是,上面我们旋转的线是单独的一根独立的线,如果我们选择旋转现有的构成图形的线,两个引擎会不会有什么区别呢?旋转的目标是下面这个,我们想将其逆时针旋转90°:
在这里插入图片描述
occ引擎-实际上是复制并旋转,这是为了保持原结构不变:
在这里插入图片描述
geo引擎-原来边的对应关系也全部改变了,逻辑关系比较复杂:
在这里插入图片描述
代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.rotate([(1, line2_tag)], 0, 1, 0, 0, 0, 1, math.pi / 2)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
# gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

2.4、面的旋转

使用下面的函数进行旋转:

kernel.rotate([(2, surface_tag)], 0, 0, 0, 0, 0, 1, math.pi / 4)

其中:

------ [(2, surface_tag)]:1是代表移动的是2维的面,surface_tag是要移动的面的编号
------0, 0 0参数代表旋转选择的中心点在坐标(0,0,0)
------0, 0, 1参数代表选择所绕的轴是Z轴
------(math.pi / 4)参数表示是逆时针旋转45°

occ引擎-可以看到原来的正方形向左滚了45°,但是线的位置不变:
在这里插入图片描述

geo引擎-可以看到原来的正方形向左滚了45°,且那线也跟着一起走了,结构是耦合的:
在这里插入图片描述
代码:

import math

import gmsh
import sys

gmsh.initialize()
# 新建模型,命名为t1,t1指的是整个结构
gmsh.model.add("my_t2")

kernel = gmsh.model.geo
mesh_size = 5e-1
point1_tag = kernel.addPoint(0, 0, 0, meshSize=mesh_size)
point2_tag = kernel.addPoint(0, 1, 0, meshSize=mesh_size)
point3_tag = kernel.addPoint(1, 0, 0, meshSize=mesh_size)
point4_tag = kernel.addPoint(1, 1, 0, meshSize=mesh_size)
line1_tag = kernel.addLine(point1_tag, point2_tag)
line2_tag = kernel.addLine(point2_tag, point4_tag)
line3_tag = kernel.addLine(point4_tag, point3_tag)
line4_tag = kernel.addLine(point3_tag, point1_tag)
curve_loop_tag = kernel.addCurveLoop([line1_tag, line2_tag, line3_tag, line4_tag])
surface_tag = kernel.addPlaneSurface([curve_loop_tag])

point5_tag = kernel.addPoint(1, 2, 0, meshSize=mesh_size)
line5_tag = kernel.addLine(point4_tag, point5_tag)

kernel.rotate([(2, surface_tag)], 0, 0, 0, 0, 0, 1, math.pi / 4)

# GMSH模型同步
kernel.synchronize()
# 创建点集合,命名为My point
gmsh.model.addPhysicalGroup(2, [surface_tag], name="My Surface")



# 2维网格剖分
# gmsh.model.mesh.generate(2)
# 保存一下
gmsh.write("my_t1.msh")
# 默认启动gui界面
if '-nopopup' not in sys.argv:
    gmsh.fltk.run()
# 结束gmsh
gmsh.finalize()

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

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

相关文章

代码随想录Day39 198.打家劫舍,213.打家劫舍II,337.打家劫舍 III。

1.打家劫舍 力扣题目链接(opens new window) 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统…

01-linux基础命令

一、linux命令概述 命令 选项 参数命令 :就是命令名;选项:一般以 - 开头 比如:-a -p -r 等扩展命令的功能;参数:描述命令的目标,如我们要打开一个文件的话,参数就是要打开的文件名…

MATLAB符号计算-初步认识符号对象

1.1自顶向下的程序设计方法 【例1-1】列主元Guass消去法解方程组 a[2 -3 5 -1;1 4 2 -3;-2 4 -3 -7;8 0 -2 1]; b[3 7 -1 8]; sLZYguass(a,b) 代码还有问题,x11.1913,x21.1157,x30.8114,x40.0923 学长帮忙修改过: 反思: length()、size(…

支持向量机入门指南:从原理到实践

目录 1 支持向量机的基本概念 1.2 数学表达 2 间隔与支持向量 2.1 几何间隔 2.2 支持向量的概念 2.3 规范化超平面 2.4 支持向量的深入分析 2.4.1 支持向量的特征 2.4.2 支持向量的作用 2.4.3 支持向量的代数表示 2.5 KKT条件 3 最优化问题 3.1 问题的形成 3.2 规…

快速汇总Word表格

示例需求:Word文档中的有多个表格,其中最后一个表格为汇总表格,其他的为数据表格,如下图中左侧所示。 现在需要根据Category1和Category2,在数据表格中查找,如果找到匹配行,那么 为数据表中改…

OSCP课后练习-tcpdump

本篇文章旨在为网络安全渗透测试行业OSCP考证教学。通过阅读本文,读者将能够对tcpdump日志分析关键信息过滤有一定了解 1、下载练习分析文件 wget https://www.offensive-security.com/pwk-online/password_cracking_filtered.pcap2、查看分析文件所有内容 sudo t…

Linux快速入门-Linux的常用命令

Linux的常用命令 1. Linux的终端与工作区1.1 终端概述1.2 切换终端 2. Shell语言解释器2.1 Shell概述 3. 用户登录与身份切换3.1 su 命令3.2 sudo 命令 4. 文件、目录操作命令4.1 pwd 命令4.2 cd 命令4.3 ls 命令4.3.1 ls 指令叠加使用 4.4 mkdir 命令4.5 rmdir 命令4.6 cp 命令…

ASP.NET Web应用程序出现Maximum request length exceeded报错

一、问题描述 在ASP.NET的web应用中,导出数据时出现500 - Internal server error.Maximum request length exceeded。 二、原因分析 这个错误通常出现在Web应用程序中,表示客户端发送的HTTP请求的长度超过了服务器配置的最大请求长度限制。这可能是因为…

【JDBC】使用原生JDBC,数据量很大且内存空间较小的情况下,JavaHeap溢出

文章目录 使用原生JDBC,数据量很大且内存空间较小的情况下,JavaHeap非常容易溢出问题背景java.lang.OutOfMemoryError: Java heap space错误分析解决方案1. **优化数据库查询**2. **调整 JVM 堆内存**3. **批量处理数据**4. **线程池优化** 总结**Result…

uniapp 微信小程序 数据空白展示组件

效果图 html <template><view class"nodata"><view class""><image class"nodataimg":src"$publicfun.locaAndHttp()?localUrl:$publicfun.httpUrlImg(httUrl)"mode"aspectFit"></image>&l…

12.26 学习卷积神经网路(CNN)

完全是基于下面这个博客来进行学习的&#xff0c;感谢&#xff01; ​​【深度学习基础】详解Pytorch搭建CNN卷积神经网络LeNet-5实现手写数字识别_pytorch cnn-CSDN博客 基于深度神经网络DNN实现的手写数字识别&#xff0c;将灰度图像转换后的二维数组展平到一维&#xff0c;…

【团标】《信息工程造价政务信息化项目造价评估方法》(TCQAE11021-2023)-费用标准解读系列33

《信息工程造价政务信息化项目造价评估方法》&#xff08;TCQAE11021-2023&#xff09;是中国电子质量管理协会2023年发布&#xff0c;2023年12月16日开始实施的标准&#xff08;了解更多可直接关注我们咨询&#xff09;。该标准适用于政务信息化项目的造价评估&#xff0c;政务…

mybatisplu设置自动填充

/*** mybatisplus的自动化填充*/public class JboltMetaObjectHandler implements MetaObjectHandler {Overridepublic void insertFill(MetaObject metaObject) {LocalDateTime now LocalDateTime.now(ZoneId.of("Asia/Shanghai"));this.strictInsertFill(metaObje…

音视频入门基础:MPEG2-TS专题(23)——通过FFprobe显示TS流每个packet的信息

一、引言 通过FFprobe命令&#xff1a; ffprobe -of json -show_packets XXX.ts 可以显示TS流/TS文件每个packet&#xff08;也称为数据包或多媒体包&#xff09;的信息&#xff1a; 对于TS流&#xff0c;上述的“packet”&#xff08;数据包或多媒体包&#xff09;是指&…

Linux电源管理——CPU Hotplug 流程

目录 一、相关概念 二、基本原理 三、代码分析 1、CPU_ON 2、CPU_OFF References Linux Version&#xff1a;linux-5.4.239 一、相关概念 在单核操作系统中&#xff0c;操作系统只需管理一个CPU&#xff0c;当系统有任务需要执行时&#xff0c;所有的任务会在该CPU的就绪…

探索数据的艺术:R语言与Origin的完美结合

探索数据的艺术&#xff1a;R语言与Origin的完美结合 R语言统计分析与可视化从入门到精通内容简介获取方式 Origin绘图深度解析&#xff1a;科研数据的可视化艺术内容简介获取方式 R语言统计分析与可视化从入门到精通 内容简介 本书循序渐进、深入讲解了R语言数据统计分析与应…

python基础训练之元组的基本操作

主页包含元组基础知识点 【练习要求】 针对于元组的知识点进行常用的创建、定义、查询元素、查看元组长度等操作。效果实现如下 (注&#xff1a;特别要注意一下切片的用法) #创建元组的两种方法 T1 () T2 tuple() #定义一个元组并存储数据张三, 李四, 王五 T3 (张三, 李四…

选煤厂可视化技术助力智能化运营

通过图扑 HT 可视化搭建智慧选煤厂管理平台&#xff0c;优化了选煤生产流程&#xff0c;提高了资源利用率和安全性&#xff0c;助力企业实现智能化运营和可持续发展目标。

C语言基础:指针(数组指针与指针数组)

数组指针与指针数组 数组指针 概念&#xff1a;数组指针是指向数组的指针&#xff0c;本质上还是指针 特点&#xff1a; 先有数组&#xff0c;后有指针 它指向的是一个完整的数组 一维数组指针&#xff1a; 语法&#xff1a; 数据类型 (*指针变量名)[行容量][列容量]; 案…

接口测试Day03-postman断言关联

postman常用断言 注意&#xff1a;不需要手敲&#xff0c;点击自动生成 断言响应状态码 Status code&#xff1a;Code is 200 //断言响应状态码为 200 pm.test("Status code is 200", function () {pm.response.to.have.status(200); });pm: postman的实例 test() …