|
import numpy as np |
|
import gradio as gr |
|
from pathlib import Path |
|
import os |
|
from PIL import Image |
|
|
|
def prime_factors(n): |
|
""" |
|
Compute the prime factorization of a positive integer. |
|
|
|
Args: |
|
n (int): The integer to factorize. Must be greater than 1. |
|
|
|
Returns: |
|
List[int]: A list of prime factors in ascending order. |
|
|
|
Raises: |
|
ValueError: If n is not greater than 1. |
|
""" |
|
n = int(n) |
|
if n <= 1: |
|
raise ValueError("Input must be an integer greater than 1.") |
|
|
|
factors = [] |
|
while n % 2 == 0: |
|
factors.append(2) |
|
n //= 2 |
|
|
|
divisor = 3 |
|
while divisor * divisor <= n: |
|
while n % divisor == 0: |
|
factors.append(divisor) |
|
n //= divisor |
|
divisor += 2 |
|
|
|
if n > 1: |
|
factors.append(n) |
|
|
|
return factors |
|
|
|
|
|
def generate_cheetah_image(): |
|
""" |
|
Generate a cheetah image. |
|
|
|
Returns: |
|
The generated cheetah image. |
|
""" |
|
return Path(os.path.dirname(__file__)) / "cheetah.jpg" |
|
|
|
|
|
def image_orientation(image: Image.Image) -> str: |
|
""" |
|
Returns whether image is portrait or landscape. |
|
|
|
Args: |
|
image (Image.Image): The image to check. |
|
|
|
Returns: |
|
str: "Portrait" if image is portrait, "Landscape" if image is landscape. |
|
""" |
|
return "Portrait" if image.height > image.width else "Landscape" |
|
|
|
|
|
def sepia(input_img): |
|
""" |
|
Apply a sepia filter to the input image. |
|
|
|
Args: |
|
input_img (str): The input image to apply the sepia filter to. |
|
|
|
Returns: |
|
The sepia filtered image. |
|
""" |
|
sepia_filter = np.array([ |
|
[0.393, 0.769, 0.189], |
|
[0.349, 0.686, 0.168], |
|
[0.272, 0.534, 0.131] |
|
]) |
|
sepia_img = input_img.dot(sepia_filter.T) |
|
sepia_img /= sepia_img.max() |
|
return sepia_img |
|
|
|
|
|
|
|
demo = gr.TabbedInterface( |
|
[ |
|
gr.Interface(prime_factors, gr.Textbox(), gr.Textbox(), api_name="prime_factors"), |
|
gr.Interface(generate_cheetah_image, None, gr.Image(), api_name="generate_cheetah_image"), |
|
gr.Interface(image_orientation, gr.Image(type="pil"), gr.Textbox(), api_name="image_orientation"), |
|
gr.Interface(sepia, gr.Image(), gr.Image(), api_name="sepia"), |
|
], |
|
[ |
|
"Prime Factors", |
|
"Cheetah Image", |
|
"Image Orientation Checker", |
|
"Sepia Filter", |
|
] |
|
) |
|
|
|
if __name__ == "__main__": |
|
demo.launch(mcp_server=True) |
|
|