Upload 3 files
Browse files- app.py +56 -0
- lstm_model.h5 +3 -0
- requirements.txt +10 -0
app.py
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import streamlit as st
|
| 2 |
+
import pandas as pd
|
| 3 |
+
import numpy as np
|
| 4 |
+
from sklearn.preprocessing import StandardScaler, OneHotEncoder
|
| 5 |
+
from keras.models import load_model
|
| 6 |
+
|
| 7 |
+
# Modeli yükle
|
| 8 |
+
model = load_model('lstm_model.h5') # Model dosyasının adı
|
| 9 |
+
|
| 10 |
+
# Streamlit uygulaması
|
| 11 |
+
st.title('Acea Water Tahmin Uygulaması')
|
| 12 |
+
|
| 13 |
+
# Kullanıcıdan girdi al
|
| 14 |
+
st.sidebar.header('Girdi Bilgileri')
|
| 15 |
+
|
| 16 |
+
# Kullanıcıdan alınacak girdileri tanımla
|
| 17 |
+
city = st.sidebar.selectbox('Şehir Seçin:', ['İstanbul', 'Ankara', 'İzmir']) # Şehir seçenekleri
|
| 18 |
+
month = st.sidebar.number_input('Ay', min_value=1, max_value=12)
|
| 19 |
+
day = st.sidebar.number_input('Gün', min_value=1, max_value=31)
|
| 20 |
+
year = st.sidebar.number_input('Yıl', min_value=2000, max_value=2023)
|
| 21 |
+
|
| 22 |
+
# Diğer özellikler
|
| 23 |
+
P1 = st.sidebar.number_input('P1 Değeri', min_value=0)
|
| 24 |
+
P2 = st.sidebar.number_input('P2 Değeri', min_value=0)
|
| 25 |
+
# ... Diğer özellikleri ekleyin (toplam 30 özellik olmalı)
|
| 26 |
+
|
| 27 |
+
# Kullanıcı girdilerini DataFrame'e dönüştür
|
| 28 |
+
input_data = pd.DataFrame({
|
| 29 |
+
'City': [city],
|
| 30 |
+
'Month': [month],
|
| 31 |
+
'Day': [day],
|
| 32 |
+
'Year': [year],
|
| 33 |
+
'P1': [P1],
|
| 34 |
+
'P2': [P2],
|
| 35 |
+
# ... Diğer özellikleri ekleyin
|
| 36 |
+
})
|
| 37 |
+
|
| 38 |
+
# One-hot encoding işlemi
|
| 39 |
+
encoder = OneHotEncoder(sparse_output=False)
|
| 40 |
+
city_encoded = encoder.fit_transform(input_data[['City']])
|
| 41 |
+
city_encoded_df = pd.DataFrame(city_encoded, columns=encoder.get_feature_names_out(['City']))
|
| 42 |
+
|
| 43 |
+
# Girdileri birleştir
|
| 44 |
+
input_data = pd.concat([input_data.drop('City', axis=1), city_encoded_df], axis=1)
|
| 45 |
+
|
| 46 |
+
# Gerekli ön işleme adımlarını uygulayın
|
| 47 |
+
scaler = StandardScaler()
|
| 48 |
+
input_data_scaled = scaler.fit_transform(input_data)
|
| 49 |
+
|
| 50 |
+
# Giriş verilerini uygun şekle dönüştür
|
| 51 |
+
input_data_reshaped = input_data_scaled.reshape((1, 1, input_data_scaled.shape[1]))
|
| 52 |
+
|
| 53 |
+
# Tahmin yapma
|
| 54 |
+
if st.button("Tahmin Et"):
|
| 55 |
+
prediction = model.predict(input_data_reshaped)
|
| 56 |
+
st.success(f'Tahmin Edilen Su Tüketimi: {prediction[0][0]:.2f} birim')
|
lstm_model.h5
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:badf81c5204c3dc4934aa88af8a9343569ef5a878cadfeb8bfdb9869556b0901
|
| 3 |
+
size 1631856
|
requirements.txt
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
streamlit
|
| 2 |
+
tensorflow
|
| 3 |
+
opencv-python
|
| 4 |
+
scikit-learn
|
| 5 |
+
torch
|
| 6 |
+
torchvision
|
| 7 |
+
matplotlib
|
| 8 |
+
transformers
|
| 9 |
+
sentencepiece
|
| 10 |
+
plotly
|