Experimental: things are work in progress and can break
Cog is an open source tool that aims to package machine learning models into a reproducible docker container that creates an API and can be used locally, hosted in the cloud or on Replicate.
Gradio is an open source tool that aims to create easy demos and web UIs for machine learning models, with few lines of code and pure python. Such UIs can be used locally, hosted in the cloud or on Hugging Face Spaces.
To use grog
, you should first install it's requirements
git clone https://github.com/multimodalart/grog
cd grog
pip install -r requirements.txt
Now you can run it with command line
python grog.py --replicate_model_id fofr/face-to-sticker --run_type local
There are 3 ways to run Grog:
- Full local, Cog and Gradio run in your machine π₯οΈ
- Local UI, Replicate API π
- Deploy to Hugging Face Spaces π€
Both Cog and Gradio run in your machine. No remote server is needed; your computer needs to be powerful enough to run the chosen model. This means having a decent GPU for most modern Cog/Replicate images. You need to have Docker installed, and run:
python grog.py --replicate_model_id cjwbw/ledits --run_type local
This will download the Docker image to your computer, initialize it, crete a dynamic Gradio UI for it and provided that docker works in your environment (tested only on Linux)
If you wish to customize the UI to your liking, change how the Docker Image is dealt with and instantiated (custom ports, etc); or even host the demo in the cloud, you may run
python grog.py --replicate_model_id cjwbw/ledits --run_type local --gradio_type static
This will create a new folder docker_{model_name}_{timestamp}
with your Gradio app.py
that you can edit/customize and a Dockerfile
to build an image that will provide your Gradio + Cog application. This Dockerfile
can not only be used locally, but also in any cloud service of your preference.
If you want to host a local UI that sends requests to Replicate's API, you can do:
python grog.py --replicate_model_id cjwbw/ledits --run_type replicate_api --replicate_token r8_YourReplicateTokenHere
This will instantiate a Gradio UI generated dynamically that will send requests to the Replicate API
If you wish to modify/customize your UI, you can do so by using the --gradio_type static
python grog.py --replicate_model_id cjwbw/ledits --run_type replicate_api --replicate_token r8_YourReplicateTokenHere --gradio_type static
This will create a Gradio app app_{name-of-model}-{timestamp}.py
that requests Replicate's API. You may modify it as you wish.
PS: If your inputs include uploaded media, run the Gradio demo from the public URL, as the Replicate API requires uploaded files to be accessible from existing public URL.
If you wish to host a demo with both the cog backend and the Gradio UI running on a Hugging Face Space you can do:
python grog.py --replicate_model_id cjwbw/ledits --run_type huggingface_spaces --huggingface_token hf_YourHuggingFaceToken --space_hardware t4-medium
This will create a Docker
Space on yout Hugging Face account that will mount the cog image and the Gradio demo, and function just like any other Hugging Face Space. You can modify the UI by editing the app.py
in the remote repository. (This is essentially the same as deploying the Docker folder from --run_type local --gradio_type static
to HF Spaces).
All cli params you can use with grog.py
:
replicate_model_id
(required): The Replicate model id you wish to create a Gradio UI for (e.g.:fofr/face-to-sticker
)run_type
(required): Ways to run the model:replicate_api
(local UI, remote API),local
(local UI, local cog),huggingface_spaces
(deploy cog and gradio to a Hugging Face Space)gradio_type
(required): Types of Gradio app.--gradio_type static
will allow users to edit/customize the UI,--gradio_type dynamic
will generate the application dynamically. Ignored when--run_type huggingface_spaces
(default: dynamic)replicate_token
: Your Replicate token (obtained here). Mandatory when--run_type replicate_api
huggingface_token
: Your Hugging Face token (obtained here). Mandatory when--run_type huggingface_spaces
docker_port
(optional): For--run_type local
and--gradio_type dynamic
, change the default docker port. If--gradio_type static
, you can change the ports in yourDockerfile
andapp.py
.space_hardware
(optional): For--run_type huggingface_spaces
, pick which hardware to use on the Spacecpu-basic
,cpu-upgrade
,t4-small
,t4-medium
,a10g-small
,a10g-large
(all hardwares beyondcpu-basic
are billed)
space_repo
(optional): For--run_type huggingface_spaces
, you can choose the name of your Space. If not set up, it will be set as the same name as the cog model.cog_url
: Not implemented - when implemented, will allow the users to insert as an input acog
Docker image directly
Right now, it is required for the Cog image to be hosted on Replicate for Grog to function, as generating a Gradio UI directly from a cog image is not yet implemented due to limitations on both Cog (regarding documentation on typing and number of outputs) and Gradio (no dynamic components). This is planned to be addressed in the future.
Of course, without the amazing tools Gradio and Cog this tool wouldn't exist. They help make machine learning more accessible to all and I thank all the maintainers.
Special thanks to RadamΓ©s Ajna who enabled the Dockerfile
to run on any environment.