WaveSpeedAI APIWavespeed AIWan 2.2 Image LoRA Trainer

Wan 2.2 Image LoRA Trainer

Wan 2.2 Image LoRA Trainer

Playground

Try it on WavespeedAI!

Train custom Wan 2.2 LoRA models 10x faster. Style training, character training, object training. From concept to model in minutes, not hours. Upload a ZIP file containing images to start!

Features

Wan 2.2 image LoRA Trainer

Wan 2.2 LoRA Trainer is a high-performance custom model training service for the Wan 2.2 text-to-video generation model. Train personalized LoRA (Low-Rank Adaptation) models 10x faster than traditional methods, enabling custom styles, characters, and objects for video generation.

Training Architecture

The trainer leverages Wan 2.2’s innovative MoE (Mixture of Experts) architecture, producing two specialized LoRA models:

  • high_noise_lora: Optimized for high-noise denoising timesteps, handling initial structure and composition
  • low_noise_lora: Optimized for low-noise denoising timesteps, refining details and final output quality

This dual-model approach ensures superior training efficiency and generation quality across all denoising stages.

Training Process

  1. Data Upload: Upload a ZIP file containing your training images
  2. Automatic Processing: The system automatically processes and optimizes your dataset
  3. Dual Model Training: Simultaneously trains both high_noise_lora and low_noise_lora models
  4. Model Delivery: Receive two specialized LoRA models ready for video generation

Authentication

For authentication details, please refer to the Authentication Guide.

API Endpoints

Submit Task & Query Result


# Submit the task
curl --location --request POST "https://api.wavespeed.ai/api/v3/wavespeed-ai/wan-2.2-image-lora-trainer" \
--header "Content-Type: application/json" \
--header "Authorization: Bearer ${WAVESPEED_API_KEY}" \
--data-raw '{
    "data": "",
    "trigger_word": "p3r5on",
    "steps": 1000,
    "learning_rate": 0.0004,
    "lora_rank": 32
}'

# Get the result
curl --location --request GET "https://api.wavespeed.ai/api/v3/predictions/${requestId}/result" \
--header "Authorization: Bearer ${WAVESPEED_API_KEY}"

Parameters

Task Submission Parameters

Request Parameters

ParameterTypeRequiredDefaultRangeDescription
datastringYes--To train a WAN T2V LoRA, you need to upload a zip file containing at least 10 images. In addition to images the archive can contain text files with captions. Each text file should have the same name as the image file it corresponds to.
trigger_wordstringNop3r5on-The phrase that will trigger the model to generate an video.
stepsintegerNo10001000 ~ 10000Number of steps to train the LoRA on.
learning_ratenumberNo0.00040.00000 ~ 1.00000
lora_rankintegerNo321 ~ 128

Response Parameters

ParameterTypeDescription
codeintegerHTTP status code (e.g., 200 for success)
messagestringStatus message (e.g., “success”)
data.idstringUnique identifier for the prediction, Task Id
data.modelstringModel ID used for the prediction
data.outputsarrayArray of URLs to the generated content (empty when status is not completed)
data.urlsobjectObject containing related API endpoints
data.urls.getstringURL to retrieve the prediction result
data.has_nsfw_contentsarrayArray of boolean values indicating NSFW detection for each output
data.statusstringStatus of the task: created, processing, completed, or failed
data.created_atstringISO timestamp of when the request was created (e.g., “2023-04-01T12:34:56.789Z”)
data.errorstringError message (empty if no error occurred)
data.timingsobjectObject containing timing details
data.timings.inferenceintegerInference time in milliseconds

Result Query Parameters

Result Request Parameters

ParameterTypeRequiredDefaultDescription
idstringYes-Task ID

Result Response Parameters

ParameterTypeDescription
codeintegerHTTP status code (e.g., 200 for success)
messagestringStatus message (e.g., “success”)
dataobjectThe prediction data object containing all details
data.idstringUnique identifier for the prediction, the ID of the prediction to get
data.modelstringModel ID used for the prediction
data.outputsarrayArray of URLs to the generated content (empty when status is not completed)
data.urlsobjectObject containing related API endpoints
data.urls.getstringURL to retrieve the prediction result
data.has_nsfw_contentsarrayArray of boolean values indicating NSFW detection for each output
data.statusstringStatus of the task: created, processing, completed, or failed
data.created_atstringISO timestamp of when the request was created (e.g., “2023-04-01T12:34:56.789Z”)
data.errorstringError message (empty if no error occurred)
data.timingsobjectObject containing timing details
data.timings.inferenceintegerInference time in milliseconds
© 2025 WaveSpeedAI. All rights reserved.