三菱FX3U-PLC 前馈+PID闭环调节实现液压同步控制(比例换向阀)

42 篇文章 45 订阅 ¥399.90 ¥99.00

液压控制系统在工业现场应用非常广泛,这篇博文我们简单分析下液压同步控制。这套系统的液压缸为单液压缸。首先简单介绍下什么是单作用液压缸,液压系统的详细理论分析大家可以找些专业书籍学习。

单作用液压油缸:是一种将液压能转换为平移运动形式的机械能的装置。在压力作用下泵入液压缸体的液压流体迫使活塞移动并对油缸杆施加作用力。单作用液压缸仅在一个方向上传递力和运动。使用外部设备,例如弹簧、重物或其它相反安装的油缸,才可以将杆沿相反方向移动。

限于本人能力和水平,文中难免出现错误和不足之处,诚恳的欢迎大家批评和指正,同时感谢大家关注和订阅。

由于程序里用到了FX2N系列的模拟量模块,不太清楚的可以参看下面2篇博文,有详细的FB代码和讲解:

三菱FX3U PLC模拟量输出FB (FX2N-4DA)_RXXW_Dor的博客-CSDN博客FX2N-4DA模块由于比较老,不支持MOV G0\U0这样的访问方式,只能用传统的FROM TO指令。

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
液压缸模糊PID控制算法是一种基于模糊逻辑的控制方法,用于调节液压系统中的液压位置。该算法结合了传统的PID控制器和模糊控制器的优点,能够在系统动态性能和鲁棒性方面取得较好的效果。 液压缸模糊PID控制算法的步骤如下[^1]: 1. 设定目标位置和当前位置,计算位置误差(e)和误差变化率(de)。 2. 根据模糊控制器的模糊规则表,将位置误差和误差变化率映射到模糊集合中的隶属度。 3. 根据模糊规则表,计算模糊控制器的输出隶属度。 4. 将模糊控制器的输出隶属度转换为模糊控制器的输出值。 5. 根据PID控制器的参数(比例增益KP、积分时间TI、微分时间TD),计算PID控制器的输出值。 6. 将模糊控制器的输出值和PID控制器的输出值进行加权求和,得到最终的控制信号。 7. 将控制信号输入到液压系统中,调节液压缸的位置。 下面是一个示例代码,演示了如何使用Python实现液压缸模糊PID控制算法: ```python import numpy as np import skfuzzy as fuzz from skfuzzy import control as ctrl # 设定模糊控制器的输入和输出变量 error = ctrl.Antecedent(np.arange(-10, 10, 1), 'error') error_dot = ctrl.Antecedent(np.arange(-10, 10, 1), 'error_dot') output = ctrl.Consequent(np.arange(-10, 10, 1), 'output') # 定义模糊控制器的隶属函数 error['NB'] = fuzz.trimf(error.universe, [-10, -10, -5]) error['NM'] = fuzz.trimf(error.universe, [-10, -5, 0]) error['NS'] = fuzz.trimf(error.universe, [-5, 0, 5]) error['ZO'] = fuzz.trimf(error.universe, [0, 5, 10]) error['PS'] = fuzz.trimf(error.universe, [5, 10, 10]) error['PM'] = fuzz.trimf(error.universe, [0, 5, 10]) error['PB'] = fuzz.trimf(error.universe, [5, 10, 10]) error_dot['NB'] = fuzz.trimf(error_dot.universe, [-10, -10, -5]) error_dot['NM'] = fuzz.trimf(error_dot.universe, [-10, -5, 0]) error_dot['NS'] = fuzz.trimf(error_dot.universe, [-5, 0, 5]) error_dot['ZO'] = fuzz.trimf(error_dot.universe, [0, 5, 10]) error_dot['PS'] = fuzz.trimf(error_dot.universe, [5, 10, 10]) error_dot['PM'] = fuzz.trimf(error_dot.universe, [0, 5, 10]) error_dot['PB'] = fuzz.trimf(error_dot.universe, [5, 10, 10]) output['NB'] = fuzz.trimf(output.universe, [-10, -10, -5]) output['NM'] = fuzz.trimf(output.universe, [-10, -5, 0]) output['NS'] = fuzz.trimf(output.universe, [-5, 0, 5]) output['ZO'] = fuzz.trimf(output.universe, [0, 5, 10]) output['PS'] = fuzz.trimf(output.universe, [5, 10, 10]) output['PM'] = fuzz.trimf(output.universe, [0, 5, 10]) output['PB'] = fuzz.trimf(output.universe, [5, 10, 10]) # 定义模糊规则 rule1 = ctrl.Rule(error['NB'] & error_dot['NB'], output['NB']) rule2 = ctrl.Rule(error['NB'] & error_dot['NM'], output['NM']) rule3 = ctrl.Rule(error['NB'] & error_dot['NS'], output['NS']) rule4 = ctrl.Rule(error['NB'] & error_dot['ZO'], output['ZO']) rule5 = ctrl.Rule(error['NB'] & error_dot['PS'], output['PS']) rule6 = ctrl.Rule(error['NB'] & error_dot['PM'], output['PM']) rule7 = ctrl.Rule(error['NB'] & error_dot['PB'], output['PB']) # ... # 定义模糊控制器 fuzzy_ctrl = ctrl.ControlSystem([rule1, rule2, rule3, rule4, rule5, rule6, rule7, ...]) fuzzy_sim = ctrl.ControlSystemSimulation(fuzzy_ctrl) # 模拟控制过程 target_position = 10 current_position = 0 time = 0 while current_position != target_position and time < 100: # 计算位置误差和误差变化率 error_value = target_position - current_position error_dot_value = error_value - last_error_value # 设置模糊控制器的输入 fuzzy_sim.input['error'] = error_value fuzzy_sim.input['error_dot'] = error_dot_value # 运行模糊控制器 fuzzy_sim.compute() # 获取模糊控制器的输出 output_value = fuzzy_sim.output['output'] # 更新液压位置 current_position += output_value # 更新时间和上一次的误差值 time += 1 last_error_value = error_value # 输出最终的液压位置 print("Final position:", current_position) ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

RXXW_Dor

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值