API драйвера CUDA определяет CUDA_VERSION (в cuda.h), а API среды выполнения CUDA определяет CUDART_VERSION (в cuda_runtime_api.h). Однако CUDART_VERSION определяется не как CUDA_VERSION, а непосредственно как число.
Всегда ли предполагается, что они имеют точно такое же значение, или существуют обстоятельства, при которых они могут различаться?





Они будут одинаковыми по наблюдению, но не связанными.
Как ты уже знаешь в время выполнения, версия CUDA может отличаться от версии CUDART. Следовательно (или, насколько этот ответ описывает) между ними нет никакой связи.
Однако и cuda.h, и cuda_runtime_api.h будут установлены установщиком CUDA. Так что в отношении того, что устанавливает этот установщик, они будут совпадать. Установщик устанавливает как драйвер, так и среду разработки, где версия CUDA (драйвер API) и версия API среды выполнения CUDA совпадают. Но позже это может измениться (например, если вы обновите драйвер). То есть версии среды выполнения могут измениться в зависимости от последующей активности установки. Но cuda.h, установленный установщиком набора инструментов CUDA, и cuda_runtime_api.h, установленный установщиком набора инструментов CUDA, останутся такими, какими они были, установленными установщиком набора инструментов.
cuda_runtime_api.h не зависит от cuda.h. По этой причине одно определение не является просто определением другого. Вы можете создавать приложения API среды выполнения CUDA, которые не зависят от cuda.h (пример кода deviceQuery является примером), и поэтому нет причин для cuda_runtime_api.h создавать определение на основе чего-то в cuda.h — это потребовало бы от вас всегда включать cuda.h всякий раз, когда вы включаете cuda_runtime_api.h, а дизайнеры CUDA не собирались этого делать.