你已经派生过 gprMax
镜像自地址
https://gitee.com/sunhf/gprMax.git
已同步 2025-08-07 23:14:03 +08:00
Refactor SoilPeplinski UserObject build process
Move mixingmodels from FDTDGrid to Model class
这个提交包含在:
@@ -1572,7 +1572,7 @@ class SoilPeplinski(UserObjectMulti):
|
||||
self.order = 14
|
||||
self.hash = "#soil_peplinski"
|
||||
|
||||
def build(self, grid, uip):
|
||||
def build(self, model, uip):
|
||||
try:
|
||||
sand_fraction = self.kwargs["sand_fraction"]
|
||||
clay_fraction = self.kwargs["clay_fraction"]
|
||||
@@ -1615,7 +1615,7 @@ class SoilPeplinski(UserObjectMulti):
|
||||
"fraction."
|
||||
)
|
||||
raise ValueError
|
||||
if any(x.ID == ID for x in grid.mixingmodels):
|
||||
if any(x.ID == ID for x in model.mixingmodels):
|
||||
logger.exception(f"{self.params_str()} with ID {ID} already exists")
|
||||
raise ValueError
|
||||
|
||||
@@ -1631,14 +1631,14 @@ class SoilPeplinski(UserObjectMulti):
|
||||
)
|
||||
|
||||
logger.info(
|
||||
f"{self.grid_name(grid)}Mixing model (Peplinski) used to "
|
||||
f"{self.model_name(model)}Mixing model (Peplinski) used to "
|
||||
f"create {s.ID} with sand fraction {s.S:g}, clay fraction "
|
||||
f"{s.C:g}, bulk density {s.rb:g}g/cm3, sand particle "
|
||||
f"density {s.rs:g}g/cm3, and water volumetric fraction "
|
||||
f"{s.mu[0]:g} to {s.mu[1]:g} created."
|
||||
)
|
||||
|
||||
grid.mixingmodels.append(s)
|
||||
model.mixingmodels.append(s)
|
||||
|
||||
|
||||
class MaterialRange(UserObjectMulti):
|
||||
|
@@ -32,7 +32,7 @@ from gprMax import config
|
||||
from gprMax.cython.yee_cell_build import build_electric_components, build_magnetic_components
|
||||
|
||||
# from gprMax.geometry_outputs import GeometryObjects, GeometryView
|
||||
from gprMax.materials import Material, process_materials
|
||||
from gprMax.materials import process_materials
|
||||
from gprMax.pml import CFS, PML, build_pml, print_pml_info
|
||||
from gprMax.receivers import Rx
|
||||
from gprMax.snapshots import Snapshot
|
||||
@@ -76,7 +76,6 @@ class FDTDGrid:
|
||||
# TODO: Add type information.
|
||||
# Currently importing GeometryObjects, GeometryView, and
|
||||
# SubGridBaseGrid cause cyclic dependencies
|
||||
self.mixingmodels = []
|
||||
self.averagevolumeobjects = True
|
||||
self.fractalvolumes = []
|
||||
self.geometryviews = []
|
||||
|
@@ -28,7 +28,7 @@ from colorama import Fore, Style, init
|
||||
|
||||
from gprMax.grid.cuda_grid import CUDAGrid
|
||||
from gprMax.grid.opencl_grid import OpenCLGrid
|
||||
from gprMax.materials import Material
|
||||
from gprMax.materials import Material, PeplinskiSoil
|
||||
from gprMax.subgrids.grid import SubGridBaseGrid
|
||||
|
||||
init()
|
||||
@@ -66,6 +66,7 @@ class Model:
|
||||
self.G = self._create_grid()
|
||||
self.subgrids: List[SubGridBaseGrid] = []
|
||||
self.materials: List[Material] = []
|
||||
self.mixingmodels: List[PeplinskiSoil] = []
|
||||
|
||||
# Monitor memory usage
|
||||
self.p = None
|
||||
|
在新工单中引用
屏蔽一个用户