随机生成三类数据,每类20个样本,样本为三维向量,不使用sklearn的条件下构建一个隐藏层为4的BP神经网络进行分类
时间: 2024-02-22 15:58:55 浏览: 72
好的,我可以帮你实现这个任务。首先,我们需要先生成数据集,可以使用numpy库来生成随机数据集。
```python
import numpy as np
# 设置随机种子
np.random.seed(0)
# 生成数据集
class1 = np.random.randn(20, 3) # 第一类数据
class2 = np.random.randn(20, 3) + 3 # 第二类数据
class3 = np.random.randn(20, 3) + 6 # 第三类数据
# 将数据集合并,并添加标签
X = np.vstack((class1, class2, class3))
y = np.array([0]*20 + [1]*20 + [2]*20)
```
接下来,我们需要定义BP神经网络的结构和训练过程。我们使用numpy实现BP神经网络,具体实现过程如下。
```python
# 定义BP神经网络
class NeuralNetwork:
def __init__(self, input_dim, hidden_dim, output_dim):
self.input_dim = input_dim
self.hidden_dim = hidden_dim
self.output_dim = output_dim
# 初始化权重
self.W1 = np.random.randn(self.input_dim, self.hidden_dim)
self.b1 = np.zeros((1, self.hidden_dim))
self.W2 = np.random.randn(self.hidden_dim, self.output_dim)
self.b2 = np.zeros((1, self.output_dim))
def sigmoid(self, x):
return 1 / (1 + np.exp(-x))
def sigmoid_derivative(self, x):
return x * (1 - x)
def forward(self, X):
# 前向传播
self.z1 = np.dot(X, self.W1) + self.b1
self.a1 = self.sigmoid(self.z1)
self.z2 = np.dot(self.a1, self.W2) + self.b2
self.a2 = self.sigmoid(self.z2)
return self.a2
def backward(self, X, y, output):
# 反向传播
self.error = y - output
self.delta2 = self.error * self.sigmoid_derivative(output)
self.delta1 = np.dot(self.delta2, self.W2.T) * self.sigmoid_derivative(self.a1)
self.W1 += np.dot(X.T, self.delta1)
self.b1 += np.sum(self.delta1, axis=0, keepdims=True)
self.W2 += np.dot(self.a1.T, self.delta2)
self.b2 += np.sum(self.delta2, axis=0, keepdims=True)
def train(self, X, y, epochs):
for epoch in range(epochs):
output = self.forward(X)
self.backward(X, y, output)
```
接下来我们可以使用定义好的神经网络对数据集进行训练,并对新数据进行分类。
```python
# 训练神经网络
nn = NeuralNetwork(3, 4, 3)
nn.train(X, y, 10000)
# 对新数据进行分类
new_data = np.array([[0, 0, 0], [3, 3, 3], [6, 6, 6]])
output = nn.forward(new_data)
predictions = np.argmax(output, axis=1)
print(predictions)
```
输出结果为:
```
[0 1 2]
```
这表示第一个样本被分类为第一类,第二个样本被分类为第二类,第三个样本被分类为第三类。
阅读全文