Читать книгу 120 практических задач онлайн
from tensorflow.keras.layers import Conv1D, MaxPooling1D, Flatten, Dense, Dropout
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import LabelEncoder
import numpy as np
# Пример данных (данные нужно подставить под ваши)
# X – последовательности ДНК
# y – метки классов (категории, к которым относится каждая последовательность)
X = np.random.choice(['A', 'C', 'G', 'T'], size=(1000, 100)) # пример матрицы последовательностей
y = np.random.choice(['class1', 'class2', 'class3'], size=(1000,)) # пример вектора меток классов
# Преобразование последовательностей в числовой формат
encoder = LabelEncoder()
X_encoded = np.array([encoder.fit_transform(seq) for seq in X])
# Разделение данных на обучающую и тестовую выборки
X_train, X_test, y_train, y_test = train_test_split(X_encoded, y, test_size=0.2, random_state=42)
# Параметры модели и обучения
input_length = X.shape[1] # длина каждой последовательности ДНК
num_classes = len(np.unique(y)) # количество уникальных классов
# Создание модели
model = Sequential()
# Добавление слоев
model.add(Conv1D(128, 5, activation='relu', input_shape=(input_length, 1)))
model.add(MaxPooling1D(2))
model.add(Conv1D(64, 5, activation='relu'))
model.add(MaxPooling1D(2))
model.add(Flatten())
model.add(Dense(64, activation='relu'))
model.add(Dropout(0.5))
model.add(Dense(num_classes, activation='softmax')) # выходной слой с softmax для многоклассовой классификации
# Компиляция модели
model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])
# Вывод архитектуры модели
model.summary()
# Обучение модели
model.fit(X_train[:, :, np.newaxis], y_train, epochs=20, batch_size=32, validation_data=(X_test[:, :, np.newaxis], y_test))
```
Пояснение архитектуры и процесса:
1. Архитектура модели: Пример включает в себя одномерные сверточные слои (Conv1D), которые способны извлекать пространственные шаблоны из последовательностей ДНК. После каждого сверточного слоя используется слой MaxPooling1D для уменьшения размерности данных. Затем данные выравниваются в одномерный вектор с помощью слоя Flatten и обрабатываются полносвязными слоями с функцией активации ReLU. Выходной слой использует softmax для классификации последовательностей ДНК на заданные классы.