Core implementation of Lightricks' LTX-2 model
Project description
LTX-Core
The foundational library for the LTX-2 Audio-Video generation model. This package contains the raw model definitions, component implementations, and loading logic used by ltx-pipelines and ltx-trainer.
๐ฆ What's Inside?
components/: Modular diffusion components (Schedulers, Guiders, Noisers, Patchifiers) following standard protocolsconditioning/: Tools for preparing latent states and applying conditioning (image, video, keyframes)guidance/: Perturbation system for fine-grained control over attention mechanismsloader/: Utilities for loading weights from.safetensors, fusing LoRAs, and managing memorymodel/: PyTorch implementations of the LTX-2 Transformer, Video VAE, Audio VAE, Vocoder and Upscalertext_encoders/gemma: Gemma text encoder implementation with tokenizers, feature extractors, and separate encoders for audio-video and video-only generationquantization/: FP8 quantization backends (FP8-TensorRT-LLM scaled MM, FP8 cast) for reduced memory footprint.
๐ Quick Start
ltx-core provides the building blocks (models, components, and utilities) needed to construct inference flows. For ready-made inference pipelines use ltx-pipelines or ltx-trainer for training.
๐ง Installation
# From the repository root
uv sync --frozen
# Or install as a package
pip install -e packages/ltx-core
Building Blocks Overview
ltx-core provides modular components that can be combined to build custom inference flows:
Core Models
- Transformer (
model/transformer/): The asymmetric dual-stream LTX-2 transformer (14B-parameter video stream, 5B-parameter audio stream) with bidirectional cross-modal attention for joint audio-video processing. Expects inputs inModalityformat - Video VAE (
model/video_vae/): Encodes/decodes video pixels to/from latent space with temporal and spatial compression - Audio VAE (
model/audio_vae/): Encodes/decodes audio spectrograms to/from latent space - Vocoder (
model/audio_vae/): Neural vocoder that converts mel spectrograms to audio waveforms - Text Encoder (
text_encoders/): Gemma 3-based multilingual encoder with multi-layer feature extraction and thinking tokens that produces separate embeddings for video and audio conditioning - Spatial Upscaler (
model/upsampler/): Upsamples latent representations for higher-resolution generation
Diffusion Components
- Schedulers (
components/schedulers.py): Noise schedules (LTX2Scheduler, LinearQuadratic, Beta) that control the denoising process - Guiders (
components/guiders.py): Guidance strategies (CFG, STG, APG) for controlling generation quality and adherence to prompts - Noisers (
components/noisers.py): Add noise to latents according to the diffusion schedule - Patchifiers (
components/patchifiers.py): Convert between spatial latents[B, C, F, H, W]and sequence format[B, seq_len, dim]for transformer processing
Conditioning & Control
- Conditioning (
conditioning/): Tools for preparing and applying various conditioning types (image, video, keyframes) - Guidance (
guidance/): Perturbation system for fine-grained control over attention mechanisms (e.g., skipping specific attention layers)
Utilities
- Loader (
loader/): Model loading from.safetensors, LoRA fusion, weight remapping, and memory management - Quantization (
quantization/): FP8 quantization backends for reduced memory footprint and faster inference
Loader
The loader/ module provides SingleGPUModelBuilder, a frozen dataclass that loads a PyTorch model from .safetensors checkpoints and optionally fuses one or more LoRA adapters.
Basic usage
from ltx_core.loader import SingleGPUModelBuilder
builder = SingleGPUModelBuilder(
model_class_configurator=MyModelConfigurator,
model_path="/path/to/model.safetensors",
)
model = builder.build(device=torch.device("cuda"))
Loading LoRA adapters
Use the .lora() method to attach one or more LoRA adapters before calling .build():
builder = (
SingleGPUModelBuilder(
model_class_configurator=MyModelConfigurator,
model_path="/path/to/model.safetensors",
)
.lora("/path/to/lora_a.safetensors", strength=0.8)
.lora("/path/to/lora_b.safetensors", strength=0.5)
)
model = builder.build(device=torch.device("cuda"))
Memory-efficient LoRA loading (lora_load_device)
By default, LoRA weights are loaded onto the CPU (lora_load_device=torch.device("cpu")). This means each LoRA adapter is kept in CPU memory and transferred to the GPU sequentially during weight fusion, which keeps peak GPU memory low even when fusing large adapters.
If all adapters fit comfortably in GPU memory you can skip the CPU staging by setting lora_load_device to the target CUDA device:
import torch
from ltx_core.loader import SingleGPUModelBuilder
# Load LoRA weights directly onto the GPU (faster, but uses more GPU memory)
builder = SingleGPUModelBuilder(
model_class_configurator=MyModelConfigurator,
model_path="/path/to/model.safetensors",
lora_load_device=torch.device("cuda"),
).lora("/path/to/lora.safetensors", strength=1.0)
model = builder.build(device=torch.device("cuda"))
Quantization
The quantization/ module provides FP8 quantization support for the LTX-2 transformer, significantly reducing memory usage while maintaining quality. Two backends are available:
FP8 Scaled MM (TensorRT-LLM)
Uses NVIDIA TensorRT-LLM's cublas_scaled_mm for efficient FP8 matrix multiplication. Weights are stored in FP8 format with per-tensor scaling, and inputs are quantized dynamically (or statically with calibration data).
Requirements: uv sync --frozen --extra fp8-trtllm
Usage with QuantizationPolicy:
from ltx_core.quantization import QuantizationPolicy
# Dynamic input quantization (no calibration needed)
policy = QuantizationPolicy.fp8_scaled_mm()
# Static input quantization with calibration file
policy = QuantizationPolicy.fp8_scaled_mm(calibration_amax_path="/path/to/amax.json")
The policy provides sd_ops and module_ops that can be passed to the model builder:
from ltx_core.loader import SingleGPUModelBuilder
builder = SingleGPUModelBuilder(
model=model,
device=device,
sd_ops=policy.sd_ops,
module_ops=policy.module_ops,
)
builder.load(checkpoint_path)
Calibration File Format (for static input quantization):
{
"amax_values": {
"transformer_blocks.0.attn.to_q.input_quantizer": 12.5,
"transformer_blocks.0.attn.to_k.input_quantizer": 8.3,
...
}
}
FP8 Cast
A simpler approach that casts weights to FP8 for storage and upcasts during inference:
policy = QuantizationPolicy.fp8_cast()
For complete, production-ready pipeline implementations that combine these building blocks, see the ltx-pipelines package.
Architecture Overview
This section provides a deep dive into the internal architecture of the LTX-2 Audio-Video generation model.
Table of Contents
- High-Level Architecture
- The Transformer
- Video VAE
- Audio VAE
- Text Encoding (Gemma)
- Spatial Upscaler
- Data Flow
High-Level Architecture
LTX-2 is an asymmetric dual-stream diffusion transformer that jointly models the text-conditioned distribution of video and audio signals, capturing true joint dependencies (unlike sequential T2VโV2A pipelines).
Key Design Principles
- Decoupled Latent Representations: Separate modality-specific VAEs enable 3D RoPE (video) vs 1D RoPE (audio), independent compression optimization, and native V2A/A2V editing workflows
- Asymmetric Dual-Stream: 14B-parameter video stream (spatiotemporal dynamics) + 5B-parameter audio stream (1D temporal), sharing 48 transformer blocks but differing in width
- Bidirectional Cross-Modal Attention: 1D temporal RoPE enables sub-frame alignment, mapping visual cues to auditory events (lip-sync, foley, environmental acoustics)
- Cross-Modality AdaLN: Scaling/shift parameters conditioned on the other modality's hidden states for synchronization across differing diffusion timesteps/temporal resolutions
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ INPUT PREPARATION โ
โ โ
โ Video Pixels โ Video VAE Encoder โ Video Latents โ
โ Audio Waveform โ Audio VAE Encoder โ Audio Latents โ
โ Text Prompt โ Gemma 3 Encoder โ Text Embeddings โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ LTX-2 ASYMMETRIC DUAL-STREAM TRANSFORMER (48 Blocks) โ
โ โ
โ โโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโ โ
โ โ Video Stream (14B) โ โ Audio Stream (5B) โ โ
โ โ โ โ โ โ
โ โ 3D RoPE (x,y,t) โ โ 1D RoPE (temporal) โ โ
โ โ โ โ โ โ
โ โ Self-Attn โ โ Self-Attn โ โ
โ โ Text Cross-Attn โ โ Text Cross-Attn โ โ
โ โ โโโโโโโบโ โ โ
โ โ AโV Cross-Attn โ โ AโV Cross-Attn โ โ
โ โ (1D temporal RoPE) โ โ (1D temporal RoPE) โ โ
โ โ Cross-modality โ โ Cross-modality โ โ
โ โ AdaLN โ โ AdaLN โ โ
โ โ Feed-Forward โ โ Feed-Forward โ โ
โ โโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโ โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ OUTPUT DECODING โ
โ โ
โ Video Latents โ Video VAE Decoder โ Video Pixels โ
โ Audio Latents โ Audio VAE Decoder โ Mel Spectrogram โ
โ Mel Spectrogram โ Vocoder โ Audio Waveform (24 kHz) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
The Transformer
The core of LTX-2 is an asymmetric dual-stream diffusion transformer with 48 layers that processes both video and audio tokens simultaneously. The architecture allocates 14B parameters to the video stream and 5B parameters to the audio stream, reflecting the different information densities of the two modalities.
Model Structure
Source: src/ltx_core/model/transformer/model.py
The LTXModel class implements the transformer. It supports both video-only and audio-video generation modes. For actual usage, see the ltx-pipelines package which handles model loading and initialization.
Transformer Block Architecture
Source: src/ltx_core/model/transformer/transformer.py
Each dual-stream block performs four operations sequentially:
- Self-Attention: Within-modality attention for each stream
- Text Cross-Attention: Textual prompt conditioning for both streams
- Audio-Visual Cross-Attention: Bidirectional inter-modal exchange
- Feed-Forward Network (FFN): Feature refinement
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ TRANSFORMER BLOCK โ
โ โ
โ VIDEO (14B): Input โ RMSNorm โ AdaLN โ Self-Attn โ โ
โ RMSNorm โ Text Cross-Attn โ โ
โ RMSNorm โ AdaLN โ AโV Cross-Attn (1D RoPE) โ โ
โ RMSNorm โ AdaLN โ FFN โ Output โ
โ โ
โ AUDIO (5B): Input โ RMSNorm โ AdaLN โ Self-Attn โ โ
โ RMSNorm โ Text Cross-Attn โ โ
โ RMSNorm โ AdaLN โ AโV Cross-Attn (1D RoPE) โ โ
โ RMSNorm โ AdaLN โ FFN โ Output โ
โ โ
โ RoPE: Video=3D (x,y,t), Audio=1D (t), Cross-Attn=1D (t) โ
โ AdaLN: Timestep-conditioned, cross-modality for AโV CA โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Audio-Visual Cross-Attention Details
Bidirectional cross-attention enables tight temporal alignment: video and audio streams exchange information bidirectionally using 1D temporal RoPE (synchronization only, no spatial alignment). AdaLN gates condition on each modality's timestep for cross-modal synchronization.
Perturbations
The transformer supports perturbations that selectively skip attention operations.
Perturbations allow you to disable specific attention mechanisms during inference, which is useful for guidance techniques like STG (Spatio-Temporal Guidance).
Supported Perturbation Types:
SKIP_VIDEO_SELF_ATTN: Skip video self-attentionSKIP_AUDIO_SELF_ATTN: Skip audio self-attentionSKIP_A2V_CROSS_ATTN: Skip audio-to-video cross-attentionSKIP_V2A_CROSS_ATTN: Skip video-to-audio cross-attention
Perturbations are used internally by guidance mechanisms like STG (Spatio-Temporal Guidance). For usage examples, see the ltx-pipelines package.
Video VAE
The Video VAE (src/ltx_core/model/video_vae/) encodes video pixels into latent representations and decodes them back.
Architecture
- Encoder: Compresses
[B, 3, F, H, W]pixels โ[B, 128, F', H/32, W/32]latents- Where
F' = 1 + (F-1)/8(frame count must satisfy(F-1) % 8 == 0) - Example:
[B, 3, 33, 512, 512]โ[B, 128, 5, 16, 16]
- Where
- Decoder: Expands
[B, 128, F, H, W]latents โ[B, 3, F', H*32, W*32]pixels- Where
F' = 1 + (F-1)*8 - Example:
[B, 128, 5, 16, 16]โ[B, 3, 33, 512, 512]
- Where
The Video VAE is used internally by pipelines for encoding video pixels to latents and decoding latents back to pixels. For usage examples, see the ltx-pipelines package.
Audio VAE
The Audio VAE (src/ltx_core/model/audio_vae/) processes audio spectrograms.
Audio VAE Architecture
Compact neural audio representation optimized for diffusion-based training. Natively supports stereo: processes two-channel mel-spectrograms (16 kHz input) with channel concatenation before encoding.
- Encoder:
[B, mel_bins, T]โ[B, 8, T/4, 16]latents (4ร temporal downsampling, 8 channels, 16 mel bins in latent space, ~1/25s per token, 128-dim feature vector) - Decoder:
[B, 8, T, 16]โ[B, mel_bins, T*4]mel spectrogram - Vocoder: HiFi-GAN-based, modified for stereo synthesis and upsampling (16 kHz mel โ 24 kHz waveform, doubled generator capacity for stereo)
Downsampling:
- Temporal: 4ร (time steps)
- Frequency: Variable (input mel_bins โ fixed 16 in latent space)
The Audio VAE is used internally by pipelines for encoding mel spectrograms to latents and decoding latents back to mel spectrograms. The vocoder converts mel spectrograms to audio waveforms. For usage examples, see the ltx-pipelines package.
Text Encoding (Gemma)
LTX-2 uses Gemma 3 (Gemma 3-12B) as the multilingual text encoder backbone, located in src/ltx_core/text_encoders/gemma/. Advanced text understanding is critical not only for global language support but for the phonetic and semantic accuracy of generated speech.
Text Encoder Architecture
The text conditioning pipeline consists of three stages:
- Gemma 3 Backbone: Decoder-only LLM processes text tokens โ embeddings across all layers
[B, T, D, L] - Multi-Layer Feature Extractor: Aggregates features from all decoder layers (not just final layer), applies mean-centered scaling, flattens to
[B, T, DรL], and projects via learnable matrix W (jointly optimized with LTX-2, LLM weights frozen) - Text Connector: Bidirectional transformer blocks with learnable registers (replacing padded positions, also referred to as "thinking tokens" in the paper) for contextual mixing. Separate connectors for video and audio streams (
Embeddings1DConnector)
Encoders:
AVGemmaTextEncoderModel: Audio-video generation (two connectors โAVGemmaEncoderOutputwith separate video/audio contexts)VideoGemmaTextEncoderModel: Video-only generation (single connector โVideoGemmaEncoderOutput)
System Prompts
System prompts are also used to enhance user's prompts.
- Text-to-Video:
gemma_t2v_system_prompt.txt - Image-to-Video:
gemma_i2v_system_prompt.txt
Important: Video and audio receive different context embeddings, even from the same prompt. This allows better modality-specific conditioning and enables the model to synthesize speech that is synchronized with visual lip movement while being natural in cadence, accent, and emotional tone.
Output Format:
- Video context:
[B, seq_len, 4096]- Video-specific text embeddings - Audio context:
[B, seq_len, 2048]- Audio-specific text embeddings
The text encoder is used internally by pipelines. For usage examples, see the ltx-pipelines package.
Upscaler
The Upscaler (src/ltx_core/model/upsampler/) upsamples latent representations for higher-resolution output.
The spatial upsampler is used internally by two-stage pipelines (e.g., TI2VidTwoStagesPipeline, ICLoraPipeline) to upsample low-resolution latents before final VAE decoding. For usage examples, see the ltx-pipelines package.
Data Flow
Complete Generation Pipeline
Here's how all the components work together conceptually (src/ltx_core/components/):
Pipeline Steps:
- Text Encoding: Text prompt โ Gemma encoder โ separate video/audio embeddings
- Latent Initialization: Initialize noise latents in spatial format
[B, C, F, H, W] - Patchification: Convert spatial latents to sequence format
[B, seq_len, dim]for transformer - Sigma Schedule: Generate noise schedule (adapts to token count)
- Denoising Loop: Iteratively denoise using transformer predictions
- Create Modality inputs with per-token timesteps and RoPE positions
- Forward pass through transformer (conditional and unconditional for CFG)
- Apply guidance (CFG, STG, etc.)
- Update latents using diffusion step (Euler, etc.)
- Unpatchification: Convert sequence back to spatial format
- VAE Decoding: Decode latents to pixel space (with optional upsampling for two-stage)
TI2VidTwoStagesPipeline- Two-stage text-to-video (recommended)ICLoraPipeline- Video-to-video with IC-LoRA controlDistilledPipeline- Fast inference with distilled modelKeyframeInterpolationPipeline- Keyframe-based interpolation
See the ltx-pipelines README for usage examples.
๐ Related Projects
- ltx-pipelines - High-level pipeline implementations for text-to-video, image-to-video, and video-to-video
- ltx-trainer - Training and fine-tuning tools
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ltx_core-1.0.0.tar.gz.
File metadata
- Download URL: ltx_core-1.0.0.tar.gz
- Upload date:
- Size: 108.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
89c9484b733d1a04643acc3c9376c131abb9fe1a2a20cf76ec921f27dae4aee0
|
|
| MD5 |
bbe471ffb2c902933035c6b98a01b1f3
|
|
| BLAKE2b-256 |
d8910d5895a92f783cb3cdb94851bfd50288b2c42105e9b807dd20fa1eda54e1
|
File details
Details for the file ltx_core-1.0.0-py3-none-any.whl.
File metadata
- Download URL: ltx_core-1.0.0-py3-none-any.whl
- Upload date:
- Size: 147.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
610b33f1838b1dcc7b650def8171145341523df632afa88348fab49d09ef63fe
|
|
| MD5 |
371a1f0a6ae25533eaea6fc4cf481710
|
|
| BLAKE2b-256 |
45fe36862ad494293f38918c9ec9587b26a6a1e84f2a4d408a6cf02e5e5b3a88
|