news 2026/5/25 13:23:19

岩土颗粒粗糙度计算,采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度,算术平均粗糙度

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
岩土颗粒粗糙度计算,采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度,算术平均粗糙度

岩土颗粒粗糙度计算,采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度,算术平均粗糙度。 方法来自《非规则颗粒形态表征与离散元模拟方法的研究》清华大学出版社 matalb源代码

傅里叶展开在岩土颗粒形态分析中的应用挺有意思。咱们今天直接上干货,用MATLAB实现颗粒轮廓的粗糙度计算。先看核心思路:把颗粒轮廓坐标展开成傅里叶级数,通过高频分量分析表面起伏特征。

先整点基础代码框架。读取颗粒轮廓数据这个步骤不能省,假设咱们的轮廓数据是极坐标系下的半径数组:

theta = linspace(0, 2*pi, 360); % 极角均匀采样 r = load('particle_radius.txt'); % 从文件加载半径数据

接下来是傅里叶变换的重头戏。这里有个坑要注意——原始数据需要做周期性延拓处理,否则边界跳变会污染频谱:

N = length(r); mean_r = mean(r); r_centered = r - mean_r; % 消除直流分量 % 加汉宁窗减少频谱泄漏 window = hanning(N)'; r_windowed = r_centered .* window; % 执行FFT fft_coeff = fft(r_windowed)/N;

傅里叶系数处理是关键。根据清华那本书里的方法,前10%的低频分量对应颗粒整体形状,后面的是粗糙度贡献。咱们取第30阶之后的谐波:

cutoff = 30; % 经验阈值 roughness_coeff = fft_coeff; roughness_coeff(1:cutoff) = 0; % 滤除低频 roughness_coeff(end-cutoff+1:end) = 0; % 对称处理

重构粗糙度轮廓时,记得恢复直流分量:

roughness_profile = real(ifft(roughness_coeff*N)) + mean_r;

计算指标部分最带劲。均方根粗糙度RMS和算术平均粗糙度Ra这两个参数,实现起来相当直观:

deviation = roughness_profile - mean_r; RMS = sqrt(mean(deviation.^2)); Ra = mean(abs(deviation)); disp(['颗粒粗糙度指标: RMS=',num2str(RMS),' Ra=',num2str(Ra)])

代码跑起来后可能会遇到频谱混叠问题。如果发现重构曲线有锯齿,试试调整采样点数到2的整数次幂。比如把360点插值到512点,这样FFT效率更高,频谱分辨率也更好。

实际测试中发现,花岗岩颗粒的RMS通常在0.02-0.05mm之间,而砂岩颗粒能达到0.1mm以上。这个差异在离散元模拟中会显著影响接触力的计算结果,所以参数标定千万别偷懒。

最后提醒下,原始轮廓数据的采集质量直接影响结果。用光学扫描仪获取数据时,记得做各向同性滤波处理,不然方向性噪声会污染高频分量。搞定这些细节,粗糙度分析才能真正指导工程实践。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 6:22:18

AXI-A7.4.3 Atomic transactions attributes

一、atomic transactions are as follows: 1. AWLEN和AWSIZE指定写数据的字节数(对于AtomicCompare需包含比较值和交换值) AWLEN(突发长度)和AWSIZE(每次传输的字节数)共同决定了原子事务中写数据的总字节数。对于大多数原子事务,这指的是操作数的大小;但对于AtomicCom…

作者头像 李华
网站建设 2026/5/25 8:54:06

内存泄漏怎么定位和解决?core dump有哪些信息?

一、为什么会内存泄漏?常见场景:音频播放反复malloc缓冲区未freeMQTT断线重连时不断分配内存呢解析JSON字符串频繁申请堆空间回调注册后未注销导致上下文无法释放使用全局链表或队列但不清除节点二、如何定位内存泄漏?1、添加内存监控接口在T…

作者头像 李华
网站建设 2026/5/25 14:07:58

STL deque 的详细特征

STL deque 的详细特征 基本特性 #include <deque> using namespace std;deque<int> dq; // 声明一个int类型的双端队列 双端队列&#xff1a;允许在两端进行高效插入和删除动态数组&#xff1a;支持随机访问&#xff0c;可以像数组一样通过下标访问内存结构&a…

作者头像 李华
网站建设 2026/5/25 12:18:29

9.快速修改铜皮

铺铜后&#xff0c;需要进行细微调整。常规的方法使用鼠标拉扯铜皮边缘修改&#xff0c;很痛苦&#xff01;&#xff01;&#xff01;且效率非常低。技巧&#xff1a;1.选中要修改的铜皮2.如图所示&#xff1a;先选中modify&#xff0c;然后修改&#xff0c;然后重新铺铜。注意…

作者头像 李华
网站建设 2026/5/26 7:18:07

10.是否要成为全栈工程师?

1、软件工程师 嵌入式软件工程师 硬件工程师的关系一、各自的核心工作1. 软件工程师&#xff08;通常指“纯软件/应用层工程师”&#xff09;工作内容&#xff1a;负责非硬件相关的软件逻辑&#xff0c;比如&#xff1a;业务功能开发&#xff08;如APP界面、数据处理算法、网络…

作者头像 李华
网站建设 2026/5/25 2:22:17

兰顿蚂蚁——CAD二次开发

效果如下:private static void OnTick(object sender, EventArgs e){if (_currentStep > _maxSteps){Stop();return;}// 检查是否暂停if (_isPaused)return;Document doc Application.DocumentManager.MdiActiveDocument;Database db doc.Database;var ed doc.Editor;usi…

作者头像 李华