-
Notifications
You must be signed in to change notification settings - Fork 0
build_acceleration
makr-code edited this page Nov 30, 2025
·
1 revision
cmake -S . -B build
cmake --build build# Prerequisites: CUDA Toolkit 11.0+
cmake -S . -B build -DTHEMIS_ENABLE_CUDA=ON
cmake --build build# Prerequisites: Vulkan SDK
cmake -S . -B build -DTHEMIS_ENABLE_VULKAN=ON
cmake --build buildcmake -S . -B build \
-DTHEMIS_ENABLE_CUDA=ON \
-DTHEMIS_ENABLE_VULKAN=ON
cmake --build buildInstall CUDA Toolkit:
-
Linux: https://developer.nvidia.com/cuda-downloads
wget https://developer.download.nvidia.com/compute/cuda/repos/ubuntu2204/x86_64/cuda-keyring_1.1-1_all.deb sudo dpkg -i cuda-keyring_1.1-1_all.deb sudo apt-get update sudo apt-get install cuda-toolkit-12-3
-
Windows: Download installer from NVIDIA
https://developer.nvidia.com/cuda-downloads
Verify Installation:
nvcc --version
nvidia-smiHardware Requirements:
- NVIDIA GPU with Compute Capability 7.0+
- 8GB+ VRAM recommended
- CUDA Driver 450.80.02+
Install Vulkan SDK:
-
Linux:
wget -qO- https://packages.lunarg.com/lunarg-signing-key-pub.asc | sudo tee /etc/apt/trusted.gpg.d/lunarg.asc sudo wget -qO /etc/apt/sources.list.d/lunarg-vulkan-jammy.list https://packages.lunarg.com/vulkan/lunarg-vulkan-jammy.list sudo apt update sudo apt install vulkan-sdk -
Windows: Download from LunarG
https://vulkan.lunarg.com/sdk/home#windows
Verify Installation:
vulkaninfo
glslangValidator --versionHardware Requirements:
- Vulkan 1.2+ capable GPU (NVIDIA/AMD/Intel)
- 4GB+ VRAM recommended
All hardware acceleration backends are optional and disabled by default.
# CUDA (NVIDIA GPUs)
-DTHEMIS_ENABLE_CUDA=ON
# Vulkan (Cross-platform)
-DTHEMIS_ENABLE_VULKAN=ON
# DirectX 12 (Windows only)
-DTHEMIS_ENABLE_DIRECTX=ON
# AMD HIP (AMD GPUs, future)
-DTHEMIS_ENABLE_HIP=ON
# AMD ZLUDA (CUDA compatibility on AMD, future)
-DTHEMIS_ENABLE_ZLUDA=ON
# Other backends (planned)
-DTHEMIS_ENABLE_METAL=ON # Apple Silicon
-DTHEMIS_ENABLE_ONEAPI=ON # Intel GPUs
-DTHEMIS_ENABLE_OPENCL=ON # Generic
-DTHEMIS_ENABLE_OPENGL=ON # Legacy# Specify CUDA Toolkit location
-DCUDAToolkit_ROOT=/usr/local/cuda-12.3
# Specify Vulkan SDK location
-DVULKAN_SDK=/path/to/vulkan/1.3.xxx
# Enable multiple backends
-DTHEMIS_ENABLE_CUDA=ON -DTHEMIS_ENABLE_VULKAN=ONcmake -S . -B build \
-DCMAKE_BUILD_TYPE=Debug \
-DTHEMIS_ENABLE_CUDA=ON \
-DTHEMIS_BUILD_TESTS=ON
cmake --build build
./build/themis_testscmake -S . -B build \
-DCMAKE_BUILD_TYPE=Release \
-DTHEMIS_ENABLE_CUDA=ON \
-DTHEMIS_ENABLE_VULKAN=ON \
-DTHEMIS_STRICT_BUILD=ON
cmake --build build --config Release# Build only the CUDA plugin as a separate DLL
cd plugins/cuda
cmake -S . -B build
cmake --build build./build/themis_server
# Look for output:
# CUDA Backend initialized successfully:
# Device: NVIDIA GeForce RTX 4090
# Compute Capability: 8.9
# Global Memory: 24 GB
# Multiprocessors: 128./build/themis_server
# Look for output:
# Vulkan Backend: Compute shaders available
# Vulkan Device: NVIDIA GeForce RTX 4090
# VRAM: 24 GBcd build
ctest --output-on-failure
# Or specific tests
./themis_tests --gtest_filter=AccelerationTest.*Error: CUDA toolkit not found
Solution:
# Set CUDA_ROOT
export CUDA_ROOT=/usr/local/cuda
cmake -S . -B build -DTHEMIS_ENABLE_CUDA=ONError: Could NOT find Vulkan
Solution:
# Set VULKAN_SDK
export VULKAN_SDK=/path/to/vulkan/sdk
cmake -S . -B build -DTHEMIS_ENABLE_VULKAN=ONWarning: No CUDA-capable device found
Check:
- Driver installed?
nvidia-smi - GPU visible?
nvidia-smi -L - CUDA initialized?
export CUDA_VISIBLE_DEVICES=0
CUDA Compute Capability Mismatch:
nvcc fatal: Unsupported gpu architecture 'compute_89'
Solution:
# In CMakeLists.txt, adjust CUDA architectures
set(CMAKE_CUDA_ARCHITECTURES 75 80 86 89) # Adjust for your GPUVulkan Shader Compilation Failed:
# Manually compile shaders
cd src/acceleration/vulkan/shaders
glslangValidator -V l2_distance.comp -o l2_distance.spv
glslangValidator -V cosine_distance.comp -o cosine_distance.spv# Release build with CUDA optimizations
-DCMAKE_BUILD_TYPE=Release
-DTHEMIS_ENABLE_AVX2=ON # CPU fallback optimizationRuntime:
# Use specific GPU
export CUDA_VISIBLE_DEVICES=0
# Limit VRAM usage
# (via config/acceleration.yaml)
cuda:
memory_limit_gb: 16# Optimize shaders
spirv-opt l2_distance.spv -O -o l2_distance_opt.spvFROM nvidia/cuda:12.3.0-devel-ubuntu22.04
RUN apt-get update && apt-get install -y \
cmake build-essential git
COPY . /themis
WORKDIR /themis
RUN cmake -S . -B build -DTHEMIS_ENABLE_CUDA=ON && \
cmake --build build
CMD ["./build/themis_server"]Run:
docker build -t themis-cuda .
docker run --gpus all themis-cudaFROM ubuntu:22.04
RUN apt-get update && apt-get install -y \
cmake build-essential git \
vulkan-sdk
# ... rest similar to CUDA- Use Visual Studio 2019+ with CUDA support
- Vulkan SDK installer handles environment variables
- DirectX 12 is native (no extra setup)
- CUDA: Requires proprietary NVIDIA drivers
- Vulkan: Works with Mesa drivers (AMD/Intel) or proprietary (NVIDIA)
- Best for multi-backend builds
- CUDA: Not supported (Apple deprecated CUDA)
- Vulkan: Via MoltenVK (Vulkan → Metal translation)
- Metal: Native, best performance on Apple Silicon
See Also:
Last Updated: 20. November 2025
Version: 1.0
- AQL Overview
- AQL Syntax Reference
- EXPLAIN and PROFILE
- Hybrid Queries
- Pattern Matching
- Subquery Implementation
- Subquery Quick Reference
- Fulltext Release Notes
- Hybrid Search Design
- Fulltext Search API
- Content Search
- Pagination Benchmarks
- Stemming
- Hybrid Fusion API
- Performance Tuning
- Migration Guide
- Storage Overview
- RocksDB Layout
- Geo Schema
- Index Types
- Index Statistics
- Index Backup
- HNSW Persistence
- Vector Index
- Graph Index
- Secondary Index
- Security Overview
- RBAC and Authorization
- TLS Setup
- Certificate Pinning
- Encryption Strategy
- Column Encryption
- Key Management
- Key Rotation
- HSM Integration
- PKI Integration
- eIDAS Signatures
- PII Detection
- PII API
- Threat Model
- Hardening Guide
- Incident Response
- SBOM
- Enterprise Overview
- Scalability Features
- Scalability Strategy
- HTTP Client Pool
- Enterprise Build Guide
- Enterprise Ingestion
- Benchmarks Overview
- Compression Benchmarks
- Compression Strategy
- Memory Tuning
- Hardware Acceleration
- GPU Acceleration Plan
- CUDA Backend
- Vulkan Backend
- Multi-CPU Support
- TBB Integration
- Time Series
- Vector Operations
- Graph Features
- Temporal Graphs
- Path Constraints
- Recursive Queries
- Audit Logging
- Change Data Capture
- Transactions
- Semantic Cache
- Cursor Pagination
- Compliance Features
- GNN Embeddings
- Geo Overview
- Geo Architecture
- 3D Game Acceleration
- Geo Feature Tiering
- G3 Phase 2 Status
- G5 Implementation
- Integration Guide
- Content Architecture
- Content Pipeline
- Content Manager
- JSON Ingestion
- Content Ingestion
- Filesystem API
- Image Processor
- Geo Processor
- Policy Implementation
- Developer Guide
- Implementation Status
- Development Roadmap
- Build Strategy
- Build Acceleration
- Code Quality Guide
- AQL LET Implementation
- Audit API Implementation
- SAGA API Implementation
- PKI eIDAS
- WAL Archiving
- Architecture Overview
- Strategic Overview
- Ecosystem
- MVCC Design
- Base Entity
- Caching Strategy
- Caching Data Structures
- Docker Build
- Docker Status
- Multi-Arch CI/CD
- ARM Build Guide
- ARM Packages
- Raspberry Pi Tuning
- Packaging Guide
- Package Maintainers
- Roadmap
- Changelog
- Database Capabilities
- Implementation Summary
- Sachstandsbericht 2025
- Enterprise Final Report
- Test Report
- Build Success Report
- Integration Analysis
- Source Overview
- API Implementation
- Query Engine
- Storage Layer
- Security Implementation
- CDC Implementation
- Time Series
- Utils and Helpers
Updated: 2025-11-30