
matplotlib 在绘制多条曲线时,若数据量级差异巨大,自动缩放的 y 轴范围可能掩盖小幅变化——看似“扁平”的线条实为有效信号被极端数值压缩所致,本质是坐标轴尺度失配而非数据或绘图逻辑错误。
在你提供的代码中,FTBS_nonlin_out[0.0](初始时刻的解)本应是一段局部正弦扰动(由 shape = lambda x: 5*np.sin(x/np.pi) 定义,幅值约 ±5),但当它与 FTBS_nonlin_out[4](t=4 时刻的演化结果)同图绘制时,后者因 FTBS 格式在非线性对流问题中缺乏耗散控制,叠加时间步长(dt=0.5)与空间步长(dx=1.0)不满足 CFL 条件(CFL = c·dt/dx = 0.5
而 FTBS_nonlin_out[2](t=2)尚未发生严重失稳,其数值仍在合理区间(≈ −25 到 5),因此与 FTBS_nonlin_out[0.0] 同图时,y 轴自动适配为紧凑范围,初始扰动得以清晰展现。
✅ 验证与修复建议:
-
始终检查数据实际范围
在绘图前打印关键列的统计信息:print("t=0.0:", FTBS_nonlin_out[0.0].describe()) print("t=4:", FTBS_nonlin_out[4].describe()) print("t=2:", FTBS_nonlin_out[2].describe()) -
显式限制 y 轴范围(临时诊断)
强制聚焦关注区域,确认“扁平线”是否真实存在:ax1.plot(FTBS_nonlin_out[0.0]) ax1.plot(FTBS_nonlin_out[4]) ax1.set_ylim(-30, 30) # 或 ax1.set_ylim(*np.percentile(FTBS_nonlin_out[[0.0,4]], [1,99]))
-
根本性改进:提升数值稳定性
- ✅ 减小时间步长:将 dt=0.5 降至 0.1 或更小(CFL ≈ 0.1),显著抑制非线性失稳;
- ✅ 添加人工粘性或使用更稳健格式:如 Lax-Friedrichs、ENO/WENO,或改用 scipy.integrate.solve_ivp 配合隐式方法;
- ✅ 初始化与边界处理优化:当前 FTBS_nonlin 对 i=0 未定义(跳过首行),但边界条件缺失可能导致反射误差累积。
绘图最佳实践
避免跨量级数据直接混绘;推荐分图对比(subplots(nrows=2))或使用双 y 轴(twinx())并明确标注量纲。
⚠️ 注意:该现象并非 Matplotlib Bug,而是科学计算可视化中的经典陷阱——“看不见的信号,往往不是不存在,而是被坐标轴吞没了。” 始终以数据探查为绘图前提,是避免此类误导的关键。










