news 2026/5/1 8:46:32

岩土颗粒粗糙度计算,采用傅里叶展开。 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/1 8:03:20

软件测试面试喜欢问的linux文件操作命令总结

1切换目录 我们切换目录的命令是cd 但是在切换的时候,可以用两种形式,一种是绝对目录的形式切换,一种是相对目录的形式切换。 绝对路径:以 / 开头,或者 ~ 开头,分别表示根路径或者root路径。表示从根目录…

作者头像 李华
网站建设 2026/5/1 4:41:52

跨平台硬件直连:基于Flutter+鸿蒙的轻量化IoT解决方案

欢迎大家加入开源鸿蒙跨平台开发者社区,一起共建开源鸿蒙跨平台生态。 跨平台硬件直连:基于Flutter鸿蒙的轻量化IoT解决方案 在物联网开发中,跨平台兼容性与硬件直连能力至关重要。本方案结合Flutter的跨平台特性和鸿蒙系统的Sensor API&am…

作者头像 李华
网站建设 2026/4/30 7:46:39

飞控开发——熟悉uORB

基础讲解 基础术语 消息:数据格式模板(类似 “语言语法”),定义数据字段(如时间戳、具体参数),所有消息必须包含timestamp(时间戳)字段主题:消息的 “通信通…

作者头像 李华
网站建设 2026/5/1 4:42:44

煤层卸压开采瓦斯越流以及塑性变形 煤层工作开挖过程,会引起邻近煤岩层应力、变形场发生变化,以及...

煤层卸压开采瓦斯越流以及塑性变形 煤层工作开挖过程,会引起邻近煤岩层应力、变形场发生变化,以及引起临近煤层卸压,从而达到保护层开挖目的。 本模型根据煤岩层之间的位置关系,建立瓦斯流动场、煤岩弹塑性变形场,供大…

作者头像 李华