| 
									
										
										
										
											2023-09-24 21:36:57 +08:00
										 |  |  | import numpy | 
					
						
							|  |  |  | import opennsfw2 | 
					
						
							|  |  |  | from PIL import Image | 
					
						
							| 
									
										
										
										
											2024-08-31 03:49:01 +08:00
										 |  |  | import cv2  # Add OpenCV import | 
					
						
							| 
									
										
										
										
											2024-08-31 04:02:23 +08:00
										 |  |  | import modules.globals  # Import globals to access the color correction toggle | 
					
						
							| 
									
										
										
										
											2023-09-24 21:36:57 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | from modules.typing import Frame | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MAX_PROBABILITY = 0.85 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-21 03:14:37 +08:00
										 |  |  | # Preload the model once for efficiency | 
					
						
							| 
									
										
										
										
											2024-08-21 03:02:00 +08:00
										 |  |  | model = None | 
					
						
							| 
									
										
										
										
											2023-09-24 21:36:57 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | def predict_frame(target_frame: Frame) -> bool: | 
					
						
							| 
									
										
										
										
											2024-08-31 04:02:23 +08:00
										 |  |  |     # Convert the frame to RGB before processing if color correction is enabled | 
					
						
							|  |  |  |     if modules.globals.color_correction: | 
					
						
							|  |  |  |         target_frame = cv2.cvtColor(target_frame, cv2.COLOR_BGR2RGB) | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2023-09-24 21:36:57 +08:00
										 |  |  |     image = Image.fromarray(target_frame) | 
					
						
							|  |  |  |     image = opennsfw2.preprocess_image(image, opennsfw2.Preprocessing.YAHOO) | 
					
						
							| 
									
										
										
										
											2024-08-21 03:02:00 +08:00
										 |  |  |     global model | 
					
						
							| 
									
										
										
										
											2024-08-31 04:02:23 +08:00
										 |  |  |     if model is None:  | 
					
						
							|  |  |  |         model = opennsfw2.make_open_nsfw_model() | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2023-09-24 21:36:57 +08:00
										 |  |  |     views = numpy.expand_dims(image, axis=0) | 
					
						
							|  |  |  |     _, probability = model.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) |