ℹ️ Info:
We just migrated to a new server infrastructure!
All current workflows should continue to work with the existing endpoint and no changes are needed from you.
If you experience any issues, you can temporarily use our legacy endpoint athttps://api.retrodiffusion.ai/v1/inferences/legacy.
- First you need to generate an API Key directly from your RetroDiffusion account
- Make sure you have available credits in your account Take in mind that each model supports different styles.
- Prepare your request, in this example we will use Python and make simple request to generate one image with RD_FAST model and no styles:
import requests url = "https://api.retrodiffusion.ai/v1/inferences" method = "POST" headers = { "X-RD-Token": "YOUR_API_KEY", } payload = { "width": 256, "height": 256, "prompt": "A really cool corgi", "num_images": 1 } response = requests.request(method, url, headers=headers, json=payload) print(response.text)- The response should look like this:
{ "created_at": 1733425519, "credit_cost": 1, "base64_images": ["..."], "type": "txt2img", "remaining_credits": 999 }RD_FASTonly support one style at a time, and it's passed as a parameter namedprompt_style:
payload = { "width": 256, "height": 256, "prompt": "A really cool corgi wearing sunglasses and a party hat", "num_images": 1, "prompt_style": "rd_fast__simple" }Default size range is 64x64 <-> 512x512 unless otherwise specified.
- rd_fast__default
Simple clean pixel art, with Anime illustration influences - rd_fast__retro
A classic arcade game aesthetic inspired by early PC games - rd_fast__simple
Simple shading with minimalist shapes and designs - rd_fast__detailed
Pixel art with lots of shading and details - rd_fast__anime
Simple clean pixel art, with Anime illustration influences - rd_fast__game_asset
Distinct assets set on a simple background - rd_fast__portrait
Character portrait focused images with high detail - rd_fast__texture
Flat game textures like stones, bricks, or wood - rd_fast__ui
User interface boxes and buttons - rd_fast__item_sheet
Sheets of objects placed on a simple background - rd_fast__character_turnaround
Character sprites viewed from different angles - rd_fast__1_bit
Two color black and white only images - rd_fast__low_res
(16x16 <-> 128x128) General low resolution pixel art images - rd_fast__mc_item
(16x16 <-> 128x128) Minecraft-styled items with automatic transparency - rd_fast__mc_texture
(16x16 <-> 128x128) Minecraft-styled flat textures, like grass, stones, or wood - rd_fast__no_style
Pixel art with no style influence applied
RD_PLUSsupports several styles, and it's passed as a parameter namedprompt_style:RD_PLUSis more expensive thanRD_FAST, please confirm the cost in our web app selecting the model and style and settings you want to use.
- rd_plus__default
Clean pixel art style with bold colors and outlines - rd_plus__retro
Classic pixel art style inspired by PC98 games - rd_plus__watercolor
Pixel art mixed with a watercolor painting aesthetic - rd_plus__textured
Semi-realistic pixel art style with lots of shading and texture - rd_plus__cartoon
Simple shapes and shading, with bold outlines - rd_plus__ui_element
User interface boxes and buttons - rd_plus__item_sheet
Sheets of objects placed on a simple background - rd_plus__character_turnaround
Character sprites viewed from different angles - rd_plus__topdown_map
Video game map style pixel art with a 3/4 top down perspective - rd_plus__topdown_asset
3/4 top down perspective game assets on a simple background - rd_plus__isometric
45 degree isometric perspective, with consistent outlines - rd_plus__isometric_asset
45 degree isometric objects or assets, on a neutral background - rd_plus__classic
(32x32 <-> 192x192) Strongly outlined medium-resolution pixel art with a focus on simple shading and clear design - rd_plus__low_res
(16x16 <-> 128x128) High quality, low resolution pixel art assets and backgrounds - rd_plus__mc_item
(16x16 <-> 128x128) High quality Minecraft-styled items and game assets - rd_plus__mc_texture
(16x16 <-> 128x128) Detailed Minecraft-style flat block textures, with enhanced prompt following - rd_plus__topdown_item
(16x16 <-> 128x128) Top-down view of items and objects, with a simple background - rd_plus__skill_icon
(16x16 <-> 128x128) Icons for skills, abilities, or spells
We support the following animation styles:
- animation__four_angle_walking
(48x48 only) Consistent 4 direction, 4 frame long walking animations of humanoid characters - animation__walking_and_idle
(48x48 only) Consistent 4 direction walking and idle animations of humanoid characters - animation__small_sprites
(32x32 only) Consistent 4 direction walking, arm movement, looking, surprised, and laying down animations - animation__vfx
(24x24 <-> 96x96, 1:1 aspect ratio) Eye-catching animations for fire, explosions, lightning, or other simple effects
Some important notes:
animation__four_angle_walkingandanimation__walking_and_idlecurrently only support 48x48 resolution. (Bigger or smaller resolutions will be ignored and default to 48x48)animation__small_spritesonly supports 32x32 resolution.animation__vfxsupports sizes between 24x24 and 96x96, square aspect ratios only.- Animations only support generating one image at a time.
- Outputs are transparent GIF images encoded in base64. bypass_prompt_expansion Example payload:
This payload will generate a 48x48 transparent GIF, if you want the spritesheet, look below
{ "prompt": "corgi wearing a party hat", "width": 48, "height": 48, "num_images": 1, "seed": 123, "prompt_style": "animation__four_angle_walking" }Spritesheet output payload:
Just add the return_spritesheet property set to
true, this will output a transparent PNG with the spritesheet
{ "prompt": "corgi wearing a party hat", "width": 48, "height": 48, "num_images": 1, "seed": 123, "prompt_style": "animation__four_angle_walking", "return_spritesheet": true }The walking and idle animation format is similar to the four angle walking format, but has some changes. Below is an example:
The small sprites animation sheets are broken down like the example below:
You can use the parameter input_image in your payload to let the model know what image to use as a reference. The input_image should be a base64 encoded RGB image with no transparency. In your prompt you can include a brief description of your reference image.
Don't include the data:image/png;base64, in the base64 image.
{ "prompt": "robot", "width": 48, "height": 48, "num_images": 1, "seed": 1234, "prompt_style": "animation__four_angle_walking", "return_spritesheet": true, "input_image": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ..." }- Just send a base64 image in the
input_imageparameter and adjuststrengthto your likinng. Strength is a value between 0 and 1 and represents how much the image should be modified. - No need to include
 the base64 image. - Send your image as a base64 string, it should be a RGB image with no transparency.
with Image.open(input_image_path) as img: rgb_img = img.convert('RGB') buffer = BytesIO() rgb_img.save(buffer, format='PNG') base64_input_image = base64.b64encode(buffer.getvalue()).decode('utf-8') payload = { "prompt": "A really cool corgi wearing sunglasses and a party hat", "width": 256, "height": 256, "input_image": base64_input_image, "strength": 0.8 }- You can use the
input_paletteparameter to let the model know what palette to use as a reference. - Just send a base64 image in the
input_paletteparameter. - The
input_paletteshould be a base64 encoded image with no transparency. - Keep your palette image small, below 1mb is recommended 200k characters or less.
- No need to include
 the base64 image.
{ "prompt": "a raven with a glowing green eye", "width": 256, "height": 256, "num_images": 1, "seed": 1234, "input_palette": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ..." }- Optionally, you can also receive the original image before palette is applied by setting
return_pre_palettetotrue:
{ "prompt": "a raven with a glowing green eye", "width": 256, "height": 256, "num_images": 1, "seed": 1234, "input_palette": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ...", "return_pre_palette": true }When return_pre_palette is enabled, the response will include an additional string in the base64_images array, which is the original image before the palette is applied.
- Simply
remove_bgas a boolean
payload = { "prompt": "a raven with a glowing green eye", "width": 128, "height": 128, "remove_bg": True }- Optionally, you can also receive the original image before background removal by setting
return_non_bg_removedtotrue:
payload = { "prompt": "a raven with a glowing green eye", "width": 128, "height": 128, "remove_bg": True, "return_non_bg_removed": True }When return_non_bg_removed is enabled, the response will include an additional string in the base64_images array, which is the original image before background removal.
- Simply add
tile_xandtile_yboth as booleans
payload = { "prompt": "Stone bricks", "width": 128, "height": 128, "tile_x": true, "tile_y": true }- You can use the
bypass_prompt_expansionparameter to disable prompt expansion for your request.
payload = { "prompt": "a raven with a glowing green eye", "width": 128, "height": 128, "bypass_prompt_expansion": True }- You can use the
https://api.retrodiffusion.ai/v1/editendpoint to edit images. - The request should be a POST request with the following parameters:
{ "prompt": "add a hat", "inputImageBase64": "iVBORw0KGgoAAAANSUhEUgAAAUA...", }- We support sizes between 16x16 and 256x256
- You can send any image within the size limits to be edited
- Progressive editing is possible by sending the response you get from one task as the input for a new task
- The cost is 5 credits per image edit
- We have the following response format:
{ "outputImageBase64": "iVBORw0KGgoAAAANSUhEUgAAAUA...", "remaining_credits": 999 }-
You can generate tilesets using the following styles:
- rd_tile__tileset
- rd_tile__tileset_advanced
-
rd_tile__tilesetsupports an inspiration image via theinput_imageparameter -
rd_tile__tileset_advancedsupports inside and outside textures via theinput_imageandextra_input_imageparameters. Advanced tilesets require the inside texture description in thepromptparameter and the outside texture description in theextra_promptparameter. -
The
widthandheightparameters specify the size of each tile in the tileset. Values can range between 16 and 32.
Advanced tileset example payload:
{ "width": 32, "height": 32, "prompt": "grey stones with gravel and dirt", "extra_prompt": "lush green grass", "num_images": 1, "prompt_style": "rd_tile__tileset_advanced", "seed": 123, "input_image": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ...", "extra_input_image": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ..." }
- You can generate single tiles using the
rd_tile__single_tilestyle. - The
widthandheightparameters specify the size of the tile and can range between 16 and 64.
Example:
{ "width": 32, "height": 32, "prompt": "volcanic rock with cracks", "num_images": 1, "prompt_style": "rd_tile__single_tile" }- You can generate variations of a tile using the
rd_tile__tile_variationstyle. - The
input_imageparameter is required and should be a base64 encoded image of the tile you want to create variations from. - Use the
promptparameter to describe the changes you want to see in the variations.
Example:
{ "width": 32, "height": 32, "prompt": "add moss and cracks", "num_images": 1, "prompt_style": "rd_tile__tile_variation", "input_image": "iVBORw0KGgoAAAANSUhEUgAAAUA... ... ..." }rd_tile__tile_objectcan generate small assets for placing on tile sectionsrd_tile__scene_objectcan generate large assets for placing on tileset maps
- How much does it cost?
- Cost is calculated based on the model and resolution you choose. You can check the cost of each request in our web app
- How can I check my remaining credits?
- You can make a GET request to the
https://api.retrodiffusion.ai/v1/inferences/creditsendpoint, with the headerX-RD-Tokenset to your API key. The response will include the remaining credits in the following format:
- You can make a GET request to the
{ "credits": 999 }- Can I buy credits from the API?
- No, but to ensure you always have enough credits for your requests, you can set up auto refills in the Payment Methods section
- What happened to RD_CLASSIC?
- We just dropped support for RD_CLASSIC
- What happened to RD_FLUX?
- We just renamed RD_FLUX to RD_FAST, so you can use it as before.
- What happened to the model parameter
modelis no longer required, as the model is determined by theprompt_styleparameter.
- How to get images at native resolution?
- You can use the
upscale_output_factorparameter to get images at native resolution. Set it to 1 for native resolution, ornullfor regular size.
- You can use the



