Spaces:
				
			
			
	
			
			
		Sleeping
		
	
	
	
			
			
	
	
	
	
		
		
		Sleeping
		
	File size: 2,542 Bytes
			
			| 0ceff0a b60cbe3 fd4d84b 0ceff0a b60cbe3 991fbeb 7d87e8c 991fbeb 0ceff0a 75f06df 991fbeb b60cbe3 991fbeb 93c87bc 991fbeb 074b0e2 991fbeb 7c583bd 7d87e8c 7c583bd 75f06df b60cbe3 d89bbe7 b60cbe3 991fbeb b60cbe3 bd01473 b60cbe3 bd01473 3023b74 bd01473 b60cbe3 93ac46b b60cbe3 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | import gradio as gr
from PIL import Image
from vit_model_test import CustomModel  # Ensure this is the correct import for your model
from vit_Training import Custom_VIT_Model
# Initialize the model
model = CustomModel()
model_training = Custom_VIT_Model()
# Variable to store the last prediction result
last_prediction = None
def predict(image: Image.Image):
    global last_prediction
    label, confidence = model.predict(image)
    result = "AI image" if label == 1 else "Real image"
    last_prediction = (image, label)  # Store the image and label for feedback
    return result, f"Confidence: {confidence:.2f}%"
def report_feedback():
    global last_prediction
    if last_prediction is not None:
        image, predicted_label = last_prediction
        correct_label = 1 if predicted_label == 0 else 0  # Invert the label
        print(f"Reporting feedback: predicted_label={predicted_label}, correct_label={correct_label}")  # Debugging line
        try:
            model_training.add_data(image, correct_label)  # Pass the incorrect prediction to the model
            print("Feedback recorded successfully.")  # Debugging line
            return "Feedback recorded. Thank you!"
        except Exception as e:
            print(f"Error recording feedback: {e}")  # Debugging line
            return f"Error recording feedback: {e}"
    else:
        print("No prediction available to report.")  # Debugging line
        return "No prediction available to report."
# Define the Gradio interface
with gr.Blocks(theme=gr.themes.Soft()) as demo:
    gr.Markdown("### Vision Transformer Model")
    gr.Markdown("Upload an image to classify it using the Vision Transformer model.")
    
    image_input = gr.Image(type="pil", label="Upload Image")
    prediction_output = gr.Textbox(label="Prediction", interactive=False)
    confidence_output = gr.Textbox(label="Confidence", interactive=False)
    feedback_output = gr.Textbox(label="Feedback Status", interactive=False)
    submit_btn = gr.Button("Submit")
    feedback_btn = gr.Button("The model was wrong")
    clear_btn = gr.Button("Clear")
    submit_btn.click(predict, inputs=image_input, outputs=[prediction_output, confidence_output])
    feedback_btn.click(report_feedback, outputs=feedback_output)
    # Clear button logic
    def clear_all():
        return None, "", ""
    clear_btn.click(clear_all, outputs=[image_input, prediction_output, confidence_output,feedback_output])
# Launch the Gradio interface
if __name__ == "__main__":
    demo.launch(share=True) | 
