75 lines
3.7 KiB
Python
75 lines
3.7 KiB
Python
|
from app.utils.system import clear_console
|
|||
|
from app.zadachi.zadacha1 import zadacha1
|
|||
|
from app.zadachi.zadacha2 import zadacha2
|
|||
|
|
|||
|
class pod_menu:
|
|||
|
|
|||
|
def __init__(self):
|
|||
|
pass # Конструктор пока пустой, при необходимости можно добавить параметры
|
|||
|
|
|||
|
def zadacha1_menu():
|
|||
|
"""Меню для задачи 1 с подкатегориями."""
|
|||
|
clear_console()
|
|||
|
while True:
|
|||
|
print('\nЗадача 1:')
|
|||
|
print('1. линейно')
|
|||
|
print('2. квадратично')
|
|||
|
print('0. Назад')
|
|||
|
|
|||
|
choice = input('Выберите подкатегорию: ')
|
|||
|
|
|||
|
clear_console()
|
|||
|
z1 = zadacha1() # создаем объект для задачи 1
|
|||
|
|
|||
|
if choice == '1':
|
|||
|
z1.plot_lin_data() # Выполнить первую подзадачу
|
|||
|
#return # Вернуться в основное меню после выполнения
|
|||
|
elif choice == '2':
|
|||
|
z1.plot_sqr_data() # Выполнить вторую подзадачу
|
|||
|
#return # Вернуться в основное меню после выполнения
|
|||
|
elif choice == '0':
|
|||
|
break # Вернуться в основное меню
|
|||
|
else:
|
|||
|
print('Неверный выбор, попробуйте снова.')
|
|||
|
|
|||
|
def zadacha2_menu():
|
|||
|
"""Меню для задачи 2 (расчет коэффициентов методом наименьших квадратов)."""
|
|||
|
clear_console()
|
|||
|
z1 = zadacha1() # Используем объект задачи 1 для генерации данных
|
|||
|
z2 = zadacha2() # Создаем объект для задачи 2
|
|||
|
|
|||
|
while True:
|
|||
|
print('\nЗадача 2:')
|
|||
|
print('1. Рассчитать коэффициенты b0 и b1 для линейной модели')
|
|||
|
print('2. Сделать прогноз по рассчитанным коэффициентам')
|
|||
|
print('0. Назад')
|
|||
|
|
|||
|
choice = input('Выберите подкатегорию: ')
|
|||
|
|
|||
|
clear_console()
|
|||
|
|
|||
|
if choice == '1':
|
|||
|
# Генерация линейных данных с помощью функции из задачи 1
|
|||
|
x_data, y_data = z1.create_lin_array()
|
|||
|
|
|||
|
# Рассчет коэффициентов b0 и b1 методом наименьших квадратов
|
|||
|
b0, b1 = z2.calculate_coefficients(x_data, y_data)
|
|||
|
|
|||
|
print(f'Рассчитанные коэффициенты:')
|
|||
|
print(f'b0 (свободный член) = {b0}')
|
|||
|
print(f'b1 (коэффициент наклона) = {b1}')
|
|||
|
elif choice == '2':
|
|||
|
# Пример предсказания на новых данных
|
|||
|
x_data, y_data = z1.create_lin_array() # Сначала генерируем данные
|
|||
|
b0, b1 = z2.calculate_coefficients(x_data, y_data) # Рассчитываем коэффициенты
|
|||
|
|
|||
|
# Выполняем прогноз
|
|||
|
predicted_y = z2.predict(x_data, b0, b1)
|
|||
|
|
|||
|
print(f'Предсказанные значения Y на основе рассчитанных коэффициентов:')
|
|||
|
print(predicted_y)
|
|||
|
elif choice == '0':
|
|||
|
break # Вернуться в основное меню
|
|||
|
else:
|
|||
|
print('Неверный выбор, попробуйте снова.')
|