Browse ModelsBytedanceBytedance Avatar Omni Human

Bytedance Avatar Omni Human

Bytedance Avatar Omni Human

Playground

Try it on WavespeedAI!

Bytedance OmniHuman turns a single portrait photo into avatar video with lifelike motion and expressions ($0.12/sec). Ready-to-use REST inference API, best performance, no coldstarts, affordable pricing.

Features

ByteDance Avatar Omni Human

Transform any portrait into a realistic talking avatar with ByteDance’s Avatar Omni Human. Simply upload a photo and an audio clip, and watch the subject come to life with perfectly synchronized lip movements, natural expressions, and lifelike head motion — ideal for virtual presenters, digital content, and personalized video messages.

Why It Looks Great

  • Realistic lip sync: Advanced audio analysis ensures precise mouth movements matching every syllable.
  • Natural expressions: Generates authentic facial expressions and subtle head movements.
  • Simple workflow: Just two inputs — an image and audio — for complete avatar generation.
  • High fidelity: Preserves the original portrait’s likeness and quality.
  • Versatile audio support: Works with speech, singing, and various audio types.

Parameters

ParameterRequiredDescription
imageYesPortrait image of the person to animate (upload or public URL).
audioYesAudio file for lip synchronization (upload or public URL).
enable_base64_outputNoAPI only: Returns base64 string instead of URL.

How to Use

  1. Upload your image — drag and drop a clear portrait photo or paste a public URL.
  2. Upload your audio — add the speech or audio you want the avatar to perform.
  3. Run — click the button to generate.
  4. Download — preview and save your talking avatar video.

Pricing

Per-second billing based on audio duration.

MetricCost
Per second$0.12

Examples

Audio LengthCalculationTotal Cost
5s5 × $0.12$0.60
15s15 × $0.12$1.80
30s30 × $0.12$3.60
1m (60s)60 × $0.12$7.20
5m (300s)300 × $0.12$36.00

Best Use Cases

  • Virtual Presenters — Create AI spokespeople for videos, presentations, and training content.
  • Personalized Messages — Generate custom video messages from a single photo.
  • Content Localization — Dub content into different languages with matching lip movements.
  • Social Media Content — Produce engaging talking-head videos without filming.
  • E-learning & Training — Create instructor-led content from static presenter images.
  • Digital Avatars — Bring character portraits and illustrations to life with speech.

Pro Tips for Best Results

  • Use clear, front-facing portrait photos with good lighting for best lip sync accuracy.
  • Ensure the face is clearly visible and not obscured by hair, accessories, or shadows.
  • High-quality audio with minimal background noise produces more accurate synchronization.
  • Neutral or slightly open mouth expressions in the source image work best.
  • The subject’s face should be a reasonable size in the frame — not too small or cropped.
  • Test with shorter audio clips first before processing longer content.

Notes

  • If using URLs for image or audio, ensure they are publicly accessible.
  • The enable_base64_output option is only available through the API.
  • Processing time scales with audio duration.
  • Best results come from portrait-style images with clear facial features.
  • Works with various audio formats — speech, narration, singing, and more.

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/bytedance/avatar-omni-human" \
--header "Content-Type: application/json" \
--header "Authorization: Bearer ${WAVESPEED_API_KEY}" \
--data-raw '{
    "enable_base64_output": false
}'

# 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
imagestringYes-The portrait image to animate, can be a URL or base64 encoded image. Better results with clear, front-facing portraits with good lighting.
audiostringYes--Optional background audio for the generated video, can be a URL or base64 encoded audio file.
enable_base64_outputbooleanNofalse-If enabled, the output will be encoded into a BASE64 string instead of a URL. This property is only available through the API.

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 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.outputsstringArray 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.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.