Skip to main content

2D Electromagnetic Simulator for GPR Scenarios

Project description

2D electromagnetic simulator

2D Electromagnetic Simulator for GPR Scenarios. This simulator allows for varying the relative permittivity and conductivity of the subsurface. Additionally, cylindrical objects can be added, defined by a coordinate (x, y) indicating the center of the cylinder, as well as their relative permittivity and conductivity. The simulation requires defining the location of the transmission and reception antennas, as well as the frequency of the Ricker pulse. Below is an example image showing all the parameters necessary to configure the GPR scenario.
GPR scenario
The default spatial discretization in this simulator is 0.01 meters for the "x" and "y" coordinates. The positions of the antennas, cylindrical objects, and the height of the subsurface are specified in terms of points. These points are calculated as follows: if the transmission antenna is to be positioned at 0.10 meters on the "x" axis and 0.5 meters on the "y" axis, this corresponds to 10 points and 50 points, respectively. This is obtained by dividing 0.10 by 0.01, resulting in 10, and 0.5 by 0.01, resulting in 50.

Table of Contents

Glossary

  • $Dm$ = model_size_y
  • $Ws$ = model_size_x
  • $Ds$ = subsurface_height
  • $Rx_{x}$ = RX_antenna_position_x
  • $Rx_{y}$ = RX_antenna_position_y
  • $Tx_{x}$ = TX_antenna_position_x
  • $Tx_{y}$ = TX_antenna_position_y
  • $steps$ = steps_antenna
  • $\varepsilon_{rs}$ = permittivity_r (subsurface)
  • $\varepsilon_{rc}$ = permittivity_r (cylinder)
  • $\sigma_{s}$ = conductivity (subsurface)
  • $\sigma_{c}$ = conductivity (cylinder)
  • $r_{c}$ = radius (cylinder)

Installation

Instructions on how to install the project. For example:

pip install em_simulation

Code Example

For instance, the following code can be executed in Google Colab. Simply copy and paste it into a new Colab notebook.

from em_simulation.create_gpr_image import run_image
from em_simulation.visualization import graph_ez

#--------------------------------------------------------------------------------
# 1) definition of parameters for the simulation
dicc_model ={
      'name_simulation':'test_1.npy',
      'model_size_x' : 100 ,
      'model_size_y': 60,
      'TX_antenna_position_x':10,
      'TX_antenna_position_y':50,
      'RX_antenna_position_x':14,
      'RX_antenna_position_y':50,
}

dicc_simulation = {
      'steps_antenna': 60,
      'time_window': 420,
      'frecuency': 1.6e9,

}


characteristics_subsurface= { 
'permittivity_r': 5,
'conductivity': 0.005, #mS/m
'subsurface_height': 50
}

characteristics_cylinder= { 'x_position': 50,
'y_position': 35,
'conductivity': 5.81e7, #cu
'permittivity_r': 1,
'radius': 3
}

#--------------------------------------------------------------------------------
# 2) Perform simulation:
ez = run_image(dicc_model,dicc_simulation,characteristics_subsurface,characteristics_cylinder )
#--------------------------------------------------------------------------------
# 3) show result:
graph_ez(electric_field_Z)

Create the environment

Create a local environment using Anaconda from an environment.yml file.

conda env create -f environment.yml

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

em_simulation-0.7-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file em_simulation-0.7-py3-none-any.whl.

File metadata

  • Download URL: em_simulation-0.7-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for em_simulation-0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 85023ebec05b92b530d9384a2a6a057a06438757ae8634a0a52ce365ba55ab36
MD5 f9d0392a856f041d5cba91b0cb0b894c
BLAKE2b-256 9e50d20babab5430ec3d1fb3d2921f79ec5dc56c6879e6957f5427454518531b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page