Skip to content

A repository for a Minecraft skin generator based off of Stable Diffusion v1.5. It's trained off of Stable Diffusion and uses data scraped with https://github.com/RandomGamingDev/mcskins-net-scraper

License

Notifications You must be signed in to change notification settings

RandomGamingDev/MCSkinsGen

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MCSkinsGen

A repository for prototype 2 of a Minecraft skin generator based off of Stable Diffusion v1.5. It's trained off of Stable Diffusion and uses data scraped with https://github.com/RandomGamingDev/mcskins-net-scraper.
This is the current most permissive model (in terms of license) and is one of the most powerful (I can't be sure whether or not it's the most powerful since I don't have access to some of the competitors or simply can't run them)


Our Discord :D     Discord Stats

https://discord.gg/APdcNPMvR3

Youtube (basically a vid explaining the AI and how to use it) (preferable to the text tutorial if you don't have experience with this sorta stuff)

https://www.youtube.com/watch?v=Zhug5-smQ8g


Here are the Colab Notebooks for the models (Skin Generator is for generating the skins):

Just follow the instructions in the Google Colab for Skin Generator and this model will create skins that can be used in game!

(btw I recommend generating more than 2 images once you know what you want)

📊 Skin Generator: Open in Colab (Click on the icon left of me!)
Model Trainer: Open in Colab


Instructions for generating a skin: (Note: You should choose the T4 GPU runtime instance especially on the free tier)

  1. Click on the Skin Generator Google Colab link to open the notebook
  2. Sign up for a Hugging Face account and then create a read key here: https://huggingface.co/settings/tokens (making the key type read is all that's needed, but write works too)
  3. Press play for the first code block (I will refer to pressing play as "running" the code block from now on) (it won't appear until you hover over it so that it appears between the 2 square brackets), which will install some dependencies and then present a login screen in which you'll enter the key and then enter y for whether or not to add it as a git credential To enter text simply press the empty space next to the : which will reveal an input bar that you can type in.
    The login screen you find at the end of the fancy install bars:
    The login screen
  4. Run the second code block
  5. Run the final code block with the prompt that you want

Step 5 can be repeated for each skin you try to generate without repeating the previous steps
However, you'll need to repeat the steps when Google Colab restarts


Here are some example skins that I liked (Note: The model will try to follow the prompt, but currently does so very very loosely if at all in a lot of cases.):

This skin was generated with the name "Alchemist", the "movies" category, and with the "Alchemist with golden hair" description.
alt text
This skin was generated with the name "Christmas Golem", the "fantasy" category, and with the "Golem with christmas pajamas" description.
alt text
This skin was generated with the name "Cute Robot", the "fantasy" category, and with the "Cute robot with cyclopes eye" description.
alt text

Note: Only the Skin Generator itself can be used on the Google Colab free tier


Why Stable Diffusion?

While a smaller GAN UNet may be more efficient, if we even got to a fraction of utilizing the abilities of Stable Diffusion, that means that we don't have to do nearly as much work with characters that are less well known if we can get the model to learn how to make pixel art of the characters its seen before. However, I might try using a smaller custom model in the future for efficiency.

How does this work?

First, we scrape the data with https://github.com/RandomGamingDev/mcskins-net-scraper before using to-imagefolder.py and to-1dir-dataset.py to convert it into a form that can be used and with a 512x512 resolution for each skin before placing it into Loras/mcskins/dataset and train it with the default LoRA model. (This requires Google Colab Compute units since Google doesn't let you do it with the free tier) (If you want to train based off of another LoRA or based off of the LoRAs generated from what you previously trained just place it somewhere downloadable (perhaps in a github pull request) and then place the url to it in the optional_custom_training_model_url) With the finished models, we can then generate skins that we then proceed to resize back to 64x64 with Pillow before exporting. (This can be done on the free tier)

Why is the model not was powerful as it could be?

I've trained up to epoch 18, but I haven't had enough computing power to train past that (Google Colab does a funni and kicks me off and I don't have a GPU powerful enough to train the AI) + the dataset used, although very high quality, is very small