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

相关文章

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.