mirror of
https://github.com/Deepshift/DeepCreamPy.git
synced 2024-11-29 05:10:43 +00:00
162 lines
7.8 KiB
Markdown
162 lines
7.8 KiB
Markdown
# DeepCreamPy
|
|
*Decensoring Hentai with Deep Neural Networks. Formerly named DeepMindBreak.*
|
|
|
|
A deep learning-based tool to automatically replace censored artwork in hentai with plausible reconstructions.
|
|
|
|
The user specifies the censored regions in each image by coloring those regions green in a separate image editing program like GIMP or Photoshop. A neural network handles the hard part of filling in the censored regions.
|
|
|
|
DeepCreamPy has a pre-built binary for Windows 64-bit. DeepCreamPy works on Windows, Mac, and Linux.
|
|
|
|
![Censored, decensored](/readme_images/mermaid_collage.png)
|
|
|
|
## What's New?
|
|
- Decensoring images of ANY size
|
|
- Decensoring censors of ANY shape (e.g. bunch of black lines, pink hearts, etc.)
|
|
- Higher quality decensors
|
|
- Support for mosaic decensors (still a WIP and not very usable)
|
|
- User interface (not usable)
|
|
|
|
## Installation
|
|
|
|
### Download Prebuilt Binaries
|
|
You can download the latest release [here](https://github.com/deeppomf/DeepCreamPy/releases/latest) or find all previous releases [here](https://github.com/deeppomf/DeepCreamPy/releases).
|
|
Binary only available for Windows 64-bit.
|
|
|
|
### Run Code Yourself
|
|
If you want to run the code yourself, you can clone this repo and download the model from https://drive.google.com/open?id=1byrmn6wp0r27lSXcT9MC4j-RQ2R04P1Z. Unzip the file into the /models/ folder.
|
|
|
|
#### Dependencies (for running the code yourself)
|
|
- Python 3.6.7
|
|
- TensorFlow 1.10
|
|
- Keras 2.2.4
|
|
- Pillow
|
|
- h5py
|
|
|
|
No GPU required! Tested on Ubuntu 16.04 and Windows. Tensorflow on Windows is compatible with Python 3 and not Python 2. Tensorflow is not compatible with Python 3.7.
|
|
|
|
Tensorflow, Keras, Pillow, and h5py can all be installed by running in the command line
|
|
|
|
```
|
|
$ pip install -r requirements.txt
|
|
```
|
|
|
|
## Limitations
|
|
The decensorship is intended to work on color hentai images that have minor to moderate censorship of the penis or vagina. If a vagina or penis is completely censored out, decensoring will be ineffective.
|
|
|
|
It does NOT work with:
|
|
- Black and white/Monochrome image
|
|
- Hentai containing screentones (e.g. printed hentai)
|
|
- Real life porn
|
|
- Censorship of nipples
|
|
- Censorship of anus
|
|
- Animated gifs/videos
|
|
|
|
## Usage
|
|
### I. Decensoring bar censors
|
|
|
|
For each image you want to decensor, using image editing software like Photoshop or GIMP to color the areas you want to decensor the green color (0,255,0), which is a very bright green color.
|
|
|
|
*I strongly recommend you use the pencil tool and NOT the brush tool.*
|
|
|
|
*If you aren't using the pencil tool, BE SURE TO TURN OFF ANTI-ALIASING on the tool you are using.*
|
|
|
|
I personally use the wand selection tool with anti-aliasing turned off to select the censored regions. I then expand the selections slightly, pick the color (0,255,0), and use the paint bucket tool on the selected regions.
|
|
|
|
To expand selections in Photoshop, do Selection > Modify > Expand or Contract.
|
|
To expand selections in GIMP, do Select > Grow.
|
|
|
|
Save these images in the PNG format to the "decensor_input" folder.
|
|
|
|
#### A. Using the binary
|
|
|
|
Decensor the images by double-clicking on the decensor file.
|
|
|
|
#### B. Running from scratch
|
|
|
|
Decensor the images by running
|
|
|
|
```
|
|
$ python decensor.py
|
|
```
|
|
|
|
Decensored images will be saved to the "decensor_output" folder. Decensoring takes a few minutes per image.
|
|
|
|
### II. Decensoring mosaic censors
|
|
|
|
As with decensoring bar censors, perform the same steps of coloring the censored regions green and putting the colored image into the "decensor_input" folder.
|
|
|
|
In addition, move the original, uncolored images into the "decensor_input_original" folder. Ensure each original image has the same names as their corresponding colored version in the "decensor_input" folder.
|
|
|
|
For example, if the original image is called "mermaid.jpg," then you want to put this image in the "decensor_input_original" folder and, after you colored the censored regions, name the colored image "mermaid.png" and move it to the "decensor_input" folder.
|
|
|
|
#### A. Using the binary
|
|
|
|
Decensor the images by double-clicking on the decensor_mosaic file.
|
|
|
|
#### B. Running from scratch
|
|
|
|
Decensor the images by running
|
|
|
|
```
|
|
$ python decensor.py --is_mosaic=True
|
|
```
|
|
|
|
Decensored images will be saved to the "decensor_output" folder. Decensoring takes a few minutes per image.
|
|
|
|
### III. Decensoring with the user interface
|
|
|
|
To be implemented.
|
|
|
|
## Troubleshooting
|
|
|
|
### Installation
|
|
```
|
|
ModuleNotFoundError: No module named '_pywrap_tensorflow_internal'
|
|
```
|
|
See https://github.com/deeppomf/DeepCreamPy/issues/26#issuecomment-434043166
|
|
|
|
### Decensoring
|
|
If your decensor output looks like this, then the censored regions were not colored correctly.
|
|
|
|
![Bad decensor](/readme_images/mermaid_face_censored_bad_decensor.png)
|
|
|
|
*Make sure you have antialiasing off.*
|
|
|
|
Here are some examples of bad and good colorings:
|
|
|
|
|Image|Zoom|Comment|
|
|
|--- | --- | ---|
|
|
|![Incomplete coloring](/readme_images/mermaid_face_censored_bad_incomplete.png)|![Incomplete coloring](/readme_images/mermaid_face_censored_bad_incomplete_zoom.png)|Some censored pixels was left uncolored. Expand your selections to fully cover all censored regions.|
|
|
|![Bad edges](/readme_images/mermaid_face_censored_bad_edge.png)|![Bad edges](/readme_images/mermaid_face_censored_bad_edge_zoom.png)|Some pixels around the edges of the green regions are not pure green. This will cause the green to bleed into the decensors. Make sure anti-aliasing is off and to use a pencil tool and not a brush tool if possible.|
|
|
|![Perfect coloring!](/readme_images/mermaid_face_censored_good.png)|![Perfect coloring! The censored region is uniformly colored correctly.](/readme_images/mermaid_face_censored_good_zoom.png)|Perfect coloring!|
|
|
|
|
## FAQ
|
|
- Q: Why aren't black and white images supported? Aren't black and white images easier to decensor than color images?
|
|
- A: Black and white images are harder to decensor than color images because neural networks struggle to replicate screentone patterns.
|
|
|
|
## To do
|
|
- Finish the user interface (sometime in November)
|
|
- Update model with better quality data (sometime in November)
|
|
- Add support for black and white images
|
|
- Add error log
|
|
|
|
Contributions are welcome! Special thanks to StartleStars for contributing code for mosaic decensorship and SoftArmpit for greatly simplifying decensoring!
|
|
|
|
## License
|
|
This project is licensed under GNU Affero General Public License v3.0.
|
|
|
|
See [LICENSE.txt](LICENSE.txt) for more information about the license.
|
|
|
|
## Acknowledgements
|
|
Example mermaid image by Shurajo & AVALANCHE Game Studio under [CC BY 3.0 License](https://creativecommons.org/licenses/by/3.0/). The example image is modified from the original, which can be found [here](https://opengameart.org/content/mermaid).
|
|
|
|
Neural network code is modified from MathiasGruber's project [Partial Convolutions for Image Inpainting using Keras](https://github.com/MathiasGruber/PConv-Keras), which is an unofficial implementation of the paper [Image Inpainting for Irregular Holes Using Partial Convolutions](https://arxiv.org/abs/1804.07723). [Partial Convolutions for Image Inpainting using Keras](https://github.com/MathiasGruber/PConv-Keras) is licensed under the MIT license.
|
|
|
|
User interface code is modified from Packt's project [Tkinter GUI Application Development Blueprints - Second Edition](https://github.com/PacktPublishing/Tkinter-GUI-Application-Development-Blueprints-Second-Edition). [Tkinter GUI Application Development Blueprints - Second Edition](https://github.com/PacktPublishing/Tkinter-GUI-Application-Development-Blueprints-Second-Edition) is licensed under the MIT license.
|
|
|
|
Data is modified from gwern's project [Danbooru2017: A Large-Scale Crowdsourced and Tagged Anime Illustration Dataset](https://www.gwern.net/Danbooru2017).
|
|
|
|
See [ACKNOWLEDGEMENTS.md](ACKNOWLEDGEMENTS.md) for full license text of these projects.
|
|
|
|
## Donations
|
|
If you like the work I do, you can donate to me via Paypal: [![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=SAM6C6DQRDBAE) |