krakjoe / ort
High performance tensor mathematics for PHP.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 108
Watchers: 4
Forks: 6
Open Issues: 2
Language:C
Type:php-ext-zend
Ext name:ext-ort
pkg:composer/krakjoe/ort
Requires
- php: >=8.0
This package is auto-updated.
Last update: 2025-10-22 09:32:32 UTC
README
PHP - Oh Really, Tensors?
This extension provides high performance tensor mathematics. It supports a wide range of mathematical operations on tensors, including element-wise computations, reductions, linear algebra functions, and more.
This extension also includes optional integration with Microsoft's ONNX Runtime for efficient model execution.
Features
- High-Performance Mathematics: SIMD-accelerated operations (AVX2, SSE4.1, SSE2)
- Multi-Core Parallelism: Automatic work distribution across CPU cores
- Comprehensive Type Support: 9 data types with automatic promotion
- Memory Efficient: Reference-counted tensors with zero-copy slicing
- ONNX Integration: Optional and Direct ONNX model loading and inference
Quick Start
Installation
# Build extension
phpize
./configure --enable-ort
make
sudo make install
Installation with ONNX Runtime
# Fetch onnxruntime from github wget https://github.com/microsoft/onnxruntime/releases/download/v1.22.0/onnxruntime-linux-x64-1.22.0.tgz # Install onnxruntime tar -C /usr/local -xvf onnxruntime-linux-x64-1.22.0.tgz --strip-components 1 # Build and install extension phpize ./configure --with-ort-onnx=/usr/local --enable-ort make sudo make install
Note: Use microsoft provided releases of ONNX, not brew or ppa or apt provided releases.
Post Installation
Add to your php.ini:
extension=ort.so
Basic Usage
use ORT\Tensor\Transient; use ORT\Math; // Create tensors $a = new Transient([1000, 1000], $matrix_data, ORT\Tensor::FLOAT); $b = new Transient([1000, 1000], $matrix_data, ORT\Tensor::FLOAT); // High-performance matrix multiplication $result = Math\matmul($a, $b); // Element-wise operations $sum = Math\add($a, $b); $scaled = Math\multiply($a, 2.5); // Scalar operations // Reductions $total = Math\reduce\tensor\sum($a); $row_sums = Math\reduce\axis\sum($a, 1);
Performance
- SIMD Acceleration: Up to 8x faster with AVX2 vectorization
- Multi-Core Scaling: Automatic scaling to available CPU cores
- Memory Optimization: Aligned memory allocation for optimal performance
Check your system configuration:
echo "Backend: " . (ORT\Math\backend() ?: "scalar") . "\n"; echo "Cores: " . ORT\Math\cores() . "\n";
API Reference (not exhaustive)
Tensor Types
- ORT\Tensor\Transient- Temporary tensors
- ORT\Tensor\Persistent- Named, persistent tensors
Mathematical Operations
- Binary: add,subtract,multiply,divide,pow,mod
- Unary: sin,cos,exp,log,sqrt,abs,neg
- Matrix: matmul,dot,transpose
- Reduction: sum,mean,min,max,softmax
ONNX Integration
- ORT\Model- Load and manage ONNX models
- ORT\Runtime- Execute ONNX model inference
Configuration
Environment Variables
- ORT_SCALE_CORES- Set thread pool size (default: CPU cores)
Build Options
- --enable-ort-backend- Enable SIMD optimizations (default: yes)
- --disable-ort-avx2- Disable AVX2, use SSE4.1
- --disable-ort-sse41- Disable SSE4.1, use SSE2
- --enable-ort-neon- For armv8 builds (disable all other backends)
- --disable-ort-backend- Disable all SIMD optimizations (default: no)
- --with-ort-onnx- Link against ONNX Runtime (default: no)
Technical Details
See docs for detailed technical documentation.
Requirements
- PHP: 7.4+ or 8.0+
- ONNX Runtime: 1.16+ (optional)
- Compiler: GCC 4.8+ or Clang 3.8+
- CPU: x86_64 with SSE2 (AVX2 recommended)
License
This project is licensed under the PHP License 3.01.
Contributing
Contributions are welcome! Please ensure:
- Code follows existing style conventions
- SIMD implementations include proper fallbacks
- Thread safety is maintained
- Tests pass across supported PHP versions
Support
For issues and feature requests, please use the project's issue tracker.