-
Notifications
You must be signed in to change notification settings - Fork 1
build_acceleration
Stand: 5. Dezember 2025
Version: 1.0.0
Kategorie: Development
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
ThemisDB v1.3.4 | GitHub | Documentation | Discussions | License
Last synced: January 02, 2026 | Commit: 6add659
Version: 1.3.0 | Stand: Dezember 2025
- Übersicht
- Home
- Dokumentations-Index
- Quick Reference
- Sachstandsbericht 2025
- Features
- Roadmap
- Ecosystem Overview
- Strategische Übersicht
- Geo/Relational Storage
- RocksDB Storage
- MVCC Design
- Transaktionen
- Time-Series
- Memory Tuning
- Chain of Thought Storage
- Query Engine & AQL
- AQL Syntax
- Explain & Profile
- Rekursive Pfadabfragen
- Temporale Graphen
- Zeitbereichs-Abfragen
- Semantischer Cache
- Hybrid Queries (Phase 1.5)
- AQL Hybrid Queries
- Hybrid Queries README
- Hybrid Query Benchmarks
- Subquery Quick Reference
- Subquery Implementation
- Content Pipeline
- Architektur-Details
- Ingestion
- JSON Ingestion Spec
- Enterprise Ingestion Interface
- Geo-Processor Design
- Image-Processor Design
- Hybrid Search Design
- Fulltext API
- Hybrid Fusion API
- Stemming
- Performance Tuning
- Migration Guide
- Future Work
- Pagination Benchmarks
- Enterprise README
- Scalability Features
- HTTP Client Pool
- Build Guide
- Implementation Status
- Final Report
- Integration Analysis
- Enterprise Strategy
- Verschlüsselungsstrategie
- Verschlüsselungsdeployment
- Spaltenverschlüsselung
- Encryption Next Steps
- Multi-Party Encryption
- Key Rotation Strategy
- Security Encryption Gap Analysis
- Audit Logging
- Audit & Retention
- Compliance Audit
- Compliance
- Extended Compliance Features
- Governance-Strategie
- Compliance-Integration
- Governance Usage
- Security/Compliance Review
- Threat Model
- Security Hardening Guide
- Security Audit Checklist
- Security Audit Report
- Security Implementation
- Development README
- Code Quality Pipeline
- Developers Guide
- Cost Models
- Todo Liste
- Tool Todo
- Core Feature Todo
- Priorities
- Implementation Status
- Roadmap
- Future Work
- Next Steps Analysis
- AQL LET Implementation
- Development Audit
- Sprint Summary (2025-11-17)
- WAL Archiving
- Search Gap Analysis
- Source Documentation Plan
- Changefeed README
- Changefeed CMake Patch
- Changefeed OpenAPI
- Changefeed OpenAPI Auth
- Changefeed SSE Examples
- Changefeed Test Harness
- Changefeed Tests
- Dokumentations-Inventar
- Documentation Summary
- Documentation TODO
- Documentation Gap Analysis
- Documentation Consolidation
- Documentation Final Status
- Documentation Phase 3
- Documentation Cleanup Validation
- API
- Authentication
- Cache
- CDC
- Content
- Geo
- Governance
- Index
- LLM
- Query
- Security
- Server
- Storage
- Time Series
- Transaction
- Utils
Vollständige Dokumentation: https://makr-code.github.io/ThemisDB/