Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -21,6 +21,7 @@ def load_model():
|
|
21 |
model, scaler, data = load_model()
|
22 |
feature_list = data['features']
|
23 |
categorical_features = data['categorical_features']
|
|
|
24 |
categorical_options = data['categorical_options']
|
25 |
group_names = data['group_names']
|
26 |
|
@@ -33,7 +34,7 @@ def get_user_input():
|
|
33 |
# Числовые признаки
|
34 |
st.subheader('Числовые параметры')
|
35 |
for feature in feature_list:
|
36 |
-
if feature
|
37 |
input_data[feature] = st.number_input(f'{feature}', value=0.0)
|
38 |
|
39 |
# Категориальные признаки
|
@@ -55,18 +56,19 @@ if st.button('Выполнить классификацию'):
|
|
55 |
# One-hot encoding для категориальных признаков
|
56 |
input_df_encoded = pd.get_dummies(input_df, columns=categorical_features)
|
57 |
|
|
|
|
|
|
|
|
|
58 |
# Убедитесь, что все необходимые столбцы присутствуют
|
59 |
for col in feature_list:
|
60 |
if col not in input_df_encoded.columns:
|
61 |
input_df_encoded[col] = 0
|
62 |
|
63 |
-
# Масштабирование числовых признаков
|
64 |
-
numeric_cols = [col for col in feature_list if col not in categorical_features]
|
65 |
-
input_df_encoded[numeric_cols] = scaler.transform(input_df_encoded[numeric_cols])
|
66 |
-
|
67 |
# Получение предсказания
|
68 |
-
|
69 |
-
|
|
|
70 |
|
71 |
# Отображение результата
|
72 |
st.success(f'Предсказанная группа: {group_names[str(prediction[0])]}')
|
@@ -74,4 +76,8 @@ if st.button('Выполнить классификацию'):
|
|
74 |
# Вывод вероятностей
|
75 |
st.write('Вероятности для каждой группы:')
|
76 |
for i, prob in enumerate(probabilities):
|
77 |
-
st.write(f'{group_names[str(i)]}: {prob:.2f}')
|
|
|
|
|
|
|
|
|
|
21 |
model, scaler, data = load_model()
|
22 |
feature_list = data['features']
|
23 |
categorical_features = data['categorical_features']
|
24 |
+
numeric_features = data['numeric_features']
|
25 |
categorical_options = data['categorical_options']
|
26 |
group_names = data['group_names']
|
27 |
|
|
|
34 |
# Числовые признаки
|
35 |
st.subheader('Числовые параметры')
|
36 |
for feature in feature_list:
|
37 |
+
if feature in numeric_features:
|
38 |
input_data[feature] = st.number_input(f'{feature}', value=0.0)
|
39 |
|
40 |
# Категориальные признаки
|
|
|
56 |
# One-hot encoding для категориальных признаков
|
57 |
input_df_encoded = pd.get_dummies(input_df, columns=categorical_features)
|
58 |
|
59 |
+
# Масштабирование числовых признаков
|
60 |
+
if numeric_features:
|
61 |
+
input_df_encoded[numeric_features] = scaler.transform(input_df_encoded[numeric_features])
|
62 |
+
|
63 |
# Убедитесь, что все необходимые столбцы присутствуют
|
64 |
for col in feature_list:
|
65 |
if col not in input_df_encoded.columns:
|
66 |
input_df_encoded[col] = 0
|
67 |
|
|
|
|
|
|
|
|
|
68 |
# Получение предсказания
|
69 |
+
X_pred = input_df_encoded[feature_list]
|
70 |
+
prediction = model.predict(X_pred)
|
71 |
+
probabilities = model.predict_proba(X_pred)[0]
|
72 |
|
73 |
# Отображение результата
|
74 |
st.success(f'Предсказанная группа: {group_names[str(prediction[0])]}')
|
|
|
76 |
# Вывод вероятностей
|
77 |
st.write('Вероятности для каждой группы:')
|
78 |
for i, prob in enumerate(probabilities):
|
79 |
+
st.write(f'{group_names[str(i)]}: {prob:.2f}')
|
80 |
+
|
81 |
+
# Добавим вывод введенных данных для проверки
|
82 |
+
st.write("\nВведенные данные:")
|
83 |
+
st.write(input_df)
|