Member of Technical Staff (AI Inference Engineer)
Perplexity · London, United Kingdom · AI
About this role
Perplexity is hiring a staff-level Staff Engineer in the software engineering function based in London, United Kingdom. The posting calls out experience with TensorFlow, PyTorch, LLMs, Deep Learning.
- Role
- Staff Engineer
- Function
- software engineering
- Level
- staff
- Track
- Tech leadership
- Employment
- Full-time
- Location
- London, United Kingdom
- Department
- AI
- Posted
- Apr 13, 2026
More roles at Perplexity
Job description
from Perplexity careersWe are looking for an AI Inference Engineer to join our growing team. We build and run the inference engine behind every Perplexity query and deploy dozens of model architectures at scale with tight latency and cost budgets. Our stack is Rust, Python, CUDA, and CuTe DSL.
Responsibilities:
New models support. Support transformer-based retrieval, text-generation, and multimodal models in our inference infrastructure, from weight loading, request scheduling and KV-cache management to support in API Gateway.
GPU kernels migration to CuTe DSL. Port our in-house CUDA kernels to NVIDIA's CuTe DSL so they run on GB200 today and are portable to Vera Rubin racks tomorrow.
Rust-native serving runtime. Develop our internal Rust-based inference server to solve all Python pains and keep up with rapidly growing traffic.
Performance optimisation. Profile and fix bottlenecks from network ingress through continuous batching and GPU kernels interleaving.
Reliability and observability. Build dashboards, alerts, and automated remediation so we catch regressions before users do. Respond to and learn from production incidents.
Who we're looking for:
Deep experience with GPU programming and performance work (CUDA, Triton, CUTLASS, or similar). Any other deep systems programming experience is a plus.
You understand modern LLM architectures and are able to bring them up reliably in a production environment.
This is an excerpt. Read the full job description on Perplexity careers →