使用python脚本批量对gprmax建模(用不同含水量、rebar半径、rebar深度)

本文主要是介绍使用python脚本批量对gprmax建模(用不同含水量、rebar半径、rebar深度),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、软件

1.spyder

2.Gprmax

2、代码及解释

1.首先在spyder中编辑好python部分代码,代码如下:主要是确定含水量、半径、深度三个部分,随机生成需要的范围内的数据;

import scipy.interpolate
import numpy as np
from random import  random as rdm=np.array([12,9.3,6.2,5.5,2.8,0.2])
e_stat = np.array([12.84,11.19,9.14,8.63,6.75,4.814])
e_inf = np.array([7.42,7.2,5.93,6.023,5.503,4.507])
t = np.array([0.611,0.73,0.8,1,2.28,0.82])*10**-9
sigma = np.array([20.6,23,6.7,5.15,2.03,0.606])*10**-3es = scipy.interpolate.interp1d(m, e_stat)
ei = scipy.interpolate.interp1d(m, e_inf)
t0 = scipy.interpolate.interp1d(m, t)
si = scipy.interpolate.interp1d(m, sigma)mv=0.2+11.8*rd()print("#material:{} {} 1 0 concrete \n".format(ei(mv), si(mv)))
print("#add_dispersion_debye: 1 {} {} concrete \n".format(es(mv)-ei(mv), t0(mv)))print("#box: 0 0 0 0.5 0.3 0.3 concrete \n")r=0.005 + 0.0245*rd()
z=(0.3-r)*rd()
print("#cylinder: 0.25 0 {} 0.25 0.3 {} {} pec \n".format(z,z,r))

2.生成结果:每次都随机生成含水量、半径、深度,含水量有Debye模型来确定;

3.整合到gprmax中可批量生成,代码如下:

#domain: 0.5 0.3 0.4
#dx_dy_dz: 0.001 0.001 0.001
#time_window: 3000#python:
import scipy.interpolate
import numpy as np
from random import  random as rdm=np.array([12,9.3,6.2,5.5,2.8,0.2])
e_stat = np.array([12.84,11.19,9.14,8.63,6.75,4.814])
e_inf = np.array([7.42,7.2,5.93,6.023,5.503,4.507])
t = np.array([0.611,0.73,0.8,1,2.28,0.82])*10**-9
sigma = np.array([20.6,23,6.7,5.15,2.03,0.606])*10**-3es = scipy.interpolate.interp1d(m, e_stat)
ei = scipy.interpolate.interp1d(m, e_inf)
t0 = scipy.interpolate.interp1d(m, t)
si = scipy.interpolate.interp1d(m, sigma)mv=0.2+11.8*rd()print("#material: {} {} 1 0 concrete \n".format(ei(mv), si(mv)))
print("#add_dispersion_debye: 1 {} {} concrete \n".format(es(mv)-ei(mv), t0(mv)))print("#box: 0 0 0 0.5 0.3 0.3 concrete \n")r=0.005 + 0.0245*rd()
z=(0.3-r)*rd()
print("#cylinder: 0.25 0 {} 0.25 0.3 {} {} pec \n".format(z,z,r))filename="concrete_labels"
f=open(filename,'a')
f.write("{}: {} {} {}".format(current_model_run, r,z,mv))#定义天线
from user_libs.antennas import GSSI
GSSI.antenna_like_GSSI_1500(0.25,0.15,0.3,resolution=0.001)#end_python:
#geometry_view: 0 0 0 0.5 0.3 0.4 0.002 0.002 0.002 geo n

 4.输入指令在gprmax中执行改输入文件:

  • python -m gprMax ×××(文件名)-n 2000  ,这个两千是指模型数量

4、结果

最后结果会生成你所定义的模型数量的out文件;

这篇关于使用python脚本批量对gprmax建模(用不同含水量、rebar半径、rebar深度)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as