31-CPU和GPU

CPU 和 GPU

本节目录:

1.CPU:

1.1 提升 CPU 利用率一:

  • 在计算 a+b 之前,需要准备数据

  • 主内存->L3->L2->L1->寄存器

    • L1 访问延时:0.5ms
    • L2 访问延时:7ns(14XL1)
    • 主内存访问延时:100ns(200XL1)
  • 提升空间和时间的内存本地性

    • 时间:重用数据使它们在缓存里
    • 空间:按序读写数据是的可以预读取

1.2 样例分析:

  • 如果一个矩阵是按行存储,访问一行比访问一列要快
    • CPU 一次读取 64 字节(缓存线)
    • CPU 会“聪明的”提前读取下一个(缓存线)
image

1.3 提升 CPU 利用率二:

  • 高端 CPU 有几十个核

    • EC2 P3.16xlarge:2 Intel Xeon CPUs,32 物理核
  • 并行来利用所用核

    • 超线程不一定提升性能,因为他们共享寄存器

1.4 样例分析:

  • 左边比右边慢(python)
image
  • 左边调用 n 次函数,每次调用有开销
  • 右边很容易被并行(例如下面的 C++实现)
image

2.CPU vs GPU:

image

2.1 提升 GPU 利用率

  • 并行

    • 使用数千个线程
  • 内存本地性

    • 缓存更小,架构更简单
  • 少用控制语句

    • 支持有限
    • 同步开销大

2.2 CPU/GPU 带宽

image

2.3 更多的 CPUs 和 GPUs

  • CPU:AMD,ARM
  • GPU:AMD,Intel,ARM,Qualcomm…

2.4 CPU/GPU 高性能计算编程

  • CPU:C++或者任何高性能语言
    • 编译器成熟
  • GPU
    • Nvida 上用 CUDA
      • 编译器和驱动成熟
    • 其他用 OpenCL
      • 质量取决于硬件厂商

3.总结

  • CPU:可以处理通用计算。性能优化考虑数据读写效率和多线程
  • GPU:使用更多的小核和更好的内存带宽,适合能大规模并行的计算任务

4.Q&A

Q1: 如果要提高泛化性,就要增加数据?调参的意思是不是最大?

提高泛化性的有效手段是增加数据,但是数据的质量很重要,少量高质量数据和大量低质量数据可能有 1:10 或者 1:100 的换算关系。实际应用场景对调参要求不高,因为有不断增加的数据。

Q2:alexnet 模型比 resnet 要大,为什么计算上 resnet 比 alexnet 运算量大?

alexnet 后面用到的几个连续的全连接层使模型变大,但是 resnet 使用的卷积层在少量参数下更消耗计算资源。模型大小和计算复杂度不能直接换算。

Q3:训练时为什么使用 w-=lr*w.grad,而不写做 w=w-lr*w.grad?

因为第二种写法定义了一个新的 tensor,梯度参数会成为 false

Q4:llc 是显存还是缓存,是 l1,l2,还是 l3?

llc 是缓存,last level cash,是最后一层缓存,具体是 ln 取决于一共有几层缓存。

Q5:做计算时把 for_lopps 运算尽可能向量化?

是的,尽量不要用 python 写 for-loop

Q6:可视化时,需要把数据在 cpu 和 GPU 之间切换,如何避免频繁传输?常见的错误操作有哪些?怎么看到和排查这种错误?

可视化操作不需要太担心,只要不是计算中来回传递就好。深度学习框架会有限制,只能在一个设备上做。框架没报错一般不会有太多问题

Q7:go 怎么样?

go 分布式系统做的很好,和深度学习的分布式不太一样

Q8:怎样复现论文?

80%的论文无法复现,要读懂每一句话,和明白作者实现的细节。

Q9:分布式和高性能的区别?

没有本质区别,分布式更多考虑容错。高性能是分布式的一个应用

Q10:自动驾驶烧钱,短时间难以落地是不是和 nas 一样?

不是,自动驾驶有很好的商业前景。nas 没有太多意义。

上一页
下一页