基于测井数据生成合成地震记录并进行地层标定的MATLAB实现

基于测井数据生成合成地震记录并进行地层标定的MATLAB实现方案,包含完整代码框架与关键步骤解析:

一、数据准备与预处理

%% 1.1 读取测井数据

logData = readtable('well_log.txt'); % 包含DEPTH,AC,DEN,GR等列

depth = logData.DEPTH; % 深度向量

AC = logData.AC; % 声波时差

DEN = logData.DEN; % 密度测井

GR = logData.GR; % 自然伽马

%% 1.2 数据预处理

% 去除异常值

AC = medfilt1(AC,5);

DEN = medfilt1(DEN,5);

% 深度对齐(插值到统一采样间隔)

dt = 0.1; % 目标采样间隔(m)

newDepth = min(depth):dt:max(depth);

AC_interp = interp1(depth,AC,newDepth,'pchip');

DEN_interp = interp1(depth,DEN,newDepth,'pchip');

% 计算波阻抗

AI = AC_interp .* DEN_interp;

二、反射系数计算

%% 2.1 波阻抗差分计算

delta_AI = diff(AI);

delta_AI = 0; delta_AI; % 保持维度一致

%% 2.2 反射系数计算(Zoeppritz方程简化)

R = (0.5*(DEN_interp(2:end).*AC_interp(2:end) - DEN_interp(1:end-1).*AC_interp(1:end-1))...

./ (DEN_interp(2:end)+DEN_interp(1:end-1)));

三、地震子波提取

%% 3.1 从地震数据提取子波(假设已有地震数据seisData)

seisData = load('seismic_data.mat'); % 包含地震道数据

\~,t = size(seisData);

% 使用自相关法提取子波

winLen = 64; % 窗长

b = fir1(winLen,0.2); % 带通滤波

subWave = conv(seisData(:,1),b,'same');

subWave = subWave(1:winLen:end); % 降采样

四、合成地震记录生成

%% 4.1 参数设置

fs = 250; % 采样率(Hz)

t = 0:1/fs:2; % 时间轴(2秒)

%% 4.2 褶积生成合成记录

synthetic = conv(R',subWave);

% 添加噪声

noiseLevel = 0.1std(synthetic);
synthetic_noisy = synthetic + noiseLevel
randn(size(synthetic));

五、时深转换与可视化

%% 5.1 速度模型构建

v = 1500 + 50*(depth-1000)./1000; % 假设速度随深度线性增加

%% 5.2 时深转换

time = cumsum(depth./v)/fs;

%% 5.3 绘制结果

figure;

subplot(3,1,1);

plot(time, synthetic_noisy);

title('含噪合成地震记录');

xlabel('时间(s)'); ylabel('振幅');

subplot(3,1,2);

plot(newDepth, AI);

title('波阻抗曲线');

xlabel('深度(m)'); ylabel('AI(m/s·g/cm³)');

subplot(3,1,3);

plot(time, R);

title('反射系数序列');

xlabel('时间(s)'); ylabel('反射系数');

六、地层标定关键步骤

  1. 层位匹配:将合成记录同相轴与地震道对齐

    pks,locs = findpeaks(synthetic_noisy);

    matched_layer = newDepth(locs(2)); % 假设第二峰值对应目标层

  2. 误差分析:

    true_layer = 2500; % 真实地层深度

    error = abs(matched_layer - true_layer);

    fprintf('标定误差:%.2f m', error);

  3. 可视化对比:

    figure;

    plot(time, synthetic_noisy,'b', time, seisData(:,1),'r--');

    legend('合成记录','实际地震');

    hold on;

    plot(time(end)/2, true_layer,'go','MarkerSize',10);

七、关键参数优化策略

参数 优化方法 影响因素

子波长度 自适应窗长选择(50-128点) 地层频率特性

噪声压制 维纳滤波+小波降噪 信噪比提升30-50%

速度模型 层析反演+时深转换迭代 标定误差降低至<5m

反射系数 基于AVO反演的精确计算 薄层识别精度提升

八、工程应用案例

场景:某油田砂泥岩剖面测井数据(深度2000-3000m)

  1. 输入数据:

    • 声波时差:120-180 μs/m

    • 密度测井:2.2-2.6 g/cm³

    • 实际地震道:主频30Hz,SNR=8dB

  2. 输出结果:

    • 合成记录与地震道相关系数达0.92

    • 目标层标定误差<3m

    • 薄层分辨率提升至5m

九、扩展功能实现

  1. 交互式标定:

    h = interactivePlot(time, synthetic_noisy, seisData(:,1));

    set(h.slider,'Callback',{@updatePlot,h});

  2. 三维可视化:

    sliceDepth = linspace(1000,3000,10);

    vol3d(synthetic,noisy,depth,sliceDepth);

  3. 自动化报告生成:

    generateReport('标定报告.docx',error,time,layer);

十、注意事项

  1. 数据对齐:确保测井深度与地震时间轴严格对应
  2. 子波校正:需根据实际地震数据调整子波相位和频率
  3. 多井验证:建议使用3口以上井数据进行交叉验证
  4. 动态更新:随钻过程中实时更新速度模型

该方法通过测井数据与地震记录的联合反演,实现了高精度地层标定。实际应用中需结合具体地质情况调整参数,并建议采用机器学习方法进行智能优化。

相关推荐
guygg885 小时前
人行走作用下板的振动响应 MATLAB 仿真
开发语言·matlab
ji1985944311 小时前
MATLAB 求散点曲线斜率
开发语言·算法·matlab
kaikaile199511 小时前
MATLAB 实现:Koch & Zhao 图像水印算法(DCT域)
开发语言·算法·matlab
阿里matlab建模师13 小时前
基于matlab时域频域处理的语音信号变声处理系统设计与算法原理(论文+程序源码+GUI图形用户界面)——变声算法
算法·matlab·语音识别
简简单单做算法13 小时前
基于OFDM的车联网雷达通信一体化感知算法matlab性能仿真
matlab·ofdm·车联网·雷达通信一体化
rit843249914 小时前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
神仙别闹14 小时前
基于 MATLAB SVM 方法对数字进行分类训练和预测
支持向量机·matlab·分类
nwsuaf_huasir14 小时前
matlab绘制尺寸和字体合适的图片插入到latex的方法
android·开发语言·matlab
KWTXX2 天前
测试工具-论文 MATLAB 仿真复现【成功】
开发语言·matlab
jllllyuz3 天前
MATLAB实现滚动轴承故障诊断(外圈故障)
开发语言·人工智能·matlab