栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

SEGY数据的读取与写出C++

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SEGY数据的读取与写出C++


#include
#include
#include
#include


#include
#include
#include
#include
#include

#include

#define NS 21 //道数
#define NT 426//采样点数
#define pi 3.1415926
using namespace std;
int main()
{
	ifstream FP1;
	ofstream FP2;
	

	FP1.open("D:\Multiple\Job-05\Untitled+GathAP-Z.sgy", ios::in|ios::binary);
	FP2.open("D:\Visual_Stdio_Code\real_seismic\FFTW.sgy", ios::out|ios::binary|ios::binary);
	
	
	char Head[3600];//卷头
	char tracehead[NS][240];//道头数据
	float ** seis = new float* [NT];//用于临时存储地震数据
	
	for (int i = 0; i < NT; i++)
	{
		seis[i] = new float[NS];
		for (int j = 0; j < NS; j++)
		{
			seis[i][j] = 0.00;
		}
	}
	for (int i = 0; i < NS; i++)
	{
		for (int j = 0; j < 240; j++)
		{
			tracehead[i][j] =' ';
		}
	}
	for (int i = 0; i < 3600; i++)
	{
		Head[i] = '0';
	}
	FP1.seekg(0, 0);
	FP1.read(Head, 3600);
	FP2.write(Head, 3600);
	
	for (int i = 0; i < NS;i++)
	{
		FP1.read(tracehead[i],240);
		FP2.write(tracehead[i], 240);
		for (int j = 0; j < NT; j++)
		{
			FP1.read((char*) &seis[j][i], sizeof(float));
			
			FP2.write( (char*) &seis[j][i], sizeof(float));
		}
	}
	FP1.close();
	FP2.close();
	system("pause");
	return 0;
}

地震数据的处理首先是能够正确的读写地震数据,本文就SEGY文件的读写做了一点描述,源代码做了分享,虽然很简单,但是有些时候就是不好解决。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1004957.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号