基于神经网络的倒立摆控制系统设计

基于神经网络的倒立摆控制系统设计

问题:一级倒立摆装置如图所示。装在小车上的倒立摆在水平力的作用下,通过控制小车的运动速度使偏转角θ为0,即可使倒立摆直立起来。

在这里插入图片描述
一、参数分析
在这里插入图片描述全部的主要参数就是以上七个,其中需要用到的是小车质量M、摆杆质量m、摆杆转动轴心到杆质心的长度l以及摆杆惯量!
二、受力分析(不多赘述,百度一大堆,直接进入数据采集模块)

三、数据采集
这里首先我们打开matlab的help参考页面的搜索Inverted pendulum找到以下这个matlab自带的modol。(这个modol其实就是基于LQR控制的一个倒立摆小车模型)

  • 16
    点赞
  • 141
    收藏
    觉得还不错? 一键收藏
  • 26
    评论
好的,我可以为您讲解基于numpy设计神经网络的步骤: 1. 导入numpy库 ``` import numpy as np ``` 2. 定义神经网络的结构,包括输入层、隐藏层和输出层的节点数,以及权重和偏置的初始值 ``` input_size = 2 hidden_size = 4 output_size = 1 W1 = np.random.randn(input_size, hidden_size) b1 = np.zeros((1, hidden_size)) W2 = np.random.randn(hidden_size, output_size) b2 = np.zeros((1, output_size)) ``` 3. 定义激活函数,常用的有sigmoid和relu函数 ``` def sigmoid(x): return 1 / (1 + np.exp(-x)) def relu(x): return np.maximum(0, x) ``` 4. 定义前向传播函数,将输入数据通过神经网络得到输出结果 ``` def forward(X): # 第一层 z1 = np.dot(X, W1) + b1 a1 = relu(z1) # 第二层 z2 = np.dot(a1, W2) + b2 y_hat = sigmoid(z2) return y_hat ``` 5. 定义损失函数,常用的有均方误差和交叉熵函数 ``` def mse_loss(y, y_hat): return np.mean((y - y_hat) ** 2) def cross_entropy_loss(y, y_hat): return -(y * np.log(y_hat) + (1 - y) * np.log(1 - y_hat)).mean() ``` 6. 定义反向传播函数,计算权重和偏置的梯度 ``` def backward(X, y, y_hat): # 输出层 dz2 = y_hat - y dW2 = np.dot(a1.T, dz2) db2 = dz2.sum(axis=0, keepdims=True) # 隐藏层 da1 = np.dot(dz2, W2.T) dz1 = da1 * (z1 > 0) dW1 = np.dot(X.T, dz1) db1 = dz1.sum(axis=0) return dW1, db1, dW2, db2 ``` 7. 定义更新权重和偏置的函数,采用梯度下降法更新神经网络的参数 ``` def update_params(dW1, db1, dW2, db2, lr): W1 -= lr * dW1 b1 -= lr * db1 W2 -= lr * dW2 b2 -= lr * db2 return W1, b1, W2, b2 ``` 8. 定义训练函数,利用前向传播、反向传播和权重更新来训练神经网络 ``` def train(X, y, epochs, lr): for i in range(epochs): y_hat = forward(X) loss = mse_loss(y, y_hat) dW1, db1, dW2, db2 = backward(X, y, y_hat) W1, b1, W2, b2 = update_params(dW1, db1, dW2, db2, lr) if i % 100 == 0: print(f"Epoch {i}, Loss: {loss:.4f}") return W1, b1, W2, b2 ``` 这些步骤可以帮助您基于numpy设计神经网络,进行训练和预测任务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值