Читать книгу Искусственный интеллект в прикладных науках. Медицина онлайн
])
# Компиляция модели
model.compile(loss='binary_crossentropy',
optimizer='adam',
metrics=['accuracy'])
# Обучение модели
history = model.fit(
train_generator,
steps_per_epoch=train_generator.samples/train_generator.batch_size,
epochs=10,
validation_data=test_generator,
validation_steps=test_generator.samples/test_generator.batch_size)
# График точности и потерь
plt.plot(history.history['accuracy'], label='accuracy')
plt.plot(history.history['val_accuracy'], label='val_accuracy')
plt.xlabel('Epoch')
plt.ylabel('Accuracy')
plt.legend()
plt.show()
```
Этот пример демонстрирует создание и обучение модели сверточной нейронной сети (CNN) для классификации медицинских изображений. Обратите внимание, что для запуска этого кода вам потребуется наличие набора данных медицинских изображений и указание правильных путей к этим данным в переменных `train_data_dir` и `test_data_dir`.
Разберем этапы кода подробнее.
1. Импорт библиотек:
```python
import numpy as np
import matplotlib.pyplot as plt
import tensorflow as tf
from tensorflow.keras.preprocessing.image import ImageDataGenerator
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Conv2D, MaxPooling2D, Flatten, Dense
```
– `numpy` используется для работы с массивами чисел.
– `matplotlib.pyplot` используется для построения графиков.
– `tensorflow` – фреймворк глубокого обучения.
– `ImageDataGenerator` используется для предварительной обработки изображений перед подачей их в модель.
– `Sequential` используется для создания последовательной модели.
– `Conv2D`, `MaxPooling2D`, `Flatten` и `Dense` – типы слоев нейронной сети.
2. Загрузка данных:
```python
train_data_dir = 'path_to_training_data_directory'
test_data_dir = 'path_to_test_data_directory'
train_datagen = ImageDataGenerator(rescale=1./255)
test_datagen = ImageDataGenerator(rescale=1./255)
train_generator = train_datagen.flow_from_directory(
train_data_dir,
target_size=(150, 150),
batch_size=32,
class_mode='binary')
test_generator = test_datagen.flow_from_directory(