VOID Video Inpainting removes objects from videos using mask-guided inpainting. Supports quad-mask or auto-generated SAM-3 masks, optional Pass 2 refinement for temporal consistency, adjustable denoising steps, guidance scale, and temporal window size. Ready-to-use REST inference API, best performance, no coldstarts, affordable pricing.
En attente
$0.05par exécution·~20 / $1
The man is having breakfast.
VOID Video Inpainting removes objects or people from video footage and fills the background with realistic, temporally consistent content. Describe what to remove and what the background should look like — the model handles the rest, with optional mask video input for precise control.
Text-driven object removal Describe the object or person to remove in plain language — no manual masking required. The model uses SAM-3 to auto-generate a mask from your text description.
Custom mask video support Upload a pre-prepared VOID-style quadmask or simple binary mask video for precise, frame-accurate removal control.
Background inpainting Describe the desired background after removal — the model fills the gap with contextually appropriate, motion-consistent content.
Pass 2 refinement Enable enable_pass2_refinement for additional warped-noise refinement that improves temporal consistency on longer clips.
Fine-grained generation control Adjust inference steps, guidance scale, denoising strength, and temporal window size for precise output control.
| Parameter | Required | Description |
|---|---|---|
| video | Yes | Input video containing the object to remove (URL). |
| prompt | Yes | Text description of the desired background after object removal. |
| mask_video | No | Mask video URL. Supports VOID quadmask (4 grayscale values) or simple binary mask. Auto-generated if omitted. |
| mask_prompt | No | Text description of what to mask/remove. Used to auto-generate a mask when mask_video is not provided. |
| enable_pass2_refinement | No | Run Pass 2 warped-noise refinement for improved temporal consistency. Slower but higher quality. Default: false. |
| negative_prompt | No | Negative prompt to guide generation away from undesired outputs. |
| num_inference_steps | No | Number of denoising steps. Range: 1–50. Default: 30. Higher = better quality, slower. |
| guidance_scale | No | Classifier-free guidance scale. Range: 0–20. Default: 1. |
| strength | No | Denoising strength. Range: 0–1. Default: 1 (full denoising). |
| num_frames | No | Temporal window size. Valid values: 69, 77, 85, …, 197. Default: 85. |
| seed | No | Random seed for reproducible results. |
The mask_video supports two formats:
If mask_video is not provided, a mask is auto-generated from mask_prompt using SAM-3.
| Pass 2 Refinement | Mask Video | Cost |
|---|---|---|
| No | No (auto) | $0.05 |
| Yes | No (auto) | $0.10 |
| No | Yes | $0.10 |
| Yes | Yes | $0.15 |
Grab a WaveSpeedAI API key, then call POST https://api.wavespeed.ai/api/v3/wavespeed-ai/void-video-inpainting/mask with your input as JSON. The endpoint returns a prediction id; poll the prediction endpoint until status flips to completed, then read the output URL from data.outputs[0]. Examples for Void Video Inpainting Mask below.
# Submit the prediction
curl -X POST "https://api.wavespeed.ai/api/v3/wavespeed-ai/void-video-inpainting/mask" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $WAVESPEED_API_KEY" \
-d '{
"prompt": "A cinematic shot of a city at sunset, soft golden light",
"video": "https://example.com/your-input.mp4",
"enable_pass2_refinement": false,
"negative_prompt": "blurry, low quality, distorted",
"num_inference_steps": 30,
"guidance_scale": 1,
"strength": 1,
"num_frames": 85,
"seed": 0
}'
# Response includes a prediction id. Poll for the result:
curl -X GET "https://api.wavespeed.ai/api/v3/predictions/{request_id}/result" \
-H "Authorization: Bearer $WAVESPEED_API_KEY"
# When status is "completed", read the output from data.outputs[0].// npm install wavespeed
const WaveSpeed = require('wavespeed');
const client = new WaveSpeed(); // reads WAVESPEED_API_KEY from env
const result = await client.run("wavespeed-ai/void-video-inpainting/mask", {
"prompt": "A cinematic shot of a city at sunset, soft golden light",
"video": "https://example.com/your-input.mp4",
"enable_pass2_refinement": false,
"negative_prompt": "blurry, low quality, distorted",
"num_inference_steps": 30,
"guidance_scale": 1,
"strength": 1,
"num_frames": 85,
"seed": 0
});
console.log(result.outputs[0]); // → URL of the generated output# pip install wavespeed
import wavespeed
output = wavespeed.run(
"wavespeed-ai/void-video-inpainting/mask",
{
"prompt": "A cinematic shot of a city at sunset, soft golden light",
"video": "https://example.com/your-input.mp4",
"enable_pass2_refinement": false,
"negative_prompt": "blurry, low quality, distorted",
"num_inference_steps": 30,
"guidance_scale": 1,
"strength": 1,
"num_frames": 85,
"seed": 0
}
)
print(output["outputs"][0]) # → URL of the generated outputVoid Video Inpainting Mask is a WaveSpeedAI model for video editing, exposed as a REST API on WaveSpeedAI. VOID Video Inpainting removes objects from videos using mask-guided inpainting. Supports quad-mask or auto-generated SAM-3 masks, optional Pass 2 refinement for temporal consistency, adjustable denoising steps, guidance scale, and temporal window size. Ready-to-use REST inference API, best performance, no coldstarts, affordable pricing. You can call it programmatically or try it from the playground above.
POST your input parameters to the model's REST endpoint (shown in the API tab of this playground) with your WaveSpeedAI API key in the Authorization header. Submission returns a prediction ID; poll the prediction endpoint until status flips to "completed", then read the output URL from the result. The playground generates a ready-to-paste code sample in Python, JavaScript, or cURL for whatever inputs you've set. Full request/response shape is documented at https://wavespeed.ai/docs/docs-api/wavespeed-ai/void-video-inpainting-mask.
Void Video Inpainting Mask starts at $0.050 per run. That figure is the base price — the final charge scales with the parameters you set in the form (output size, length, count, references, or whatever knobs this model exposes), so a higher-quality or larger output costs more than a minimal one. The exact cost for your current input is shown live next to the Generate button before you submit, and the actual per-call charge is recorded on the prediction afterwards.
Key inputs: `prompt`, `video`, `seed`, `guidance_scale`, `num_inference_steps`, `negative_prompt`. The full JSON schema (types, defaults, allowed values) is rendered above the Generate button and mirrored in the API reference at https://wavespeed.ai/docs/docs-api/wavespeed-ai/void-video-inpainting-mask.
Sign up for a free WaveSpeedAI account to claim starter credits, copy your API key from /accesskey, then call the endpoint shown in the API tab of the playground. The playground also auto-generates a code sample in Python, JavaScript, or cURL for the parameters you've set.
Commercial usage rights depend on the model's license, set by its provider (WaveSpeedAI). The license summary appears on the model card above; see WaveSpeedAI's Terms of Service for platform-level conditions.