1sozidatel1's picture
Update app.py
8c562fd verified
import gradio as gr
import tensorflow as tf
import numpy as np
import pandas as pd
from datasets import load_dataset
from huggingface_hub import hf_hub_download
# Загрузка файла модели из Hugging Face Hub
model_path = hf_hub_download(repo_id="1sozidatel1/PricePredictorAI_Model", filename="price_model.h5")
# Загрузка модели
model = tf.keras.models.load_model(model_path)
# Карты местоположений и районов
location_mapping = {1: 'Астрахань', 2: 'Волгоград', 3: 'Краснодар', 4: 'Ростов-на-Дону', 5: 'Майкоп', 6: 'Элиста'}
district_mapping = {
1: [11, 12, 13, 14, 15],
2: [21, 22, 23, 24, 25, 26, 27, 28],
3: [31, 32, 33, 34],
4: [41, 42, 43, 44, 45, 46, 47, 48],
5: [51],
6: [61]
}
district_names = {
11: 'Кировский', 12: 'Ленинский', 13: 'Советский', 14: 'Трусовский', 15: 'Центральный',
21: 'Ворошиловский', 22: 'Дзержинский', 23: 'Кировский', 24: 'Красноармейский', 25: 'Краснооктябрьский', 26: 'Советский', 27: 'Тракторозаводский', 28: 'Центральный',
31: 'Западный', 32: 'Карасунский', 33: 'Прикубанский', 34: 'Центральный',
41: 'Ворошиловский', 42: 'Железнодорожный', 43: 'Кировский', 44: 'Ленинский', 45: 'Октябрьский', 46: 'Первомайский', 47: 'Пролетарский', 48: 'Советский',
51: 'Центральный',
61: 'Центральный'
}
author_type_mapping = {0: 'Риелтор', 1: 'Частный владелец'}
# Загрузка данных
dataset = load_dataset("1sozidatel1/sfd_housing_prices_november_2024")
data = pd.DataFrame(dataset['train'])
feature_cols = ['author_type_id', 'location_id', 'district_id', 'floor', 'rooms_count', 'total_meters']
X = data[feature_cols]
X_min = X.min()
X_max = X.max()
y = data['price'].values.reshape(-1, 1)
y_min = np.min(y)
y_max = np.max(y)
def predict_price(author_type, location, district, floor, rooms_count, total_meters):
author_type_id = list(author_type_mapping.keys())[list(author_type_mapping.values()).index(author_type)]
location_id = list(location_mapping.keys())[list(location_mapping.values()).index(location)]
district_id = list(district_names.keys())[list(district_names.values()).index(district)]
input_data = np.array([[author_type_id, location_id, district_id, floor, rooms_count, total_meters]])
input_data_normalized = (input_data - X_min.values) / (X_max.values - X_min.values)
prediction = model.predict(input_data_normalized)
prediction_unscaled = prediction * (y_max - y_min) + y_min
return np.round(prediction_unscaled.flatten()[0], 1)
def update_districts(location):
location_id = list(location_mapping.keys())[list(location_mapping.values()).index(location)]
districts = [district_names[district_id] for district_id in district_mapping[location_id]]
return gr.update(choices=districts)
# Создание интерфейса Gradio
with gr.Blocks() as demo:
gr.Markdown("# Предсказание цен на квартиры в Южном Федеральном Округе")
gr.Markdown("Этот интерфейс позволяет предсказать цену на недвижимость на основе различных параметров, таких как тип продавца, город, район, этаж, количество комнат и площадь.")
gr.Markdown("Введите необходимые данные и нажмите кнопку 'Предсказать цену', чтобы получить предсказанную цену.")
gr.Markdown("❗️Все поля обязательны для заполнения❗️")
with gr.Row():
with gr.Column():
author_type = gr.Dropdown(choices=list(author_type_mapping.values()), label="Тип продавца")
location = gr.Dropdown(choices=list(location_mapping.values()), label="Город")
district = gr.Dropdown(label="Район")
floor = gr.Number(label="Этаж", minimum=1, maximum=50)
rooms_count = gr.Dropdown(choices=[1, 2, 3, 4, 5], label="Количество комнат")
total_meters = gr.Number(label="Площадь, кв.м", minimum=18, maximum=500)
predict_btn = gr.Button("Предсказать цену")
with gr.Column():
price = gr.Number(label="Предсказанная цена, (тыс. руб.)")
location.change(update_districts, inputs=location, outputs=district)
predict_btn.click(predict_price, inputs=[author_type, location, district, floor, rooms_count, total_meters], outputs=price)
if __name__ == "__main__":
demo.launch()