gctl/README.md

250 lines
5.0 KiB
Markdown
Raw Normal View History

2025-02-03 11:23:32 +08:00
![logo](GCTL_logo.jpg)
2024-09-10 15:45:07 +08:00
# Geophysical Computational Tools & Library (GCTL)
2025-02-03 11:23:32 +08:00
GCTL 是一个用于地球物理研究的计算工具和 C++ 库。完整的软件包由核心库和额外的库以及命令行工具组成。本库采用现代 C++ 设计,提供高性能的数值计算和数据处理功能。
## 主要特性
- **高性能**: 采用现代 C++ 技术,支持并行计算和 SIMD 优化
- **易用性**: 直观的 API 设计,完善的文档和示例
- **可扩展**: 模块化设计,支持自定义扩展
- **可靠性**: 完整的单元测试,异常安全保证
- **跨平台**: 支持 Linux、macOS 和 Windows
## 库结构
### 1. 核心库 (gctl)
- **核心数据结构** (`core/`)
- 动态数组 (`array.h`, `array_enhanced.h`)
- 自动内存管理
- 并行算法支持
- 数学运算功能
- 序列化支持
- 矩阵操作 (`matrix.h`)
- 基础矩阵运算
- 线性代数操作
- 分解算法
- 特征值计算
- 稀疏数据结构 (`spmat.h`, `sparray.h`)
- 压缩存储格式
- 高效稀疏运算
- 内存优化
- 向量模板 (`vector_t.h`)
- 2D/3D 向量运算
- 几何变换
- 坐标系转换
- 枚举定义 (`enum.h`)
- 类型安全枚举
- 状态定义
- 错误码
- **输入输出** (`io/`)
- DSV 文件操作 (`dsv_io.h`)
- CSV/TSV 格式支持
- 自定义分隔符
- 表头处理
- 文本文件操作 (`text_io.h`)
- 文本读写
- 编码转换
- 流式处理
- NetCDF 支持 (`netcdf_io.h`)
- 科学数据格式
- 多维数组支持
- 元数据处理
- 网格文件操作 (`mesh_io.h`)
- 多种网格格式
- 网格转换
- 拓扑处理
- **数学计算** (`maths/`)
- 线性代数 (`linear_algebra.h`)
- 矩阵分解
- 特征值计算
- 线性方程组求解
- 数学函数 (`mathfunc.h`)
- 基础数学函数
- 特殊函数
- 插值函数
- 形状函数 (`shapefunc.h`)
- 有限元基函数
- 节点形函数
- 边界条件
- FFT 变换 (`fft.h`)
- 快速傅里叶变换
- 频谱分析
- 滤波器
- **几何处理** (`geometry/`)
- 基础几何 (`basic.h`)
- 点线面运算
- 几何变换
- 相交检测
- 网格处理 (`mesh.h`)
- 网格生成
- 网格优化
- 质量评估
- 形状函数 (`shape.h`)
- 几何形状描述
- 参数化曲面
- 边界表示
- **工具函数** (`utility/`)
- 通用工具 (`common.h`)
- 字符串处理
- 时间日期
- 日志系统
- 算法实现 (`algorithm.h`)
- 排序算法
- 搜索算法
- 图算法
### 2. 扩展库
- **gctl_potential**: 势场数据处理库
- 重力数据处理
- 磁场数据处理
- 势场反演
- 场源解释
- **gctl_seismic**: 地震数据处理库
- 波形处理
- 震相识别
- 速度建模
- 层析成像
- **gctl_elecmag**: 电磁数据处理库
- MT数据处理
- 电磁反演
- 各向异性分析
- 噪声处理
- **gctl_optimization**: 优化算法库
- 线性规划
- 非线性优化
- 全局优化
- 约束优化
- **gctl_ai**: 人工智能算法库
- 神经网络
- 机器学习
- 深度学习
- 模式识别
- **gctl_graphic**: 数据可视化库
- 2D绘图
- 3D可视化
- 等值线图
- 矢量场图
## 系统要求
### 编译器支持
- GCC 7.0 或更高版本
- Clang 6.0 或更高版本
- MSVC 2019 或更高版本
### 操作系统
- Linux (Ubuntu 18.04+, CentOS 7+)
- macOS (10.14+)
- Windows (10, 11)
### 依赖库版本
- CMake 3.10+
- OpenMP 4.0+
- NetCDF 4.6+
- FFTW 3.3+
- OpenBLAS 0.3+
- Eigen 3.3+
## 性能优化
### 1. 并行计算
- OpenMP 多线程并行
- 自动线程分配
- 负载均衡
- 缓存优化
- SIMD 向量化
- AVX/AVX2 指令集
- 自动向量化
- 手动优化
- GPU 加速(可选)
- CUDA 支持
- OpenCL 支持
- 异构计算
### 2. 内存管理
- 智能指针管理
- 内存池技术
- 缓存对齐
- 零拷贝优化
### 3. 算法优化
- 自适应算法选择
- 数值稳定性保证
- 计算精度控制
- 资源使用优化
## 应用领域
### 1. 地球物理勘探
- 重力勘探
- 磁法勘探
- 地震勘探
- 电磁勘探
### 2. 地球科学研究
- 地壳结构研究
- 地球内部成像
- 地球动力学模拟
- 地震预测研究
### 3. 工程应用
- 矿产资源勘探
- 工程地质调查
- 环境地球物理
- 灾害监测预警
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
## 贡献指南
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### 代码规范
- 遵循现代 C++ 规范
- 代码格式化要求
- 命名规范
- 注释规范
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### 开发流程
1. Fork 项目
2. 创建特性分支
3. 提交变更
4. 发起 Pull Request
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### 测试要求
- 单元测试覆盖
- 集成测试
- 性能测试
- 回归测试
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
## 版本历史
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### v1.0.0 (2024-01)
- 初始版本发布
- 核心功能实现
- 基础文档完成
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### 开发计划
- GPU 加速支持
- 分布式计算
- 深度学习集成
- 实时处理优化
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
## 联系方式
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
### 技术支持
- **邮箱**: yizhang-geo@zju.edu.cn
2024-09-10 15:45:07 +08:00
2025-02-03 11:23:32 +08:00
## 致谢
2024-09-10 15:18:30 +08:00
2025-02-03 11:23:32 +08:00
感谢以下机构和个人的支持:
- 浙江大学地球科学学院
- 国家自然科学基金委员会