news 2026/4/22 18:20:58

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
行星齿轮非线性程序:相图、庞加莱与分叉图

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

行星齿轮系统这玩意儿搞动力学分析,满屏都是非线性项。刚接触那会儿看着微分方程头皮发麻,后来发现直接数值求解才是真香。咱今天就拿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,否则啥非线性现象都给你压没了。另外激励频率Ω在固有频率附近最容易出活,调参时可以重点照顾这个区间。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 17:30:45

伪代码示意

利用CST对三维超材料的能带计算程序刚接触超材料能带计算那会儿,被三维结构搞得头皮发麻。传统平面结构的Floquet模式分析套路在立方体、金字塔这些立体结构面前直接失效。摸索了两个月,终于搞定了CST里三维能带计算的完整流程,这里把踩过的坑…

作者头像 李华
网站建设 2026/4/23 13:12:16

Comsol周期性超表面多极子分解仿真:模型、公式与图解教程

Comsol周期性超表面多极子分解仿真 (注意区分与单个散射体的区别,单个散射体多极子分解见主页其他案例) 附赠一键使用教学。 包含三个模型,包含公式总结、Comsol程序以及matlab绘图。 包含matlab作图和comsol直接出图两种版本。周期性超表面多极子分解&a…

作者头像 李华
网站建设 2026/4/23 13:19:19

玩COMSOL的老司机都知道,表面增强拉曼散射(SERS)的核心戏法全在局域电场增强上。今天咱们不整虚的,直接上干货聊聊怎么用波动光学模块调教纳米结构

COMSOL表面增强拉曼散射。 概述:通过仿真表面增强基底的局域表面电场分布,研究衬底材料、基底形貌和尺寸等对表面增强基底局域电场强度的影响,为后续制备高增强效果的表面增强基底提供理论指导。 建模:设置表面增强基底的形貌和尺寸&#xff…

作者头像 李华
网站建设 2026/4/23 13:15:40

Linly-Talker在法院庭审记录回放中的当事人代理演示

Linly-Talker在法院庭审记录回放中的当事人代理演示 在一场民事纠纷的庭审中,一位年迈的当事人因紧张和方言口音,陈述时语句断续、逻辑不清。书记员的笔录虽然完整,但读来生硬晦涩,连法官也不得不反复确认其真实意思。而当庭播放录…

作者头像 李华
网站建设 2026/4/23 13:33:23

真心建议大家冲一冲新兴领域,工资高前景好

据中国基金报报道,某招聘平台显示,杭州深度求索人工智能(AI)基础技术研究有限公司(即DeepSeek),发布了多个岗位的招聘信息。在DeepSeek挂出的职位中,大部分岗位的起薪在3万元以上&am…

作者头像 李华
网站建设 2026/4/23 13:31:59

46、监控与管理 Windows Server 2008 全攻略

监控与管理 Windows Server 2008 全攻略 在 Windows Server 2008 的管理与维护中,监控系统性能、管理磁盘以及进行数据备份恢复是至关重要的环节。下面将详细介绍相关的工具和操作方法。 数据收集集的使用 实时数据虽然有用,但很多时候我们需要一段时间跨度的数据来为服务器…

作者头像 李华