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

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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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 mathimport gmsh
import sysgmsh.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.rhkb.cn/news/495836.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Go C编程 第6课 无人机 --- 计算旋转角

旋转的秘密---认识角度 rt、lt命令学习 goc电子课程 一、编程步骤 第一步 第二步 第三步 第四步 二、画“四轴无人机” (一)、画第一根机轴 (二)、画第二根机轴 (三)、画完整的无人机 三、画“多轴无人…

Java中以某字符串开头且忽略大小写字母如何实现【正则表达式(Regex)】

第一种思路是先将它们都转换为小写或大写,再使用String类的startsWith()方法实现: 例如,如下的二个示例: "Session".toLowerCase().startsWith("sEsSi".toLowerCase()); //例子之一//例子之二String str "Hello Wo…

虚拟机桥接模式网络连接不上解决方法

可能是桥接模式自动配置网络地址的时候没配好,自己手动配置一下。先看看windows里的wifi的ip 把虚拟机的网络设置打开ipv4把地址、子网掩码、网关输进去,然后再连接

频繁拿下定点,华玉高性能中间件迈入商业化新阶段

伴随着智能驾驶渗透率的快速增长,中国基础软件市场开始进入黄金窗口期。 近日,华玉通软(下称“华玉”)正式获得某国内头部轨道交通产业集团的智能化中间件平台定点项目。这将是华玉在基础软件领域深耕和商业化发展过程中的又一重…

Java:188 基于springboot妇幼健康管理系统

作者主页:舒克日记 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 本妇幼健康管理系统分为管理员、用户、医生三个权限。 管理员可以管理用户、医生的基本信息内容,可以管理药物信息以及患者预约信息等操作…

使用Excel制作通达信自定义“序列数据“

序列数据的视频教程演示 Excel制作通达信自定义序列数据 1.序列数据的制作方法:删掉没有用的数据(行与列)和股代码格式处理,是和外部数据的制作方法是相同,自己上面看历史博文。只需要判断一下,股代码跟随的…

计算机网络概要与习题

第1章 概论 1、计算机网络 2、互联网 3、计算机网络体系结构 分层模型 OSI/RM 7层模型 TCP/IP 5层模型 协议、PDU、SDU、SAP等术语 数据封装(计算) 第2章 数据通信基础 1、数据通信系统组成 2、主要性能指标 数据传输速率 码元速率 时延 …

微信小程序-基于Vant Weapp UI 组件库的Area 省市区选择

Area 省市区选择,省市区选择组件通常与 弹出层 组件配合使用。 areaList 格式 areaList 为对象结构,包含 province_list、city_list、county_list 三个 key。 每项以地区码作为 key,省市区名字作为 value。地区码为 6 位数字,前两…

每天40分玩转Django:Django静态文件

Django静态文件 一、今日学习内容概述 学习模块重要程度主要内容静态文件配置⭐⭐⭐⭐⭐基础设置、路径配置CDN集成⭐⭐⭐⭐⭐CDN配置、资源优化静态文件处理⭐⭐⭐⭐压缩、版本控制部署优化⭐⭐⭐⭐性能优化、缓存策略 二、基础配置 # settings.py import os# 静态文件配置…

Python数据处理——re库与pydantic的使用总结与实战,处理采集到的思科ASA防火墙设备信息

目录 Python正则表达式re库的基本用法 引入re库 各函数功能 总结 使用方法举例 正则表达式语法与书写方式 正则表达式的常用操作符 思科ASA防火墙数据 数据1 数据2 书写正则表达式 Python中pydantic的使用 导入基础数据模板 根据数据采集目标定义Pydantic数据类型…

「Python数据科学」标量、向量、矩阵、张量与多维数组的辨析

引言 在数据科学中,有很多概念,其中,最容易搞混的就是标量、向量、矩阵、张量了。具体到这些概念的落地实现,又与多维数组有着密不可分的联系。 本文就来尝试对这些概念进行简要地梳理,从而更加清晰地理解这些概念及…

iOS开发代码块-OC版

iOS开发代码块-OC版 资源分享资源使用详情Xcode自带代码块自定义代码块 资源分享 自提: 通过网盘分享的文件:CodeSnippets 2.zip 链接: https://pan.baidu.com/s/1Yh8q9PbyeNpuYpasG4IiVg?pwddn1i 提取码: dn1i Xcode中的代码片段默认放在下面的目录中…

第十七届山东省职业院校技能大赛 中职组“网络安全”赛项任务书正式赛题

第十七届山东省职业院校技能大赛 中职组“网络安全”赛项任务书-A 目录 一、竞赛阶段 二、竞赛任务书内容 (一)拓扑图 (二)模块A 基础设施设置与安全加固(200分) (三)B模块安全事件响应/网络安全数据取证/…

Git(11)之log显示支持中文

Git(11)之log显示支持中文 Author:Once Day Date:2024年12月21日 漫漫长路有人对你微笑过嘛… 参考文档:GIT使用log命令显示中文乱码_gitlab的log在matlab里显示中文乱码-CSDN博客 全系列文章可查看专栏: Git使用记录_Once_day的博客-CSD…

rabbitmq相关使用

使用rabbitmq实现异步解耦 使用步骤&#xff1a; 1、pom依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId> </dependency> 2、yml配置文件 spring:rabbitmq:host: 12…

oracle linux8.10+ oracle 23ai安装

介质准备&#xff1a; 数据库23ai https://edelivery.oracle.com 上述网站下载基础版本&#xff0c;本次未使用。 本次是安装了带补丁的版本&#xff1a; Database Release Update 23.6.0.24.10 GoldImage表示带补丁用于直接安装的软件包 查找888.1对应Primary Note for …

使用helm安装canal-server和canal-admin

1.前置条件&#xff1a; 需要电脑有helm kubectl 如果没有的话需要安装环境 2.需要拉取canal-server和canal-admin镜像 拉取镜像的时候可能存在拉取不下来的情况&#xff0c;需要配置&#xff1a; /etc/docker/daemon.json {"registry-mirrors": ["https://do…

使用ForceBindIP绑定应用到指定IP

前言 使用ForceBindIP工具&#xff0c;用户可以轻松地将特定应用程序绑定到指定的IP地址&#xff0c;从而确保应用程序的网络连接通过指定的网络适配器进行。通过在命令提示符下运行ForceBindIP并指定IP地址和应用程序的完整路径&#xff0c;用户能够控制应用程序的网络流量&a…

Windows下安装Rabbit MQ

一、安装环境&#xff1a; 系统&#xff1a;windows11; 环境配置安装&#xff1a;otp_win64_25.3.2.14.exe&#xff08;erlang类库&#xff09;&#xff1b; 服务应用安装&#xff1a;rabbitmq-server-3.12.4.exe&#xff1b; 二、erlang环境&#xff1a; 1.执行…

层序遍历练习

层次遍历 II 给定一个二叉树&#xff0c;返回其节点值自底向上的层次遍历。 &#xff08;即按从叶子节点所在层到根节点所在的层&#xff0c;逐层从左向右遍历&#xff09; 思路 相对于102.二叉树的层序遍历&#xff0c;就是最后把result数组反转一下就可以了。 C代码&…