球面谐波函数 (Spherical harmonic function)分析实际颗粒形状公式推导及数值实现 Part 1

本文主要是介绍球面谐波函数 (Spherical harmonic function)分析实际颗粒形状公式推导及数值实现 Part 1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、公式推导

        球面谐波函数是一组定义在单位球上的基函数,是傅里叶展开式的一种;球面谐波函数最早应用于电磁场、核物理学、行星重力场计算,Garboczi (2002)最早基于该方法分析了混凝土集料的颗粒形状特性;展现出其对颗粒形状解析表征的强大能力。

         球面谐波函数对颗粒形状分析主要原理是将颗粒的形状视作一个三维的解析表达式,并能够用球面谐波基函数的线性组合进行展开,如下式表示:

\begin{equation} v(\theta, \phi)=\sum_{n=0}^{\infty} \sum_{m=-n}^n c_n^m Y_n^m(\theta, \phi) \end{equation}

其中,n表示阶数,m表示次数;$Y_n^m$表示球面谐波基函数,表达式如下:

\begin{equation} Y_n^m(\theta, \phi)=\sqrt{\left(\frac{(2 n+1)(n-m) !}{4 \pi(n+m) !}\right)} P_n^m(\cos (\theta)) e^{j m \phi} \end{equation}

$P_n^m$表示关联勒让德函数,系数的表达式如下:

\begin{equation} c_n^m=\int_0^{2 \pi} \int_0^\pi \mathrm{d} \phi \mathrm{d} \theta \sin (\theta) r(\theta, \phi) Y_n^{m *} \end{equation}

其中星号表示共轭复数。以上是Garboczi在该方法的原始文献中提出的系数求解方法;后续的研究对此求解方法进行了改进(Zhou Bo等, 2015,香港城市大学),$P_n^m$的表达式可以写成:

其中,p_n(x)表达式如下:

        接下来是系数的计算,将要分析的颗粒的表面进行参数化,映射到一个单位球体中(接下来的文章中再介绍),坐标用V表示,如下:

      那么根据第一个式子,我们就能得到一个线性方程组,注意这个方程组中是将Y_n^m转化成一个行向量,依次计算(m,n)为(0,0)、(-1,1)、(0,1) ......时候的值,如下所示:

这样只要选的原始颗粒上的坐标个数i足够多大于(n+1)^2,就能得到确定的系数值。

二、球面谐波基函数Y_n^m的数值实现

            数值实现时,一般采用分段的形式将球面谐波函数写出:

n=0时候,Y_n^m等于:

            在Matlab中编程实现(实数形式的基函数),程序及注释如下:

 % 定义参数l = 3; % 角动量量子数m = -3; % 磁量子数% 创建球坐标网格theta = linspace(0, pi, 100);phi = linspace(0, 2*pi, 200);[Theta, Phi] = meshgrid(theta, phi);if l ~= 0% 计算KlmKlm = sqrt((2 * l + 1) * factorial(l - abs(m)) / (4 * pi * factorial(l + abs(m))));if m > 0% 计算勒让德多项式Plm1 = legendre(l,cos(Theta));Plm = reshape(Plm1(m + 1,:,:), size(Phi));Ylm = sqrt(2) .* Klm .* cos(m .* Phi) .* Plm;endif m < 0Plm1 = legendre(l,cos(Theta));Plm = reshape(Plm1(- m + 1,:,:), size(Phi));Ylm = sqrt(2) .* Klm .* sin(- m .* Phi) .* Plm;endif m == 0Klm = sqrt((2 * l + 1) * factorial(l - abs(m)) / (4 * pi * factorial(l + abs(m))));Plm1 = legendre(l,cos(Theta));Plm = reshape(Plm1(m + 1,:,:), size(Phi));Ylm = Klm .* Plm;end% 可视化R = abs(Ylm); % 球面谐波函数的幅度X = R .* sin(Theta) .* cos(Phi);Y = R .* sin(Theta) .* sin(Phi);Z = R .* cos(Theta);figure;surf(X, Y, Z, real(Ylm),'EdgeColor','none'); % 使用实部作为颜色映射title(['球面谐波函数 Y_', num2str(l), '^', num2str(m)]);xlabel('X');ylabel('Y');zlabel('Z');colormap('jet')colorbar;axis equal;elseYlm = 0.5 * sqrt(1 / pi);% 可视化R = abs(Ylm); % 球面谐波函数的幅度X = R .* sin(Theta) .* cos(Phi);Y = R .* sin(Theta) .* sin(Phi);Z = R .* cos(Theta);figure;surf(X, Y, Z,'EdgeColor','none'); % 使用实部作为颜色映射title(['球面谐波函数 Y_', num2str(l), '^', num2str(m)]);xlabel('X');ylabel('Y');zlabel('Z');colormap('jet')colorbar;axis equal;end

运行结果:

相关的Python程序链接:

https://scipython.com/blog/visualizing-the-real-forms-of-the-spherical-harmonics/

理论链接:

https://mrtrix.readthedocs.io/en/latest/concepts/spherical_harmonics.html

这篇关于球面谐波函数 (Spherical harmonic function)分析实际颗粒形状公式推导及数值实现 Part 1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/656089

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

uva 10014 Simple calculations(数学推导)

直接按照题意来推导最后的结果就行了。 开始的时候只做到了第一个推导,第二次没有继续下去。 代码: #include<stdio.h>int main(){int T, n, i;double a, aa, sum, temp, ans;scanf("%d", &T);while(T--){scanf("%d", &n);scanf("%lf", &first);scanf

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P