← Back to context

Comment by lsb

4 days ago

That’s wild that with a KV cache and compilation on the Mac CPU you are faster than on an A100 GPU.

Given that the compiled version is slower than then eager version on A100, there's definitely something suboptimal happening there

  • No the compiled version is actually faster.

    From that table, the A100 tok/sec (larger is faster) numbers are:

    - Eager: 28

    - Compiled: 128

    And

    - KV cache eager: 26

    - KV cache compiled: 99

    The reason that the KV cache is slower is likely because it's not GPU-optimized code. On CPU the KV cache is faster. To make it faster on GPU, you would pre-allocate the tensors on the device for example instead of `torch.cat`ting them on the fly

    • Ah yep read the labels backwards and meant that - ty for catching and for the explanation

Because on Mac the CPU and GPU share memory, but A100 need to transfer to RAM/CPU on the parts that’s not supported by GPU?

(My first guess)

This would be because the GPU can’t fill its waveform and hide memory latency, no? I’m curious for a reason why