Spaces:
Running
Running
| import os | |
| from functools import lru_cache | |
| import gradio as gr | |
| import numpy as np | |
| import pandas as pd | |
| from huggingface_hub import HfFileSystem, hf_hub_download | |
| from imgutils.generic import classify_predict_score | |
| from natsort import natsorted | |
| hf_fs = HfFileSystem() | |
| _REPOSITORY = 'deepghs/anime_aesthetic' | |
| _DEFAULT_MODEL = 'swinv2pv3_v0_448_ls0.2_x' | |
| _MODELS = natsorted([ | |
| os.path.dirname(os.path.relpath(file, _REPOSITORY)) | |
| for file in hf_fs.glob(f'{_REPOSITORY}/*/model.onnx') | |
| ]) | |
| LABELS = ["worst", "low", "normal", "good", "great", "best", "masterpiece"] | |
| def _get_mark_table(model): | |
| df = pd.read_csv(hf_hub_download( | |
| repo_id=_REPOSITORY, | |
| repo_type='model', | |
| filename=f'{model}/samples.csv', | |
| )) | |
| df = df.sort_values(['score']) | |
| df['cnt'] = list(range(len(df))) | |
| df['final_score'] = df['cnt'] / len(df) | |
| x = np.concatenate([[0.0], df['score'], [6.0]]) | |
| y = np.concatenate([[0.0], df['final_score'], [1.0]]) | |
| return x, y | |
| def _get_percentile(x, y, v): | |
| idx = np.searchsorted(x, np.clip(v, a_min=0.0, a_max=6.0)) | |
| if idx < x.shape[0] - 1: | |
| x0, y0 = x[idx], y[idx] | |
| x1, y1 = x[idx + 1], y[idx + 1] | |
| return np.clip((v - x0) / (x1 - x0) * (y1 - y0) + y0, a_min=0.0, a_max=1.0) | |
| else: | |
| return y[idx] | |
| def _fn_predict(image, model): | |
| scores = classify_predict_score( | |
| image=image, | |
| repo_id=_REPOSITORY, | |
| model_name=model, | |
| ) | |
| weighted_mean = sum(i * scores[label] for i, label in enumerate(LABELS)) | |
| x, y = _get_mark_table(model) | |
| percentile = _get_percentile(x, y, weighted_mean) | |
| return weighted_mean, percentile, scores | |
| if __name__ == '__main__': | |
| with gr.Blocks() as demo: | |
| with gr.Row(): | |
| with gr.Column(): | |
| gr_input_image = gr.Image(type='pil', label='Original Image') | |
| gr_model = gr.Dropdown(_MODELS, value=_DEFAULT_MODEL, label='Model') | |
| gr_submit = gr.Button(value='Submit', variant='primary') | |
| with gr.Column(): | |
| with gr.Row(): | |
| gr_score = gr.Text(label='Aesthetic Score (0~6)', value='') | |
| gr_percentile = gr.Text(label='Percentile (0.0-1.0)', value='') | |
| with gr.Row(): | |
| gr_output = gr.Label(label='Aesthetic Classes') | |
| gr_submit.click( | |
| _fn_predict, | |
| inputs=[gr_input_image, gr_model], | |
| outputs=[gr_score, gr_percentile, gr_output], | |
| ) | |
| demo.queue(os.cpu_count()).launch() | |