Loading...
Loading...
Multi-method geophysical modelling and inversion framework. Use when Claude needs to: (1) Perform electrical resistivity tomography (ERT) inversion, (2) Run seismic refraction tomography (SRT), (3) Model induced polarization (IP) data, (4) Simulate ground penetrating radar (GPR), (5) Create finite element meshes for geophysical problems, (6) Perform joint inversions of multiple datasets, (7) Forward model geophysical responses, (8) Analyze time-lapse monitoring data.
npx skill4agent add steadfastasart/geoscience-skills pygimliimport pygimli as pg
from pygimli.physics import ert, srt
# Load ERT data
data = ert.load("survey.ohm")
# Invert
mgr = ert.ERTManager(data)
model = mgr.invert(lam=20, verbose=True)
# View result
mgr.showResult()| Class | Purpose |
|---|---|
| Finite element meshes |
| Survey data and geometry |
| Base inversion framework |
| ERT processing and inversion |
| Seismic refraction inversion |
import pygimli as pg
from pygimli.physics import ert
data = ert.load("survey.ohm")
print(f"Measurements: {data.size()}")
ert.showData(data) # Pseudosectionfrom pygimli.physics import ert
mgr = ert.ERTManager(data)
model = mgr.invert(
lam=20, # Regularization
verbose=True
)
mgr.showResult()
resistivity = mgr.modelfrom pygimli.physics import srt
data = srt.load("traveltimes.sgt")
mgr = srt.SRTManager(data)
model = mgr.invert(lam=30, zWeight=0.3)
mgr.showResult()import pygimli as pg
from pygimli.physics import ert
data = ert.load("survey.ohm")
mesh = pg.meshtools.createParaMesh(
data.sensors(),
quality=34.0,
paraMaxCellSize=5,
boundary=2
)
pg.show(mesh)# Save mesh and model
mgr.mesh.save("result_mesh.bms")
pg.save(model, "resistivity_model.vector")
# Export to VTK for ParaView
mgr.mesh.exportVTK("result", mgr.model)| Code | Array |
|---|---|
| Wenner-alpha |
| Wenner-beta |
| Dipole-dipole |
| Pole-dipole |
| Pole-pole |
| Schlumberger |
| Gradient |
| Format | Extension | Description |
|---|---|---|
| BERT/pyGIMLi | .ohm | Unified data format |
| Syscal | .txt | IRIS export |
| Res2DInv | .dat | 2D inversion format |
| ABEM | .ohm | ABEM Terrameter |
| SRT | .sgt | Seismic traveltimes |
| Scenario | Recommendation |
|---|---|
| Standard ERT inversion with common arrays | pyGIMLi - simplest API, built-in array types |
| Seismic refraction tomography (SRT) | pyGIMLi - integrated SRT manager |
| Multi-method inversion (DC, magnetics, gravity, EM) | SimPEG - broader method coverage |
| Commercial ERT processing with reporting | Res2DInv - industry standard, GUI-based |
| Custom forward operators or research flexibility | SimPEG - more modular design |
| FEM-based geophysical modelling | pyGIMLi - native FEM mesh support |
ERTManagerSRTManagerert.load("survey.ohm")data.size()ERTManagermgr.invert(lam=20)mgr.showResult()mgr.mesh.exportVTK()