import threading import numpy as np from PIL import Image from keras.models import Model import opennsfw2 from roop.typing import Frame PREDICTOR = None THREAD_LOCK = threading.Lock() MAX_PROBABILITY = 0.85 def get_predictor() -> Model: global PREDICTOR with THREAD_LOCK: if PREDICTOR is None: PREDICTOR = opennsfw2.make_open_nsfw_model() return PREDICTOR def clear_predictor() -> None: global PREDICTOR with THREAD_LOCK: PREDICTOR = None def predict_frame(target_frame: Frame) -> bool: image = Image.fromarray(target_frame) processed_image = opennsfw2.preprocess_image(image, opennsfw2.Preprocessing.YAHOO) views = np.expand_dims(processed_image, axis=0) _, probability = get_predictor().predict(views)[0] return probability > MAX_PROBABILITY def predict_image(target_path: str) -> bool: return opennsfw2.predict_image(target_path) > MAX_PROBABILITY def predict_video(target_path: str) -> bool: _, probabilities = opennsfw2.predict_video_frames(video_path=target_path, frame_interval=100) return any(probability > MAX_PROBABILITY for probability in probabilities)