Vasanth M
commited on
Commit
·
87eaaae
1
Parent(s):
e51595f
Dict
Browse files
app.py
CHANGED
@@ -1,20 +1,20 @@
|
|
1 |
import gradio as gr
|
2 |
|
3 |
-
def convert_temperature(temp: str, unit: str) ->
|
4 |
"""
|
5 |
Converts a temperature value from one unit to Celsius, Fahrenheit, and Kelvin.
|
6 |
|
7 |
-
This function takes a temperature value as a string and its unit, performs the conversion, and returns the equivalent temperatures in all three units as formatted strings. Designed for use in a Gradio interface and as an MCP tool.
|
8 |
|
9 |
Args:
|
10 |
temp (str): The temperature value as a string (e.g., '25', '-10.5'). Must be convertible to a float.
|
11 |
unit (str): The unit of the input temperature. Must be one of 'Celsius', 'Fahrenheit', or 'Kelvin'.
|
12 |
|
13 |
Returns:
|
14 |
-
|
15 |
-
- Temperature in Celsius (e.g., '25.00 °C') or 'Invalid' if input is invalid.
|
16 |
-
- Temperature in Fahrenheit (e.g., '77.00 °F') or 'Invalid' if input is invalid.
|
17 |
-
- Temperature in Kelvin (e.g., '298.15 K') or 'Invalid' if input is invalid.
|
18 |
|
19 |
Raises:
|
20 |
ValueError: If the temp input cannot be converted to a float.
|
@@ -34,9 +34,13 @@ def convert_temperature(temp: str, unit: str) -> tuple[str, str, str]:
|
|
34 |
fahrenheit = (celsius * 9/5) + 32
|
35 |
kelvin = temp
|
36 |
|
37 |
-
return
|
|
|
|
|
|
|
|
|
38 |
except ValueError:
|
39 |
-
return
|
40 |
|
41 |
# Define the Gradio interface
|
42 |
with gr.Blocks() as app:
|
@@ -59,7 +63,8 @@ with gr.Blocks() as app:
|
|
59 |
fn=convert_temperature,
|
60 |
inputs=[temp_input, unit_dropdown],
|
61 |
outputs=[celsius_output, fahrenheit_output, kelvin_output],
|
62 |
-
api_name="/convert_temperature"
|
|
|
63 |
)
|
64 |
|
65 |
# Launch the app with MCP server enabled
|
|
|
1 |
import gradio as gr
|
2 |
|
3 |
+
def convert_temperature(temp: str, unit: str) -> dict[str, str]:
|
4 |
"""
|
5 |
Converts a temperature value from one unit to Celsius, Fahrenheit, and Kelvin.
|
6 |
|
7 |
+
This function takes a temperature value as a string and its unit, performs the conversion, and returns the equivalent temperatures in all three units as formatted strings in a dictionary. Designed for use in a Gradio interface and as an MCP tool.
|
8 |
|
9 |
Args:
|
10 |
temp (str): The temperature value as a string (e.g., '25', '-10.5'). Must be convertible to a float.
|
11 |
unit (str): The unit of the input temperature. Must be one of 'Celsius', 'Fahrenheit', or 'Kelvin'.
|
12 |
|
13 |
Returns:
|
14 |
+
dict[str, str]: A dictionary with three keys:
|
15 |
+
- 'celsius': Temperature in Celsius (e.g., '25.00 °C') or 'Invalid' if input is invalid.
|
16 |
+
- 'fahrenheit': Temperature in Fahrenheit (e.g., '77.00 °F') or 'Invalid' if input is invalid.
|
17 |
+
- 'kelvin': Temperature in Kelvin (e.g., '298.15 K') or 'Invalid' if input is invalid.
|
18 |
|
19 |
Raises:
|
20 |
ValueError: If the temp input cannot be converted to a float.
|
|
|
34 |
fahrenheit = (celsius * 9/5) + 32
|
35 |
kelvin = temp
|
36 |
|
37 |
+
return {
|
38 |
+
"celsius": f"{celsius:.2f} °C",
|
39 |
+
"fahrenheit": f"{fahrenheit:.2f} °F",
|
40 |
+
"kelvin": f"{kelvin:.2f} K"
|
41 |
+
}
|
42 |
except ValueError:
|
43 |
+
return {"celsius": "Invalid", "fahrenheit": "Invalid", "kelvin": "Invalid"}
|
44 |
|
45 |
# Define the Gradio interface
|
46 |
with gr.Blocks() as app:
|
|
|
63 |
fn=convert_temperature,
|
64 |
inputs=[temp_input, unit_dropdown],
|
65 |
outputs=[celsius_output, fahrenheit_output, kelvin_output],
|
66 |
+
api_name="/convert_temperature",
|
67 |
+
_js="result => [result.celsius, result.fahrenheit, result.kelvin]"
|
68 |
)
|
69 |
|
70 |
# Launch the app with MCP server enabled
|