From 4625dc2566b162bf41e55ceefa71ff2e5d23034c Mon Sep 17 00:00:00 2001 From: agrant3 Date: Mon, 27 Nov 2023 14:25:01 +0000 Subject: [PATCH] AG: added OMP Thread issue on Pytorch --- docs/services/gpuservice/faq.md | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/docs/services/gpuservice/faq.md b/docs/services/gpuservice/faq.md index 7b37742a9..1aede79fd 100644 --- a/docs/services/gpuservice/faq.md +++ b/docs/services/gpuservice/faq.md @@ -49,3 +49,30 @@ The default size of SHM is only 64M. You can mount an empty dir to /dev/shm to s emptyDir: medium: Memory ``` + +### Pytorch Slow Performance Issues + +Pytorch on Kubernetes may operate slower than expected - much slower than an equivalent VM setup. + +Pytorch defaults to auto-detecting the number of OMP Threads and it will report an incorrect number of potential threads compared to your requested CPU core count. This is a consequence in operating in a container environment, the CPU information is reported by standard libraries and tools will be the node level information rather than your container. + +To help correct this issue, the environment variable OMP_NUM_THREADS should be set in the job submission file to the number of cores requested or less. + +This has been tested using: + +- OMP_NUM_THREADS=1 +- OMP_NUM_THREADS=(number of requested cores). + +Example fragment for a Bash command start: + +```yaml + containers: + - args: + - > + export OMP_NUM_THREADS=1; + python mypytorchprogram.py; + command: + - /bin/bash + - '-c' + - '--' +```