diff --git a/labworks/LW1/IS_lab_4.png b/labworks/LW1/IS_lab_4.png new file mode 100644 index 0000000..9ce5f26 Binary files /dev/null and b/labworks/LW1/IS_lab_4.png differ diff --git a/labworks/LW1/IS_lab_4_90.png b/labworks/LW1/IS_lab_4_90.png new file mode 100644 index 0000000..c520ac8 Binary files /dev/null and b/labworks/LW1/IS_lab_4_90.png differ diff --git a/labworks/LW1/IS_lab_7.png b/labworks/LW1/IS_lab_7.png new file mode 100644 index 0000000..6479bad Binary files /dev/null and b/labworks/LW1/IS_lab_7.png differ diff --git a/labworks/LW1/IS_lab_7_90.png b/labworks/LW1/IS_lab_7_90.png new file mode 100644 index 0000000..74df118 Binary files /dev/null and b/labworks/LW1/IS_lab_7_90.png differ diff --git a/labworks/LW1/best_model_100.keras b/labworks/LW1/best_model_100.keras new file mode 100644 index 0000000..6eb2bba Binary files /dev/null and b/labworks/LW1/best_model_100.keras differ diff --git a/labworks/LW1/images_for_report/1.png b/labworks/LW1/images_for_report/1.png new file mode 100644 index 0000000..363b58f Binary files /dev/null and b/labworks/LW1/images_for_report/1.png differ diff --git a/labworks/LW1/images_for_report/10.png b/labworks/LW1/images_for_report/10.png new file mode 100644 index 0000000..c873a7f Binary files /dev/null and b/labworks/LW1/images_for_report/10.png differ diff --git a/labworks/LW1/images_for_report/11.png b/labworks/LW1/images_for_report/11.png new file mode 100644 index 0000000..b4fa3dd Binary files /dev/null and b/labworks/LW1/images_for_report/11.png differ diff --git a/labworks/LW1/images_for_report/12.png b/labworks/LW1/images_for_report/12.png new file mode 100644 index 0000000..b2a8586 Binary files /dev/null and b/labworks/LW1/images_for_report/12.png differ diff --git a/labworks/LW1/images_for_report/13.png b/labworks/LW1/images_for_report/13.png new file mode 100644 index 0000000..2280e6a Binary files /dev/null and b/labworks/LW1/images_for_report/13.png differ diff --git a/labworks/LW1/images_for_report/14.png b/labworks/LW1/images_for_report/14.png new file mode 100644 index 0000000..30c0f9b Binary files /dev/null and b/labworks/LW1/images_for_report/14.png differ diff --git a/labworks/LW1/images_for_report/15.png b/labworks/LW1/images_for_report/15.png new file mode 100644 index 0000000..ab1900c Binary files /dev/null and b/labworks/LW1/images_for_report/15.png differ diff --git a/labworks/LW1/images_for_report/16.png b/labworks/LW1/images_for_report/16.png new file mode 100644 index 0000000..bd7b4d0 Binary files /dev/null and b/labworks/LW1/images_for_report/16.png differ diff --git a/labworks/LW1/images_for_report/17.png b/labworks/LW1/images_for_report/17.png new file mode 100644 index 0000000..b045500 Binary files /dev/null and b/labworks/LW1/images_for_report/17.png differ diff --git a/labworks/LW1/images_for_report/18.png b/labworks/LW1/images_for_report/18.png new file mode 100644 index 0000000..b0d8000 Binary files /dev/null and b/labworks/LW1/images_for_report/18.png differ diff --git a/labworks/LW1/images_for_report/19.png b/labworks/LW1/images_for_report/19.png new file mode 100644 index 0000000..e586cdd Binary files /dev/null and b/labworks/LW1/images_for_report/19.png differ diff --git a/labworks/LW1/images_for_report/2.png b/labworks/LW1/images_for_report/2.png new file mode 100644 index 0000000..1c52d9d Binary files /dev/null and b/labworks/LW1/images_for_report/2.png differ diff --git a/labworks/LW1/images_for_report/3.png b/labworks/LW1/images_for_report/3.png new file mode 100644 index 0000000..242c9dd Binary files /dev/null and b/labworks/LW1/images_for_report/3.png differ diff --git a/labworks/LW1/images_for_report/4.png b/labworks/LW1/images_for_report/4.png new file mode 100644 index 0000000..7441a05 Binary files /dev/null and b/labworks/LW1/images_for_report/4.png differ diff --git a/labworks/LW1/images_for_report/5.png b/labworks/LW1/images_for_report/5.png new file mode 100644 index 0000000..3aefd63 Binary files /dev/null and b/labworks/LW1/images_for_report/5.png differ diff --git a/labworks/LW1/images_for_report/6.png b/labworks/LW1/images_for_report/6.png new file mode 100644 index 0000000..34dc189 Binary files /dev/null and b/labworks/LW1/images_for_report/6.png differ diff --git a/labworks/LW1/images_for_report/7.png b/labworks/LW1/images_for_report/7.png new file mode 100644 index 0000000..8f475e8 Binary files /dev/null and b/labworks/LW1/images_for_report/7.png differ diff --git a/labworks/LW1/images_for_report/8.png b/labworks/LW1/images_for_report/8.png new file mode 100644 index 0000000..80d3248 Binary files /dev/null and b/labworks/LW1/images_for_report/8.png differ diff --git a/labworks/LW1/images_for_report/9.png b/labworks/LW1/images_for_report/9.png new file mode 100644 index 0000000..4103aa6 Binary files /dev/null and b/labworks/LW1/images_for_report/9.png differ diff --git a/labworks/LW1/report.md b/labworks/LW1/report.md new file mode 100644 index 0000000..0f755c2 --- /dev/null +++ b/labworks/LW1/report.md @@ -0,0 +1,508 @@ +# Отчёт по лабораторной работе №1 + +**Кобзев Александр, Кирсанов Егор — А-01-22** + +## 1. В среде Google Colab создан новый блокнот. Импортированы необходимые библиотеки и модули. + +```python +from google.colab import drive +drive.mount('/content/drive') +``` + +```python +from tensorflow import keras +import matplotlib.pyplot as plt +import numpy as np +import sklearn +from keras.datasets import mnist +from sklearn.model_selection import train_test_split +from tensorflow.keras.utils import to_categorical +from keras.models import Sequential +from keras.layers import Dense +from PIL import Image +``` + + +--- + +## 2. Загрузили набора данных MNIST с изображениями рукописных цифр. + +```python +(X_train, y_train), (X_test, y_test) = mnist.load_data() +``` + +--- + +## 3. Разбили данные на обучающую и тестовую выборки 60 000:10 000. + +При объединении исходных выборок и последующем разбиении был использован параметр `random_state = 4*k - 1`, где *k* – номер бригады (k = 10). Такой фиксированный seed обеспечивает воспроизводимость разбиения. + +```python +# объединяем исходные обучающие и тестовые данные в один массив +X = np.concatenate((X_train, X_test)) +y = np.concatenate((y_train, y_test)) + +# выполняем разбиение на обучающую (60000) и тестовую (10000) выборки +X_train, X_test, y_train, y_test = train_test_split( + X, y, train_size=60000, test_size=10000, random_state=4*10 - 1 +) + +# вывод размерностей полученных массивов +print('Shape of X train:', X_train.shape) +print('Shape of y test:', y_test.shape) +``` + +``` +Shape of X train: (60000, 28, 28) +Shape of y train: (60000,) +``` + +--- + +## 4. Вывели первые 4 элемента обучающих данных (изображения и метки цифр). + +```python +# вывод изображения +fig, axes = plt.subplots(1, 4, figsize=(10, 3)) +for i in range(4): + axes[i].imshow(X_train[i], cmap=plt.get_cmap('gray')) + axes[i].set_title(y_train[i]) + axes[i].axis('off') +plt.show() +``` +![Примеры изображений](images_for_report/1.png) + +--- + +## 5. Провели предобработку данных: привели обучающие и тестовые данные к формату, пригодному для обучения нейронной сети. Входные данные должны принимать значения от 0 до 1, метки цифр должны быть закодированы по принципу «one-hot encoding». Вывели размерности предобработанных обучающих и тестовых массивов данных. + +```python +# развернем каждое изображение 28*28 в вектор 784 +num_pixels = X_train.shape[1] * X_train.shape[2] +X_train = X_train.reshape(X_train.shape[0], num_pixels) / 255.0 +X_test = X_test.reshape(X_test.shape[0], num_pixels) / 255.0 +print('Shape of transformed X train:', X_train.shape) +``` + +``` +Shape of transformed X train: (60000, 784) +``` + +```python +# переведем метки в one-hot +from tensorflow.keras.utils import to_categorical +y_train = to_categorical(y_train) +y_test = to_categorical(y_test) +``` + +``` +Shape of transformed y train: (60000, 10) +``` + +--- + +## 6. Реализовали и обученили однослойную нейронную сеть. + +**Архитектура и параметры:** +- количество скрытых слоёв: 0 +- функция активации выходного слоя: `softmax` +- функция ошибки: `categorical_crossentropy` +- алгоритм обучения: `sgd` +- метрика качества: `accuracy` +- количество эпох: 50 +- доля валидационных данных от обучающих: 0.1 + +```python +model = Sequential() +model.add(Dense(units=10, input_dim=num_pixels, activation='softmax')) +model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +model.summary() +``` + +![архитектура модели](images_for_report/2.png) + +```python +#обучение +H1 = model.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H1.history['loss']) +plt.plot(H1.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/3.png) +--- + +## 7. Применили обученную модель к тестовым данным. + +```python +# Оценка качества работы модели на тестовых данных +scores = model.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.32417795062065125 +Accuracy on test data: 0.9110999703407288 +``` + +## 8. Добавили в модель один скрытый слой и провели обучение и тестирование (повторить п. 6–7) при 100, 300, 500 нейронах в скрытом слое. По метрике качества классификации на тестовых данных выбрали наилучшее количество нейронов в скрытом слое. В качестве функции активации нейронов в скрытом слое использовали функцию sigmoid. + +### При 100 нейронах: +```python +model_100 = Sequential () +model_100.add(Dense(units=100,input_dim=num_pixels, activation='sigmoid')) +model_100.add(Dense(units=num_classes, activation='softmax')) +model_100.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +print(model_100.summary()) +``` + +![архитектура модели](images_for_report/4.png) + +```python +#обучение +H_100 = model_100.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H_100.history['loss']) +plt.plot(H_100.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/5.png) + +```python +# Оценка качества работы модели на тестовых данных +scores = model_100.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.2998492121696472 +Accuracy on test data: 0.9138000011444092 +``` + +### При 300 нейронах: +```python +model_300 = Sequential () +model_300.add(Dense(units=300,input_dim=num_pixels, activation='sigmoid')) +model_300.add(Dense(units=num_classes, activation='softmax')) +model_300.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +print(model_300.summary()) +``` + +![архитектура модели](images_for_report/6.png) + +```python +H_300 = model_300.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H_300.history['loss']) +plt.plot(H_300.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/7.png) + +```python +# Оценка качества работы модели на тестовых данных +scores = model_300.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.31299835443496704 +Accuracy on test data: 0.9107999801635742 +``` + +### При 500 нейронах: +```python +model_500 = Sequential() +model_500.add(Dense(units=500, input_dim=num_pixels, activation='sigmoid')) +model_500.add(Dense(units=num_classes, activation='softmax')) +model_500.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +print(model_500.summary()) +``` + +![архитектура модели](images_for_report/8.png) + + +```python +H_500 = model_500.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H_500.history['loss']) +plt.plot(H_500.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/9.png) + +```python +# Оценка качества работы модели на тестовых данных +scores = model_500.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.31795090436935425 +Accuracy on test data: 0.909600019454956 +``` + +Мы видим что лучший результат показала модель со 100 нейронами в скрытом слое(Accuracy = 0.9138). + +## 9. Добавили в наилучшую архитектуру, определенную в п. 8, второй скрытый слой и провели обучение и тестирование при 50 и 100 нейронах во втором скрытом слое. В качестве функции активации нейронов в скрытом слое использовали функцию sigmoid. + +### При 50 нейронах в 2-м слое: +```python +model_100_50 = Sequential() +model_100_50.add(Dense(units=100, input_dim=num_pixels, activation='sigmoid')) +model_100_50.add(Dense(units=50, activation='sigmoid')) +model_100_50.add(Dense(units=num_classes, activation='softmax')) +model_100_50.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +print(model_100_50.summary()) +``` + +![архитектура модели](images_for_report/10.png) + +```python +H_100_50 = model_100_50.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H_100_50.history['loss']) +plt.plot(H_100_50.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/11.png) + +```python +# Оценка качества работы модели на тестовых данных +scores = model_100_50.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.3216394782066345 +Accuracy on test data: 0.9085999727249146 +``` + +### При 100 нейронах во 2-м слое:\ + +```python +model_100_100 = Sequential() +model_100_100.add(Dense(units=100, input_dim=num_pixels, activation='sigmoid')) +model_100_100.add(Dense(units=100, activation='sigmoid')) +model_100_100.add(Dense(units=num_classes, activation='softmax')) +model_100_100.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy']) +print(model_100_100.summary()) +``` + +![архитектура модели](images_for_report/12.png) + +```python +H_100_100 = model_100_100.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150) +``` + +```python +# вывод графика ошибки по эпохам +plt.plot(H_100_100.history['loss']) +plt.plot(H_100_100.history['val_loss']) +plt.grid() +plt.xlabel('Epochs') +plt.ylabel('loss') +plt.legend(['train_loss', 'val_loss']) +plt.title('Loss by epochs') +plt.show() +``` + +![граффик обучения](images_for_report/13.png) + +```python +# Оценка качества работы модели на тестовых данных +scores = model.evaluate(X_test, y_test) +print('Loss on test data:', scores[0]) +print('Accuracy on test data:', scores[1]) +``` + +``` +Loss on test data: 0.31788304448127747 +Accuracy on test data: 0.9128000140190125 +``` + +## 10. Сравнили качество классификации на тестовых данных всех построенных моделей. Сделали выводы. + +| Кол-во слоёв | Нейронов в 1-м | Нейронов во 2-м | Accuracy | +|---------------|----------------|-----------------|-----------| +| 0 | – | – | 0.9111 | +| 1 | 100 | – | 0.9138 | +| 1 | 300 | – | 0.9108 | +| 1 | 500 | – | 0.9096 | +| 2 | 100 | 50 | 0.9086 | +| 2 | 100 | 100 | 0.9128 | + +**Вывод:** наилучшей оказалась архитектура с одним скрытым слоем и 100 нейронами в нём. Увеличение числа нейронов в скрытом слое или добавление второго слоя не улучшило качество классификации, а в некоторых случаях даже ухудшило его. Вероятно, это связано с переобучением модели из-за избыточного количества параметров при относительно небольшом объёме обучающих данных. + +--- + +## 11. Сохранили наилучшую модель на диск. + +```python +model_100.save("/content/drive/MyDrive/Colab Notebooks/best_model_100.keras") +``` + +--- + +## 12. Для нейронной сети с наилучшей архитектурой вывели 2 тестовых изображения и истинные метки, а также предсказанные моделью метки. + +```python +n = 333 +result = model_100.predict(X_test[n:n+1]) +print('NNoutput:',result) +plt.imshow(X_test[n].reshape(28,28),cmap=plt.get_cmap('gray')) +plt.show() +print('Realmark:',str(np.argmax(y_test[n]))) +print('NNanswer:',str(np.argmax(result))) +``` +![Пример 1](images_for_report/14.png) + +```python +n = 234 +result = model_100.predict(X_test[n:n+1]) +print('NNoutput:',result) +plt.imshow(X_test[n].reshape(28,28),cmap=plt.get_cmap('gray')) +plt.show() +print('Realmark:',str(np.argmax(y_test[n]))) +print('NNanswer:',str(np.argmax(result))) +``` +![Пример 2](images_for_report/15.png) + +--- + +## 13. Создали собственные изображения рукописных цифр, подобное представленным в наборе MNIST. Цифру выбрали как остаток от деления на 10 числа своего дня рождения (14 июля → 14 mod 10 = 4, 7 ноября → 7 mod 10 = 7). Сохранили изображения. Загрузили, предобработали и подали на вход обученной нейронной сети собственные изображения. Вывели изображения и результаты распознавания. + +### Для 7: + +![Изображение "7"](IS_lab_7.png) + +```python +#вывод собственного изображения +plt.imshow(test_img,cmap=plt.get_cmap('gray')) +plt.show() +#предобработка +test_img=test_img/255 +test_img=test_img.reshape(1,num_pixels) +#распознавание +result=model_100.predict(test_img) +print('I think it\'s',np.argmax(result)) +``` +![Отображение "7"](images_for_report/16.png) + +### Для 4: + +![Мое изображение "4"](IS_lab_4.png) + +```python +from PIL import Image +file_data_4=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_4.png') +file_data_4=file_data_4.convert('L') +test_img_4=np.array(file_data_4) +#вывод собственного изображения +plt.imshow(test_img_4,cmap=plt.get_cmap('gray')) +plt.show() +#предобработка +test_img_4=test_img_4/255 +test_img_4=test_img_4.reshape(1,num_pixels) +#распознавание +result=model_100.predict(test_img_4) +print('I think it\'s',np.argmax(result)) +``` +![Отображение "4"](images_for_report/17.png) + +--- + +## 14. Создать копию собственного изображения, отличающуюся от оригинала поворотом на 90 градусов в любую сторону. Сохранили изображения. Загрузили, предобработали и подали на вход обученной нейронной сети измененные изображения. Вывели изображения и результаты распознавания. Сделали выводы по результатам эксперимента. + +```python +from PIL import Image +file_data=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_7_90.png') +file_data=file_data.convert('L') +test_img=np.array(file_data) +#вывод собственного изображения +plt.imshow(test_img,cmap=plt.get_cmap('gray')) +plt.show() +#предобработка +test_img=test_img/255 +test_img=test_img.reshape(1,num_pixels) +#распознавание +result=model_100.predict(test_img) +print('Ithinkit\'s',np.argmax(result)) +``` + +![Отображение "7 повернутой"](images_for_report/18.png) + +```python +from PIL import Image +file_data_4=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_4_90.png') +file_data_4=file_data_4.convert('L') +test_img_4=np.array(file_data_4) +#выводсобственногоизображения +plt.imshow(test_img_4,cmap=plt.get_cmap('gray')) +plt.show() +#предобработка +test_img_4=test_img_4/255 +test_img_4=test_img_4.reshape(1,num_pixels) +#распознавание +result=model_100.predict(test_img_4) +print('Ithinkit\'s',np.argmax(result)) +``` + +![Отображение "4 повернутой"](images_for_report/19.png) + +**Вывод:** модель неустойчива к повороту изображений, так как не обучалась на повернутых данных. + +--- + +## Заключение +Изучены принципы построения и обучения нейронных сетей в Keras на примере распознавания цифр MNIST. Лучшая точность достигнута простой моделью с одним скрытым слоем из 100 нейронов. При усложнении архитектуры наблюдается переобучение. Сеть корректно классифицирует собственные изображения, но ошибается на повернутых. \ No newline at end of file diff --git a/labworks/LW1/Копия Untitled0.ipynb b/labworks/LW1/Копия Untitled0.ipynb new file mode 100644 index 0000000..6e8c00f --- /dev/null +++ b/labworks/LW1/Копия Untitled0.ipynb @@ -0,0 +1 @@ +{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"provenance":[],"gpuType":"T4"},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"},"accelerator":"GPU"},"cells":[{"cell_type":"code","source":[],"metadata":{"id":"1TFPbD2koKmu"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["from google.colab import drive\n","drive.mount('/content/drive')"],"metadata":{"id":"RtZRG8oCnmmC"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["1) В среде Google Colab создать новый блокнот (notebook). Импортировать\n","необходимые для работы библиотеки и модули.\n"],"metadata":{"id":"5oURju7duPmk"}},{"cell_type":"code","source":["from tensorflow import keras\n","import matplotlib.pyplot as plt\n","import numpy as np\n","import sklearn\n","from keras.datasets import mnist\n","from sklearn.model_selection import train_test_split\n","from tensorflow.keras.utils import to_categorical\n","from keras.models import Sequential\n","from keras.layers import Dense\n","from PIL import Image"],"metadata":{"id":"09gFd_-eo7eW"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["2) Загрузить набор данных MNIST, содержащий размеченные изображения\n","рукописных цифр.\n"],"metadata":{"id":"mheOTPt8uTD2"}},{"cell_type":"code","source":["# загрузка датасета\n","(X_train, y_train), (X_test, y_test) = mnist.load_data()"],"metadata":{"id":"9k2EoBu8pKS0"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["3) Разбить набор данных на обучающие и тестовые данные в соотношении\n","60 000:10 000 элементов. При разбиении параметр random_state выбрать\n","равным (4k – 1), где k – номер бригады. Вывести размерности полученных\n","обучающих и тестовых массивов данных.\n","k = 10"],"metadata":{"id":"foMRRdZ-uXOa"}},{"cell_type":"code","source":["# объединяем в один набор\n","X = np.concatenate((X_train, X_test))\n","y = np.concatenate((y_train, y_test))\n","# разбиваем по вариантам\n","X_train, X_test, y_train, y_test = train_test_split(X, y,\n"," test_size = 10000,\n"," train_size = 60000,\n"," random_state = 4*10 - 1)"],"metadata":{"id":"lmfDKm9yptVY"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод размерностей\n","print('Shape of X train:', X_train.shape)\n","print('Shape of y train:', y_train.shape)"],"metadata":{"id":"ycwVxkDzqYoR"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["4) Вывести первые 4 элемента обучающих данных (изображения и метки\n","цифр)."],"metadata":{"id":"8qespHFRugQX"}},{"cell_type":"code","source":["# вывод изображения\n","fig, axes = plt.subplots(1, 4, figsize=(10, 3))\n","for i in range(4):\n"," axes[i].imshow(X_train[i], cmap=plt.get_cmap('gray'))\n"," axes[i].set_title(y_train[i])\n"," axes[i].axis('off')\n","plt.show()"],"metadata":{"id":"HLpjjwweqg_D"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["5) Провести предобработку данных: привести обучающие и тестовые данные\n","к формату, пригодному для обучения нейронной сети. Входные данные\n","должны принимать значения от 0 до 1, метки цифр должны быть\n","закодированы по принципу «one-hot encoding». Вывести размерности\n","предобработанных обучающих и тестовых массивов данных."],"metadata":{"id":"4rTauf-dunEM"}},{"cell_type":"code","source":["# развернем каждое изображение 28*28 в вектор 784\n","num_pixels = X_train.shape[1] * X_train.shape[2]\n","X_train = X_train.reshape(X_train.shape[0], num_pixels) / 255\n","X_test = X_test.reshape(X_test.shape[0], num_pixels) / 255\n","print('Shape of transformed X train:', X_train.shape)\n"],"metadata":{"id":"JJlSBKttun8W"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# переведем метки в one-hot\n","y_train = to_categorical(y_train)\n","y_test = to_categorical(y_test)\n","print('Shape of transformed y train:', y_train.shape)\n","num_classes = y_train.shape[1]\n"],"metadata":{"id":"Q5LqZcAdvhbl"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["6) Реализовать модель однослойной нейронной сети и обучить ее на\n","обучающих данных с выделением части обучающих данных в качестве\n","валидационных. Вывести информацию об архитектуре нейронной сети.\n","Вывести график функции ошибки на обучающих и валидационных данных\n","по эпохам."],"metadata":{"id":"NYYbUgM6xzEW"}},{"cell_type":"code","source":["model = Sequential()\n","model.add(Dense(units=num_classes,input_dim=num_pixels, activation='softmax'))\n","model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model.summary())"],"metadata":{"id":"IS8-6AUexljX"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H1 = model.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)\n"],"metadata":{"id":"IKRNkIbCC24a"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H1.history['loss'])\n","plt.plot(H1.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"kyd2Bh_hE9VO"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["7) Применить обученную модель к тестовым данным. Вывести значение\n","функции ошибки и значение метрики качества классификации на тестовых\n","данных."],"metadata":{"id":"Z2QVCB9NEzpM"}},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"NnPi_avSEuAy"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["8) Добавить в модель один скрытый и провести обучение и тестирование\n","(повторить п. 6–7) при 100, 300, 500 нейронах в скрытом слое. По метрике\n","качества классификации на тестовых данных выбрать наилучшее\n","количество нейронов в скрытом слое. В качестве функции активации\n","нейронов в скрытом слое использовать функцию sigmoid."],"metadata":{"id":"ukflwBJgGhu5"}},{"cell_type":"code","source":["model_100 = Sequential ()\n","model_100.add(Dense(units=100,input_dim=num_pixels, activation='sigmoid'))\n","model_100.add(Dense(units=num_classes, activation='softmax'))\n","model_100.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model_100.summary())"],"metadata":{"id":"VvgnJtzaGi-V"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H_100 = model_100.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)"],"metadata":{"id":"foBFtG3hHNsM"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H_100.history['loss'])\n","plt.plot(H_100.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"zHA_blqiJm7-"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model_100.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"rxwTYECGJsAi"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["300"],"metadata":{"id":"gcDXa-faJ-Xp"}},{"cell_type":"code","source":["model_300 = Sequential ()\n","model_300.add(Dense(units=300,input_dim=num_pixels, activation='sigmoid'))\n","model_300.add(Dense(units=num_classes, activation='softmax'))\n","model_300.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model_300.summary())"],"metadata":{"id":"CcIlDKU4J5Fy"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H_300 = model_300.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)"],"metadata":{"id":"5dChQjjIJ5Fz"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H_300.history['loss'])\n","plt.plot(H_300.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"iTj6TcVzJ5Fz"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model_300.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"AaTfpYqZJ5F0"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["500"],"metadata":{"id":"ROIhv1chKtlU"}},{"cell_type":"code","source":["model_500 = Sequential ()\n","model_500.add(Dense(units=500,input_dim=num_pixels, activation='sigmoid'))\n","model_500.add(Dense(units=num_classes, activation='softmax'))\n","model_500.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model_500.summary())"],"metadata":{"id":"APtFO2PMKu6W"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H_500 = model_500.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)"],"metadata":{"id":"vC0VRA8yKu6W"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H_500.history['loss'])\n","plt.plot(H_500.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"yEM-YlO1Ku6X"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model_500.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"wtNPbUklKu6X"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["9) Добавить в наилучшую архитектуру, определенную в п. 8, второй скрытый\n","слой и провести обучение и тестирование (повторить п. 6–7) при 50 и 100\n","нейронах во втором скрытом слое. В качестве функции активации\n","нейронов в скрытом слое использовать функцию sigmoid."],"metadata":{"id":"oxK9QRg7Muj9"}},{"cell_type":"code","source":["model_100_50 = Sequential()\n","model_100_50.add(Dense(units=100, input_dim=num_pixels, activation='sigmoid'))\n","model_100_50.add(Dense(units=50, activation='sigmoid'))\n","model_100_50.add(Dense(units=num_classes, activation='softmax'))\n","model_100_50.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model_100_50.summary())"],"metadata":{"id":"_nawrX4iNBHW"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H_100_50 = model_100_50.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)"],"metadata":{"id":"sAb7w7eINBHX"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H_100_50.history['loss'])\n","plt.plot(H_100_50.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"xXFa8Ob6NBHX"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model_100_50.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"CoZo6w5qNBHY"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["100 на втрором слое"],"metadata":{"id":"9lx5dZCGN5rS"}},{"cell_type":"code","source":["model_100_100 = Sequential ()\n","model_100_100.add(Dense(units=100,input_dim=num_pixels, activation='sigmoid'))\n","model_100_100.add(Dense(units=100, activation='sigmoid'))\n","model_100_100.add(Dense(units=num_classes, activation='softmax'))\n","model_100_100.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])\n","print(model_100_100.summary())"],"metadata":{"id":"bymnTOnJN29P"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["H_100_100 = model_100_100.fit(X_train, y_train, batch_size=256, validation_split=0.1, epochs=150)"],"metadata":{"id":"0SaEjqzoN29Q"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# вывод графика ошибки по эпохам\n","plt.plot(H_100_100.history['loss'])\n","plt.plot(H_100_100.history['val_loss'])\n","plt.grid()\n","plt.xlabel('Epochs')\n","plt.ylabel('loss')\n","plt.legend(['train_loss', 'val_loss'])\n","plt.title('Loss by epochs')\n","plt.show()"],"metadata":{"id":"HTzEyc5SN29Q"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["# Оценка качества работы модели на тестовых данных\n","scores = model.evaluate(X_test, y_test)\n","print('Loss on test data:', scores[0])\n","print('Accuracy on test data:', scores[1])"],"metadata":{"id":"MfOcXeXhN29R"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["Таблица с наилучшими архитектурами сети и вывод по ним.![image.png]()"],"metadata":{"id":"3rA05vGIDC4H"}},{"cell_type":"markdown","source":["11) Сохранить наилучшую нейронную сеть на диск. Данную нейронную сеть потребуется загрузить с диска в одной из следующих лабораторных работ."],"metadata":{"id":"mUcd8nnoLjXe"}},{"cell_type":"code","source":["model_100.save(\"/content/drive/MyDrive/Colab Notebooks/best_model_100.keras\")"],"metadata":{"id":"HS3dgfuKLocO"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["12) Для нейронной сети наилучшей архитектурывывести два тестовых изображения, истинные метки и результат распознавания изображений."],"metadata":{"id":"iWjIiC3oNUZe"}},{"cell_type":"code","source":["n = 333\n","result = model_100.predict(X_test[n:n+1])\n","print('NNoutput:',result)\n","plt.imshow(X_test[n].reshape(28,28),cmap=plt.get_cmap('gray'))\n","plt.show()\n","print('Realmark:',str(np.argmax(y_test[n])))\n","print('NNanswer:',str(np.argmax(result)))"],"metadata":{"id":"h6EsX0sWNV1Y"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["n = 234\n","result = model_100.predict(X_test[n:n+1])\n","print('NNoutput:',result)\n","plt.imshow(X_test[n].reshape(28,28),cmap=plt.get_cmap('gray'))\n","plt.show()\n","print('Realmark:',str(np.argmax(y_test[n])))\n","print('NNanswer:',str(np.argmax(result)))"],"metadata":{"id":"fA6xMRS7Ny_U"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["13\n"],"metadata":{"id":"FzvS0hqHefWX"}},{"cell_type":"code","source":["from keras.models import load_model\n","\n","model_100=load_model('/content/drive/MyDrive/Colab Notebooks/best_model_100.keras')"],"metadata":{"id":"N-z0ErgfkHdv"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["\n","file_data=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_7.png')\n","file_data=file_data.convert('L')\n","test_img=np.array(file_data)\n"],"metadata":{"id":"uQXfnnNEcF46"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["#выводсобственногоизображения\n","plt.imshow(test_img,cmap=plt.get_cmap('gray'))\n","plt.show()\n","#предобработка\n","test_img=test_img/255\n","test_img=test_img.reshape(1,num_pixels)\n","#распознавание\n","result=model_100.predict(test_img)\n","print('I think it\\'s',np.argmax(result))"],"metadata":{"id":"RDl8sPM_vnXn"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["\n","file_data_4=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_4.png')\n","file_data_4=file_data_4.convert('L')\n","test_img_4=np.array(file_data_4)"],"metadata":{"id":"M8XBxYIDv1Ui"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["#выводсобственногоизображения\n","plt.imshow(test_img_4,cmap=plt.get_cmap('gray'))\n","plt.show()\n","#предобработка\n","test_img_4=test_img_4/255\n","test_img_4=test_img_4.reshape(1,num_pixels)\n","#распознавание\n","result=model_100.predict(test_img_4)\n","print('I think it\\'s',np.argmax(result))"],"metadata":{"id":"iBTfB4W8v5Pi"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["14. Каждому члену бригады создать копию собственного изображения, отличающуюся от оригинала поворотом на 90 градусов в любую сторону. Сохранить изображения. Загрузить, предобработать и подать на вход обученной нейронной сети измененные изображения. Вывести изображения и результаты распознавания. Сделать выводы по результатам эксперимента."],"metadata":{"id":"-HMUj57ZR1N8"}},{"cell_type":"code","source":["from PIL import Image\n","file_data=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_7_90.png')\n","file_data=file_data.convert('L')\n","test_img=np.array(file_data)\n"],"metadata":{"id":"AGQgEWl1PLIv"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["#выводсобственногоизображения\n","plt.imshow(test_img,cmap=plt.get_cmap('gray'))\n","plt.show()\n","#предобработка\n","test_img=test_img/255\n","test_img=test_img.reshape(1,num_pixels)\n","#распознавание\n","result=model_100.predict(test_img)\n","print('Ithinkit\\'s',np.argmax(result))"],"metadata":{"id":"NkaPb4jtRktK"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["from PIL import Image\n","file_data_4=Image.open('/content/drive/MyDrive/Colab Notebooks/IS_lab_4_90.png')\n","file_data_4=file_data_4.convert('L')\n","test_img_4=np.array(file_data_4)\n"],"metadata":{"id":"osOpZLGtU4Sd"},"execution_count":null,"outputs":[]},{"cell_type":"code","source":["#выводсобственногоизображения\n","plt.imshow(test_img_4,cmap=plt.get_cmap('gray'))\n","plt.show()\n","#предобработка\n","test_img_4=test_img_4/255\n","test_img_4=test_img_4.reshape(1,num_pixels)\n","#распознавание\n","result=model_100.predict(test_img_4)\n","print('Ithinkit\\'s',np.argmax(result))"],"metadata":{"id":"hR_dW-lLU_Ga"},"execution_count":null,"outputs":[]}]} \ No newline at end of file