球面谐波函数 (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

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一