实现使用RBF(径向基函数)神经网络模拟二阶电机数学模型中的非线性干扰,以及使用WNN(小波神经网络)预测模型中的非线性函数来抵消迟滞影响的功能
下面将详细介绍如何实现使用RBF(径向基函数)神经网络模拟二阶电机数学模型中的非线性干扰,以及使用WNN(小波神经网络)预测模型中的非线性函数来抵消迟滞影响的功能。我们将按照以下步骤进行:
步骤1:定义二阶电机数学模型
考虑一个带有迟滞影响的二阶电机数学模型,其一般形式可以表示为:
y ¨ ( t ) + a 1 y ˙ ( t ) + a 0 y ( t ) = u ( t ) + d ( t ) + h ( t ) \ddot{y}(t) + a_1\dot{y}(t) + a_0y(t) = u(t) + d(t) + h(t) y¨(t)+a1y˙(t)+a0y(t)=u(t)+d(t)+h(t)
其中, y ( t ) y(t) y(t) 是电机的输出, u ( t ) u(t) u(t) 是控制输入, d ( t ) d(t) d(t) 是非线性干扰, h ( t ) h(t) h(t) 是迟滞影响。
步骤2:RBF神经网络模拟非线性干扰
RBF神经网络是一种前馈神经网络,其输出可以表示为:
d ^ ( t ) = ∑ i = 1 N w i φ ( ∥ x ( t ) − c i ∥ ) \hat{d}(t) = \sum_{i=1}^{N} w_i\varphi(\left\lVert x(t) - c_i\right\rVert) d^(t)=i=1∑Nwiφ(∥x(t)−ci∥)
其中, w i w_i wi 是权重, φ \varphi φ 是径向基函数(通常使用高斯函数), c i c_i ci 是中心, x ( t ) x(t) x(t) 是输入向量。
步骤3:WNN预测非线性函数
小波神经网络是一种结合了小波变换和神经网络的模型,用于预测模型中的非线性函数。
代码实现
import numpy as np
import matplotlib.pyplot as plt
from sklearn.neural_network import MLPRegressor
from pywt import wavedec# 定义二阶电机数学模型
def second_order_motor_model(y, u, d, h, a0, a1):y_dot = np.zeros(2)y_dot[0] = y[1]y_dot[1] = -a0 * y[0] - a1 * y[1] + u + d + hreturn y_dot# 定义RBF神经网络模拟非线性干扰
def rbf_network(x, centers, weights, sigma):N = len(centers)phi = np.zeros(N)for i in range(N):phi[i] = np.exp(-np.linalg.norm(x - centers[i])**2 / (2 * sigma**2))return np.dot(weights, phi)# 定义WNN预测非线性函数
def wnn_predict(x, model):# 这里简单使用MLPRegressor作为示例return model.predict([x])[0]# 模拟参数
T = 10 # 模拟时间
dt = 0.01 # 时间步长
t = np.arange(0, T, dt)
N = len(t)# 模型参数
a0 = 1.0
a1 = 0.5# 初始化状态
y = np.zeros((N, 2))
y[0] = [0, 0]# 控制输入
u = np.sin(2 * np.pi * 0.5 * t)# 非线性干扰和迟滞影响
d = 0.5 * np.sin(2 * np.pi * 1.5 * t)
h = 0.2 * np.sign(np.sin(2 * np.pi * 2 * t))# RBF神经网络参数
N_rbf = 10 # RBF神经元数量
centers = np.random.rand(N_rbf, 2)
weights = np.random.rand(N_rbf)
sigma = 0.1# WNN模型训练
X_wnn = np.column_stack((y[:, 0], y[:, 1], u))
y_wnn = -a0 * y[:, 0] - a1 * y[:, 1] + u + d + h
wnn_model = MLPRegressor(hidden_layer_sizes=(10,), activation='relu', max_iter=1000)
wnn_model.fit(X_wnn, y_wnn)# 模拟过程
for i in range(1, N):# 预测非线性干扰d_hat = rbf_network(y[i-1], centers, weights, sigma)# 预测非线性函数f_hat = wnn_predict(np.concatenate((y[i-1], [u[i-1]])), wnn_model)# 抵消影响u_compensated = u[i-1] - d_hat - f_hat# 更新状态y_dot = second_order_motor_model(y[i-1], u_compensated, d[i-1], h[i-1], a0, a1)y[i] = y[i-1] + y_dot * dt# 绘制结果
plt.figure(figsize=(12, 6))
plt.subplot(2, 1, 1)
plt.plot(t, y[:, 0], label='Output')
plt.xlabel('Time (s)')
plt.ylabel('Output')
plt.legend()plt.subplot(2, 1, 2)
plt.plot(t, u, label='Control Input')
plt.xlabel('Time (s)')
plt.ylabel('Control Input')
plt.legend()plt.tight_layout()
plt.show()
代码解释
- 二阶电机数学模型:
second_order_motor_model函数定义了二阶电机的动力学方程。 - RBF神经网络:
rbf_network函数实现了RBF神经网络的计算,用于模拟非线性干扰。 - WNN预测:
wnn_predict函数使用MLPRegressor作为WNN的示例,用于预测非线性函数。 - 模拟过程:在模拟过程中,首先使用RBF神经网络预测非线性干扰,然后使用WNN预测非线性函数,最后将其从控制输入中抵消,更新系统状态。
- 结果绘制:使用
matplotlib绘制系统的输出和控制输入。
注意事项
- 代码中的RBF神经网络和WNN只是简单示例,实际应用中可能需要更复杂的网络结构和训练方法。
- 非线性干扰和迟滞影响的具体形式可以根据实际情况进行调整。
相关文章:
实现使用RBF(径向基函数)神经网络模拟二阶电机数学模型中的非线性干扰,以及使用WNN(小波神经网络)预测模型中的非线性函数来抵消迟滞影响的功能
下面将详细介绍如何实现使用RBF(径向基函数)神经网络模拟二阶电机数学模型中的非线性干扰,以及使用WNN(小波神经网络)预测模型中的非线性函数来抵消迟滞影响的功能。我们将按照以下步骤进行: 步骤1&#x…...
潜水泵,高效排水,守护城市与农田|深圳鼎跃
洪水是常见的自然灾害,在春夏季节的我国降水多为丰富,容易造成城市内部的洪涝灾害。特别是低洼地区的积水,不仅容易造成城市交通的出行不便,还存在潜在的隐患,严重影响了人们正常生活。 潜水泵作为一种高效、可靠的排水…...
易基因:RNA甲基化修饰和R-loop的交叉调控:从分子机制到临床意义|深度综述
大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 R-loop(RNA-DNA杂合结构)是转录调控、DNA复制和修复等关键细胞过程的重要组成部分。但R-loop异常积累可能会破坏基因组完整性,从而导致多种疾病的发生…...
115 道 MySQL 面试题,从简单到深入!
1. 什么是数据库事务? 数据库事务是一个作为单个逻辑工作单元执行的一系列操作。事务具有ACID属性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性…...
一周学会Flask3 Python Web开发-flask3上下文全局变量session,g和current_app
锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili flask3提供了session,g和current_app上下文全局变量来方便我们操作访问数据。 以下是一个表格,用于比较Flask中的…...
MFC学习笔记-1
一、编辑框和按钮 //.h文件private:CString str;//给窗口类加了一个变量(定义一个成员变量),关联到IDC_EDIT1中(要在实现中关联,源文件文件夹中)CString str2;//接收button2,和IDC_EDIT2绑定 p…...
Linux搜索查找类指令
1、find指令 基本语法:find [搜索范围] [选项] 功能:将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或目录显示在终端。 常用选项: 操作 命令示例 说明 查找指定路径下的所有文件 find /path/to/dir 查找指定目…...
江协科技/江科大-51单片机入门教程——P[1-1] 课程简介P[1-2] 开发工具介绍及软件安装
本教程也力求在玩好单片机的同时了解一些计算机的基本概念,了解电脑的一些基本操作,了解电路及其元器件的基本理论,为我们学习更高级的单片机,入门IT和信息技术行业,打下一定的基础。 目录 1.课程简介 2.开发工具及…...
监听load和hashchange事件
监听load和hashchange事件 上篇文章中,我们已经将菜谱的数据给拿到,并且已经可以渲染到页面上,本篇我们将为程序添加一些事件; 注:本项目来自于Jonas Schmedtmann创建,文章仅仅作为学习作用! 菜…...
深度剖析Seata源码:解锁分布式事务处理的核心逻辑
文章目录 写在文章开头如何使用源码(配置转掉)基于AT模式详解Seata全链路流程Seata服务端启动本地服务如何基于GlobalTransaction注解开启事务客户端如何开启分布式事务RM和TC如何协调处理分支事务RM生成回滚日志事务全局提交与回滚小结参考写在文章开头 在当今分布式系统日益…...
在 Ansys Mechanical 中解决干涉拟合
有意和无意的过盈配合在工程设计和有限元分析 (FEA) 中很常见。当两个组件重叠或接触时,就会发生这种情况,从而产生应力和变形,必须仔细分析以确保功能正常。有意干涉,例如轴和轴承之间的压配合或用于固定金…...
JMeter性能问题
性能测试中TPS上不去的几种原因 性能测试中TPS上不去的几种原因_tps一直上不去-CSDN博客 网络带宽 连接池 垃圾回收机制 压测脚本 通信连接机制 数据库配置 硬件资源 压测机 业务逻辑 系统架构 CPU过高什么原因 性能问题分析-CPU偏高 - 西瓜汁拌面 - 博客园 US C…...
美国国防部(DoD)SysML v2迁移指南项目
DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 分享一篇SysML v1向SysML v2迁移的资料。 下载地址:https://ndia.dtic.mil/wp-content/uploads/2023/systems/Thurs_1560710_Stirk.pdf 核心内容用DeepSeek整理如下&#…...
JavaWeb-GenericServlet源码分析(适配器/模板方法)
文章目录 类直接实现Servlet接口的弊端Servlet接口的方法适配器设计模式 适配器对象的改造关于init方法的ServletConfig对象来源使用模板方法设计模式改造init方法 GenericServlet内置抽象类ServletConfig接口ServletConfig接口简介测试再谈GenericServlet抽象类 类直接实现Ser…...
微机原理与汇编语言试题四
一、单项选择 1.(单选题)()指向的内存单元的值被CPU做为指令执行。 A. DS:SI B. CS:IP C. SS:SP D. ES:DI 正确答案:B 2.(单选题)当RESET信号进入高电平状态时,将使8086的()寄存器初始化为0FFFFH A. SS B. DS C. ES D. CS 正确答案:D 3.(单选题)堆栈段寄存器是( …...
[java基础-JVM篇]1_JVM自动内存管理
JVM内存管理涉及但不限于类加载、对象分配、垃圾回收等,本篇主要记录运行时数据区域与对象相关内容。 内容主要来源《深入理解Java虚拟机:JVM高级特性与最佳实践》与官方文档,理解与表述错漏之处恳请各位大佬指正。 目录 运行时数据区域 栈 栈…...
安宝特科技 | Vuzix Z100智能眼镜+AugmentOS:重新定义AI可穿戴设备的未来——从操作系统到硬件生态,如何掀起无感智能革命?
一、AugmentOS:AI可穿戴的“操作系统革命” 2025年2月3日,Vuzix与AI人机交互团队Mentra联合推出的AugmentOS,被业内视为智能眼镜领域的“iOS时刻”。这款全球首个专为智能眼镜设计的通用操作系统,通过三大突破重新定义了AI可穿戴…...
Unity FBXExport导出的FBX无法在Blender打开
将FBX转换为obj: Convert 3D models online - free and secure...
UE5销毁Actor,移动Actor,简单的空气墙的制作
1.销毁Actor 1.Actor中存在Destory()函数和Destoryed()函数 Destory()函数是成员函数,它会立即标记 Actor 为销毁状态,并且会从场景中移除该 Actor。它会触发生命周期中的销毁过程,调用 Destroy() 后,Actor 立即进入销毁过程。具体…...
【python】提取word\pdf格式内容到txt文件
一、使用pdfminer提取 import os import re from pdfminer.high_level import extract_text import docx2txt import jiebadef read_pdf(file_path):"""读取 PDF 文件内容:param file_path: PDF 文件路径:return: 文件内容文本"""try:text ext…...
深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...
《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》
引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...
DockerHub与私有镜像仓库在容器化中的应用与管理
哈喽,大家好,我是左手python! Docker Hub的应用与管理 Docker Hub的基本概念与使用方法 Docker Hub是Docker官方提供的一个公共镜像仓库,用户可以在其中找到各种操作系统、软件和应用的镜像。开发者可以通过Docker Hub轻松获取所…...
基于ASP.NET+ SQL Server实现(Web)医院信息管理系统
医院信息管理系统 1. 课程设计内容 在 visual studio 2017 平台上,开发一个“医院信息管理系统”Web 程序。 2. 课程设计目的 综合运用 c#.net 知识,在 vs 2017 平台上,进行 ASP.NET 应用程序和简易网站的开发;初步熟悉开发一…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...
基于当前项目通过npm包形式暴露公共组件
1.package.sjon文件配置 其中xh-flowable就是暴露出去的npm包名 2.创建tpyes文件夹,并新增内容 3.创建package文件夹...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
