leenldk 发布的文章

BLAS : basic linear algebra subprograms (low level)
LAPACK : linear algebra package (high level,在 BLAS 之上)
ScaLAPACK : scalable LAPACK,支持 MPI 的 LAPACK

Intel MKL : 包含 BLAS, LAPACK, ScaLAPACK

ELPA : eigenvalue solvers for petaflop applications

cuBLAS

使用 cublasCreate 创建 cuBLAS library context 的 handle,
一个 context 关联一个 device
cuBLAS library context 绑定 CUDA context

GCC

编译流程:

Frontend pass :
通过源码生成 Abstract Syntax Tree (AST)

Middle-end pass :
将 AST 转换为 GIMPLE 中间表达(high-level,语言无关)
将 GIMPLE 转换为 SSA (Static Single Assignment) 格式

Backend pass :
将 GIMPLE 转换为 low level, 机器无关的中间表达 RTL (Register Transfer Language)

IPA : Interprocedural Analysis,考虑多个函数或多个文件的优化

使用 -fdump-passes 编译选项输出 GCC 使用的所有 pass
-fdump-tree-all 输出所有 gimple pass
-fdump-rtl-all 输出所有 RTL pass

编译选项:

-m : 机器相关选项

LLVM

llvm IR

用来记一些 tmux 之类工具的奇妙用法

tmux

ctrl+b s : 切换panel
Ctrl+b :set synchronize-panes : 多窗口同步输入

因为想搞一个 centos 环境,但手头只有 debian,所以打算用 docker 搞一个 centos 环境

用了 spack/centos7 这个镜像,看起来自带 spack

sudo docker run -it spack/centos7 #运行 docker 
docker ps # 显示当前运行的 docker
sudo docker exec -it e165d3e15452 bash # 在已经运行的 docker 中执行 bash
sudo docker run --net=host --env HTTPS_PROXY="127.0.0.1:10987" --env HTTP_PROXY="127.0.0.1:10987" -it spack/centos7 # docker 设置 localhost 代理
sudo docker commit 94baf9f11069 blender # 保存正在运行 docker 的修改到新的 docker