当前位置: 首页 > news >正文

行星齿轮非线性程序:相图、庞加莱与分叉图

行星齿轮非线性程序,能出相图,庞加莱,分叉图。

行星齿轮系统这玩意儿搞动力学分析,满屏都是非线性项。刚接触那会儿看着微分方程头皮发麻,后来发现直接数值求解才是真香。咱今天就拿Python撸个能出相图、庞加莱截面和分叉图的脚本,手把手看看这非线性系统能整出什么活。

先上核心代码骨架:

import numpy as np from scipy.integrate import odeint import matplotlib.pyplot as plt mu = 0.1 # 阻尼比 k = 10.0 # 刚度 omega_n = np.sqrt(k) # 固有频率 Omega = 0.8 * omega_n # 激励频率 F = 0.5 # 激励幅值 def system(y, t): x, dx = y ddx = -mu*dx - k*x + F*np.cos(Omega*t) + 0.1*x**3 # 含三次非线性项 return [dx, ddx] t = np.linspace(0, 1000, 50000) # 长时间仿真 sol = odeint(system, [0.1, 0], t)

这段代码把行星齿轮常见的非线性因素——三次刚度项给塞进去了。注意时间序列取得特别长,这是为了后面取庞加莱截面时能过滤掉瞬态响应。不过直接画相图的话得截取后面稳定段:

# 截取稳定段 x, dx = sol[-2000:,0], sol[-2000:,1] plt.plot(x, dx, ',k', alpha=0.5) plt.xlabel('Displacement') plt.ylabel('Velocity') plt.title('Phase Portrait')

跑出来的相图要是出现个极限环,说明系统在做周期性振动。但要是看到轨迹开始乱窜,那可能进入混沌状态了——这时候就该庞加莱截面出场了。

取庞加莱截面的骚操作在于按激励周期采样:

# 计算激励周期对应的采样间隔 T = 2*np.pi / Omega dt = t[1] - t[0] stride = int(T/dt) # 取截面点 poincare_x = x[::stride] poincare_dx = dx[::stride] plt.figure() plt.plot(poincare_x, poincare_dx, '.r', markersize=2) plt.title('Poincare Section')

当庞加莱截面呈现孤立点时是周期运动,出现成片的点云可能就混沌了。不过最直观的还是分叉图——看参数变化时系统如何从老实变癫狂:

bifurcation = [] omega_range = np.linspace(0.5, 2.0, 300) for Om in omega_range: # 每次微调参数重新仿真 def local_system(y, t): x, dx = y ddx = -mu*dx -k*x + F*np.cos(Om*t) + 0.1*x**3 return [dx, ddx] sol = odeint(local_system, [0.1,0], t) x = sol[-2000:,0] # 记录局部极值 peaks = (x[1:-1] > x[:-2]) & (x[1:-1] > x[2:]) bifurcation.append(x[1:-1][peaks]) plt.figure() for i, Om in enumerate(omega_range): plt.plot([Om]*len(bifurcation[i]), bifurcation[i], ',k', markersize=0.1) plt.title('Bifurcation Diagram')

这段分叉图代码有个坑:参数循环时每次都要重新定义微分方程。如果直接修改外层变量会导致闭包问题,所以得在循环内部重新定义local_system。当分叉图从单支分裂成多支,说明系统开始出现倍周期分叉——这是进入混沌的前戏。

跑完这三板斧,基本上能把行星齿轮的非线性特性摸个大概。不过实际工程中参数选择更讲究,比如阻尼比μ别超过0.3,否则啥非线性现象都给你压没了。另外激励频率Ω在固有频率附近最容易出活,调参时可以重点照顾这个区间。

http://www.jsqmd.com/news/116669/

相关文章:

  • 医疗健康领域应用:Linly-Talker构建智能导诊数字人
  • 打造虚拟主播不再难,Linly-Talker全栈解决方案来了
  • Linly-Talker语音克隆功能实测:1分钟复刻你的声音
  • 智慧城市之城市环境智能监管 非法倾倒行为自动识别 环保执法证据采 垃圾倾倒倾倒物品类型识别数据据 垃圾堆识别数据集 公路垃圾识别10315期
  • Linly-Talker在药品使用说明中的逐条强调播放设计
  • Linly-Talker边缘计算部署可行性研究:端侧推理优化方案
  • 无需动捕设备!Linly-Talker通过语音驱动面部动画
  • 1.99亿,济南低空应急救援及城市生命线监测感知数字化建设工程(信息化部分)
  • 伪代码示意
  • Linly-Talker生成视频的绿幕抠像精度评估与改进
  • 从GitHub到生产环境:Linly-Talker容器化部署最佳实践
  • Chromium143原生支持HLS
  • Comsol周期性超表面多极子分解仿真:模型、公式与图解教程
  • Linly-Talker适合中小企业吗?ROI成本收益分析
  • 用西门子TIA Portal玩转电梯仿真:五层楼全自动控制实战
  • Linly-Talker语音识别模块(ASR)精准度实测分析
  • Linly-Talker数字人系统:一张照片生成会说话的AI虚拟主播
  • 计算系统安全速成之系统级I/O【11】
  • 当热流遇上代码:COMSOL与Maxwell的工程实践
  • Xshell SSH 连接故障排查
  • 自动驾驶的工况下,基于perscan、simulink和carsim联合仿真的避障模型,实现预...
  • COMSOL 实现任意偏振态 BIC:扭转光子晶体调控远场偏振之旅
  • 用Linly-Talker生成教育讲解视频,老师效率提升300%
  • 一维光子晶体的zak相位计算 (内含comsol文件和matlab程序) 注意:这个是重复别人...
  • 转行具身最好的机会在昨天,其次是现在...
  • 【前端知识点总结】Web身份认证 Cookie vs .Token
  • 46、监控与管理 Windows Server 2008 全攻略
  • 制动系统建模仿真和ABS控制器设计文档与Simulink模型,以两自由度单轮模型为例
  • 类和对象随笔(注:后要精简笔记)
  • CFD/DDPM接口Fluent和EDEM耦合案例:传热颗粒水流动