IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 基于python的三维射线追踪库-ttcrpy详解(1) -> 正文阅读

[人工智能]基于python的三维射线追踪库-ttcrpy详解(1)

基于python的三维射线追踪库-ttcrpy详解(1)

1、ttcrpy介绍

ttcrpy是一个用于计算初至时间和射线追踪路径的python软件包,开发时考虑了在地球物理方面的应用,例如基于射线的地震/GPR层析成像和微震事件定位(联合震源速度反演)。

该软件包可以用来执行计算2D和3D和矩形网格,以及2D三角形网格和3D四面体网格,用python来实现。该软件包实现了三种不同的射线追踪算法:快速扫描法、最短路径法和动态网格最短路径法。

该计算可以在多核机器上并行运行。核心计算代码是用C++写的,已经用cython包装好了。在python中可以快捷使用。

2、ttcrpy安装

电脑快捷键wins+R,打开快捷界面输入cmd,在cmd中利用pip可直接安装ttcrpy库,输入命令如下:

pip install ttcrpy

注意:安装和使用ttcrpy需要安装相关支持的库,如numpy、scipy、vtk,其中vtk的安装易出错。

3、ttcrpy网格介绍

ttcrpy中可以构建规则网格和不规则三角网格或四面体网格,在进行走时成像或射线追踪时需要对模型进行网格剖分,ttcrpy中给出了很灵活的网格剖分方式。
在这里插入图片描述
如上图所示,在最左边的情况下,慢度值被分配给网格的单元。在最右边的情况下,慢度值被分配给网格节点。在后一种情况下,两个节点之间的走时计算是通过取两个节点处慢度值的平均值来完成的。

选择主要取决于应用。例如,在走时层析成像中,问题是使用走时数据来估计慢度模型。直线网格包含的单元比节点少,因此,如果将慢度值分配给单元,未知参数的数量会更少。对于四面体网格,节点的数量少于单元的数量,并且如果将慢度值分配给节点,要求解的系统将更小。

4、代码解析及模型示例

在pthon中运行代码,第一步需要导入各种需要的库,导入ttcrpy库。

import ttcrpy.rgrid as rg
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

根据所需的模型,建立相应的三维网格。

# 创建网格
x = np.arange(15.0)
y = np.arange(14.0)
z = np.arange(21.0)

在这里,我们建立x、y、z三个方向网格数分别为15、14、21。然后建立一个三维速度模型,

# 三维速度模型
# 速度沿z方向线性变化
a = 1.0
V20 = 3.0
b = (V20-a)/20.0

V = np.empty((x.size, y.size, z.size))
for n in range(z.size):
    V[:, :, n] = a + b*z[n]

我们假设模型的速度值为沿着z方向增大,在python中显示一下模型,

# 画图,显示一下模型
fig = plt.figure(1)
ax = fig.add_subplot(111, projection='3d')

min_val = V.min()
max_val = V.max()
n_x, n_y, n_z = V.shape
colormap = plt.cm.plasma

cut = V[0,:,:]
Y, Z = np.mgrid[0:n_y, 0:n_z]
X = np.zeros((n_y, n_z))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
cut = V[:,-1,:]
X, Z = np.mgrid[0:n_x, 0:n_z]
Y = y[-1] + np.zeros((n_x, n_z))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
cut = V[:,:,-1]
X, Y = np.mgrid[0:n_x, 0:n_y]
Z = z[-1] + np.zeros((n_x, n_y))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
ax.invert_zaxis()
ax.set_title("Velocity model")
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
fig.tight_layout()
# plt.show()

模型结果如下图所示。
在这里插入图片描述
在速度模型建立正确的情况下,下一步就是设置发射点坐标与接收点坐标,

# 发射点和接收点的坐标

src = np.array([[0.5, 0.5, 0.5]])
rcv = np.array([[2.0, 2.0, 0.5],
                [4.0, 4.0, 0.5],
                [6.0, 6.0, 0.5],
                [8.0, 8.0, 0.5],
                [10.0, 10.0, 0.5],
                [12.0, 12.0, 2.5],
                [12.0, 12.0, 4.5],
                [12.0, 12.0, 6.5],
                [12.0, 12.0, 8.5],
                [12.0, 12.0, 10.5],
                [12.0, 12.0, 12.5],
                [12.0, 12.0, 14.5],
                [12.0, 12.0, 16.5],
                [10.0, 5.0, 20.0]])

将速度模型转换为慢度模型,、

# 慢度模型
grid = rg.Grid3d(x, y, z, cell_slowness=False)

# we need to input slowness
slowness = 1./V

运行ttcrpy代码,计算射线路径与初至走时。

tt, rays = grid.raytrace(src, rcv, slowness, return_rays=True)

显示走时

plt.figure(2)
plt.plot(tt, 'r-o')
plt.xlabel('Rcv number')
plt.ylabel('Traveltime')
# plt.show()

走时计算结果如下
在这里插入图片描述
最后,显示一下射线路径,
代码如下,

fig = plt.figure(3)
ax = fig.add_subplot(111, projection='3d')
min_val = V.min()
max_val = V.max()
n_x, n_y, n_z = V.shape
colormap = plt.cm.plasma

cut = V[:,:,-1]
X, Y = np.mgrid[0:n_x, 0:n_y]
Z = z[-1] + np.zeros((n_x, n_y))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)

for r in rays:
    ax.plot(r[:,0], r[:,1], r[:,2],'r-')

ax.invert_zaxis()
ax.set_title("Rays")
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
fig.tight_layout()

plt.show()

射线路径如下图所示
在这里插入图片描述

5、参考文献

Nasr, Maher; Giroux, Bernard et Dupuis, Christian J. (2020). A hybrid approach to compute seismic travel times in 3D tetrahedral meshes. Geophys. Prospect. DOI : 10.1111/1365-2478.12930 https://onlinelibrary.wiley.com/doi/abs/10.1111/1365-2478.12930
Giroux B et Larouche B. 2013. Task-parallel implementation of 3D shortest path raytracing for geophysical applications, Computers & Geosciences, 54, 130-141. DOI : https://www.sciencedirect.com/science/article/pii/S0098300412004128
Nasr M, Giroux B, Dupuis JC, 2018. An optimized approach to compute traveltimes in 3D unstructured meshes. SEG Technical Program Expanded Abstracts 2018, pp. 5073-5077. DOI : 10.1190/segam2018-2997918.1 https://library.seg.org/doi/10.1190/segam2018-2997918.1
Giroux B. 2014. Comparison of grid-based methods for raytracing on unstructured meshes, SEG Technical Program Expanded Abstracts 2014, pp. 3388-3392. DOI : https://library.seg.org/doi/10.1190/segam2014-1197.1
Giroux B, 2013. Shortest path raytracing in tetrahedral meshes. 75th EAGE Conference & Exhibition, Londres, 10-13 June. DOI : 10.3997/2214-4609.20130236 https://www.earthdoc.org/content/papers/10.3997/2214-4609.20130236

6、完整代码

import ttcrpy.rgrid as rg
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

# 创建网格
x = np.arange(15.0)
y = np.arange(14.0)
z = np.arange(21.0)

# 三维速度模型
# 速度沿z方向线性变化
a = 1.0
V20 = 3.0
b = (V20-a)/20.0

V = np.empty((x.size, y.size, z.size))
for n in range(z.size):
    V[:, :, n] = a + b*z[n]

# 画图,显示一下模型
fig = plt.figure(1)
ax = fig.add_subplot(111, projection='3d')

min_val = V.min()
max_val = V.max()
n_x, n_y, n_z = V.shape
colormap = plt.cm.plasma

cut = V[0,:,:]
Y, Z = np.mgrid[0:n_y, 0:n_z]
X = np.zeros((n_y, n_z))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
cut = V[:,-1,:]
X, Z = np.mgrid[0:n_x, 0:n_z]
Y = y[-1] + np.zeros((n_x, n_z))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
cut = V[:,:,-1]
X, Y = np.mgrid[0:n_x, 0:n_y]
Z = z[-1] + np.zeros((n_x, n_y))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)
ax.invert_zaxis()
ax.set_title("Velocity model")
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
fig.tight_layout()
# plt.show()


# src and rcv should be 2D arrays
# 发射点和接收点的坐标

src = np.array([[0.5, 0.5, 0.5]])
rcv = np.array([[2.0, 2.0, 0.5],
                [4.0, 4.0, 0.5],
                [6.0, 6.0, 0.5],
                [8.0, 8.0, 0.5],
                [10.0, 10.0, 0.5],
                [12.0, 12.0, 2.5],
                [12.0, 12.0, 4.5],
                [12.0, 12.0, 6.5],
                [12.0, 12.0, 8.5],
                [12.0, 12.0, 10.5],
                [12.0, 12.0, 12.5],
                [12.0, 12.0, 14.5],
                [12.0, 12.0, 16.5],
                [10.0, 5.0, 20.0]])

# slowness will de assigned to grid nodes, we must pass cell_slowness=False
# 慢度模型
grid = rg.Grid3d(x, y, z, cell_slowness=False)

# we need to input slowness
slowness = 1./V

tt, rays = grid.raytrace(src, rcv, slowness, return_rays=True)

plt.figure(2)
plt.plot(tt, 'r-o')
plt.xlabel('Rcv number')
plt.ylabel('Traveltime')
# plt.show()

fig = plt.figure(3)
ax = fig.add_subplot(111, projection='3d')
min_val = V.min()
max_val = V.max()
n_x, n_y, n_z = V.shape
colormap = plt.cm.plasma

cut = V[:,:,-1]
X, Y = np.mgrid[0:n_x, 0:n_y]
Z = z[-1] + np.zeros((n_x, n_y))
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, facecolors=colormap((cut-min_val)/(max_val-min_val)), shade=False)

for r in rays:
    ax.plot(r[:,0], r[:,1], r[:,2],'r-')

ax.invert_zaxis()
ax.set_title("Rays")
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
fig.tight_layout()

plt.show()

搬砖不易,走过路过,点个赞可好。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 11:50:53  更:2022-04-28 11:51:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 18:00:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码