电阻率测深法理论曲线正演matlab,绘制多条曲线对比
时间: 2023-07-20 10:09:43 浏览: 237
电阻率测深法理论曲线正演可以通过有限元法或有限差分法进行模拟计算。下面是一个matlab程序,可以绘制多条电阻率深度剖面曲线,方便比较分析:
```matlab
% 电阻率测深法理论曲线正演程序
% 输入参数
r = 50; % 电极距离
n = 20; % 电极数目
rho1 = 100; % 地下介质电阻率
rho2 = [500, 1000, 2000]; % 地下目标电阻率,多个值用逗号隔开
h = 2000; % 探测深度
dh = 100; % 深度间距
% 计算电极间距
d = r / (n - 1);
% 计算电极位置
elec_pos = (0:(n-1)) * d;
% 初始化电位数组
potential = zeros(n, n);
% 计算目标电势
for i = 1:n
for j = 1:n
if i ~= j
distance = abs(elec_pos(i) - elec_pos(j));
if distance <= r
potential(i, j) = rho2(1);
else
potential(i, j) = rho1;
end
end
end
end
% 有限差分法计算电阻率深度剖面
resistivity_profile = zeros(h/dh, numel(rho2));
for i = 1:numel(rho2)
rho = rho2(i);
for j = 1:(h/dh)
z = j * dh;
G = zeros(n-1, n-1);
for k = 1:(n-1)
G(k, k) = (rho1 + rho) / (2 * pi * (elec_pos(k+1) - elec_pos(k)) * z);
for l = (k+1):n-1
G(k, l) = -1 * (rho1 + rho) / (2 * pi * (elec_pos(l+1) - elec_pos(l)) * z);
G(l, k) = -1 * (rho1 + rho) / (2 * pi * (elec_pos(l+1) - elec_pos(l)) * z);
end
end
U = potential(2:end, 2:end) - potential(2:end, 1:end-1);
I = G \ U(:);
resistivity_profile(j, i) = (rho1 + rho) / (dh * sum(I));
end
end
% 绘制电阻率深度剖面图
figure;
loglog(resistivity_profile(:, 1), (1:(h/dh)) * dh, 'LineWidth', 2);
hold on;
loglog(resistivity_profile(:, 2), (1:(h/dh)) * dh, 'LineWidth', 2);
loglog(resistivity_profile(:, 3), (1:(h/dh)) * dh, 'LineWidth', 2);
xlabel('电阻率(Ωm)');
ylabel('深度(m)');
title('电阻率测深法理论曲线正演结果');
legend('rho2_1 = 500', 'rho2_2 = 1000', 'rho2_3 = 2000');
```
在这个程序中,我们首先计算出目标电势矩阵,然后使用有限差分法计算电阻率深度剖面。最后,我们将多条电阻率深度剖面曲线绘制在同一张图上,方便比较分析。可以通过修改输入参数来绘制不同的曲线,例如修改 `rho2` 的值或修改 `h` 和 `dh` 的值。
阅读全文