HHT-α法(Hilber-Hughes-Taylor)
理论与物理
HHT-α法是什么
老师,HHT-α法是Newmark法的改进版吗?
是的。Hilber, Hughes, Taylor(1977)在Newmark法的基础上增加了数值衰减参数 $\alpha$。是Abaqus和Ansys的默认时间积分法。
Newmark法的问题点
Newmark法($\beta=1/4, \gamma=1/2$)具有二阶精度且无条件稳定,但数值耗散为零。高频数值噪声一旦产生就永远不会消失。接触冲击或急剧的载荷变化容易产生高频噪声。
高频噪声不消失的话很麻烦啊。
HHT-α法解决了这个问题。在保持低频精度的同时,选择性地衰减高频成分。
HHT-α法的算法
修正后的运动方程:
参数关系:
当 $\alpha = 0$ 时就与Newmark法一致了呢。
$\alpha$ 的范围是 $-1/3 \leq \alpha \leq 0$。$\alpha = 0$: 无衰减(Newmark法)。$\alpha = -0.05$: 温和的高频衰减。$\alpha = -1/3$: 最大的高频衰减(但精度会下降)。
实践推荐: $\alpha = -0.05$ 左右。这样可以保持二阶精度,同时有效衰减高频噪声。
Abaqus
```
*DYNAMIC, ALPHA=-0.05 $ HHT-α的α值
0.001, 1.0
```
Abaqus的默认值相当于 $\alpha = -0.05$(APPLICATION=MODERATE DISSIPATION)。
Ansys
```
TINTP, , , , , 0.05 $ γ = 1/2 + 0.05 → 相当于α
```
Ansys中使用TINTP命令设置Newmark参数。γ > 1/2 时产生数值衰减。
Nastran
```
PARAM, NDAMP, 0.01 $ 数值衰减参数
```
总结
要点:
- Newmark法 + 数值衰减 $\alpha$ — 选择性衰减高频噪声
- 推荐 $\alpha = -0.05$ — 保持二阶精度的同时抑制高频
- Abaqus/Ansys的默认设置 — 很多情况下是在无意识中使用
- $\alpha = 0$ 时退化为Newmark法 — 无数值衰减
- 接触或急剧载荷变化产生高频噪声时,HHT-α法有效
原来很多工程师是在“不知不觉中使用”HHT-α法啊。
Abaqus的*DYNAMIC默认就是HHT-α法。即使不改变设置,也会自动加入适当的数值衰减。不过,理解$\alpha$的值有助于在出现噪声时进行调整。
HHT-α是1977年诞生的数值衰减方案
Hilber・Hughes・Taylor于1977年发表的HHT-α算法,扩展了Newmark-β法,选择性地只衰减高频成分。α参数的范围是−1/3≦α≦0,α=0时与Newmark法一致,α=−0.1左右可以在抑制高频噪声的同时保持二阶精度和无条件稳定性。Abaqus的*DYNAMIC过程默认采用α=−0.05,已成为建筑结构地震响应计算的实际标准。
各项的物理意义
- 惯性项(质量项):$\rho \ddot{u}$,即“质量×加速度”。您是否有过急刹车时身体被向前甩出的经历?那种“被带走的感觉”正是惯性力。物体越重越难启动,一旦启动也越难停止。建筑物在地震中摇晃,也是因为地面突然移动,而建筑物的质量“被落下”。静力分析中此项设为零,这是“缓慢施加载荷,加速度可忽略”的假设。但在冲击载荷或振动问题中绝对不能省略。
- 刚度项(弹性恢复力):$Ku$ 或 $\nabla \cdot \sigma$。拉伸弹簧时能感觉到“想要恢复原状的力”吧?那就是胡克定律 $F=kx$,也是刚度项的本质。那么提问——用相同的力拉伸铁棒和橡皮筋,哪个伸得更长?当然是橡皮筋。这种“不易拉伸的程度”就是杨氏模量 $E$,它决定了刚度。常见的误解:“刚度高=强度高”是不对的。刚度是“不易变形的程度”,强度是“不易破坏的程度”,是不同的概念。
- 外力项(载荷项):体积力 $f_b$(重力等)和表面力 $f_s$(压力、接触力等)。可以这样想——桥上卡车的重量是“作用在整个内容物上的力”(体积力),轮胎压路面的力是“只作用在表面的力”(表面力)。风压、水压、螺栓紧固力…都是外力。这里容易犯的错误:弄错载荷方向。本想“拉伸”却变成了“压缩”——听起来像笑话,但在3D空间中坐标系发生旋转时确实会发生。
- 阻尼项:瑞利阻尼 $C\dot{u} = (\alpha M + \beta K)\dot{u}$。试着弹一下吉他弦。声音会一直持续吗?不,会逐渐变小。这是因为振动能量通过空气阻力或弦的内部摩擦转化成了热能。汽车的减震器也是同样原理——故意吸收振动能量来提高乘坐舒适性。如果阻尼为零会怎样?建筑物在地震后会一直摇晃不停。实际上不会这样,所以设置适当的阻尼很重要。
假设条件与适用范围
量纲分析与单位制
| 变量 | SI单位 | 注意点・换算备忘 |
|---|---|---|
| 位移 $u$ | m(米) | 以mm输入时,载荷・弹性模量也要统一为MPa/N系 |
| 应力 $\sigma$ | Pa(帕斯卡)= N/m² | MPa = 10⁶ Pa。与屈服应力比较时注意单位制不一致 |
| 应变 $\varepsilon$ | 无量纲(m/m) | 注意工程应变与对数应变的区别(大变形时) |
| 弹性模量 $E$ | Pa | 钢: 约210 GPa,铝: 约70 GPa。注意温度依赖性 |
| 密度 $\rho$ | kg/m³ | mm系中是tonne/mm³(钢为 = 10⁻⁹ tonne/mm³) |
| 力 $F$ | N(牛顿) | mm系用N,m系也用N统一 |
数值解法与实现
HHT-α法的数值特性
请详细讲解一下HHT-α法的数值特性。
| $\alpha$ | 数值衰减 | 精度 | 用途 |
|---|---|---|---|
| 0 | 无 | 2阶 | 纯粹的Newmark法 |
| -0.05 | 温和 | 接近2阶 | 推荐(标准) |
| -0.1 | 中等 | 略有下降 | 噪声较多的问题 |
| -0.33 | 最大 | 接近1阶 | 仅限特殊用途 |
$\alpha$ 比 -0.1 更负的话精度就会下降呢。
数值衰减也会影响低频。$|\alpha|$ 越大,低频响应衰减也越多。$\alpha = -0.05$ 是“衰减高频,低频几乎不受影响”的良好平衡点。
与广义α法的关系
Chung-Hulbert(1993)的广义α法进一步推广了HHT-α法。可以独立控制低频精度和高频衰减。Abaqus的APPLICATION=MODERATE DISSIPATION基于广义α法。
总结
α的选择会影响分析精度
将HHT-α的α设为−0.05〜−0.10时,数值阻尼比ξnum在最高阶模态约为数%〜10%。α过小(例:α=−0.3)会连物理性的低阶模态也一起衰减,因此在建筑结构中,最好让衰减从固有周期0.01s以下的模态开始生效。MSC Nastran的SOL 109直接瞬态响应分析中,可以通过DTI,DIRECTT,ALPHA卡片设置HHT-α。
线性单元(1阶单元)
节点间进行线性插值。计算成本低,但应力精度低。注意剪切锁定(可通过减缩积分或B-bar法缓解)。
2阶单元(带中间节点)
可以表现曲线变形。应力精度大幅提高,但自由度约增加2〜3倍。推荐:应力评估很重要的情况。
完全积分 vs 减缩积分
完全积分:有过约束(锁定)风险。减缩积分:有沙漏模式(零能量模式)风险。根据情况选择合适的方法。
自适应网格
基于误差指标(ZZ估计量等)的自动细化。有效提高应力集中部位的精度。有h法(单元细分)和p法(增加阶次)两种。
牛顿・拉弗森法
非线性分析的标准方法。每次迭代更新切线刚度矩阵。在收敛半径内具有二阶收敛性,但计算成本高。
修正牛顿・拉弗森法
切线刚度矩阵使用初始值或每隔数次迭代更新。每次迭代成本低,但收敛速度为线性。
收敛判定标准
力残差范数: $||R|| / ||F_{ext}|| < \epsilon$(通常 $\epsilon = 10^{-3}$〜$10^{-6}$)。位移增量范数: $||\Delta u|| / ||u|| < \epsilon$。能量范数: $\Delta u \cdot R < \epsilon$
载荷增量法
不一次性施加全部载荷,而是分小步增加。弧长法(Riks法)可以越过载荷-位移关系的极值点进行追踪。
直接法 vs 迭代法的比喻
直接法是“用笔算精确解联立方程”的方法——可靠但大规模问题耗时过长。迭代法是“反复猜测逼近正确答案”的方法——最初答案粗糙,但每次迭代精度都会提高。就像查字典时,从第一页开始顺序查找(直接法)不如先估计大致位置翻开,再前后调整(迭代法)来得高效,原理相同。
网格阶次与精度的关系
1阶单元是“用直尺近似曲线”——用直线折线表现,精度有限。2阶单元是“柔性曲线”——可以表现曲线变化,即使网格密度相同,精度也显著提高。但是,每个单元的计算成本增加,需要根据总体的成本效益来判断。
实践指南
HHT-α法的实践
实践中,“有意识地使用HHT-α法”的场景有限。大部分情况下交给求解器的默认设置即可。
应调整$\alpha$的场景
| 情况 | $\alpha$的调整 |
|---|---|
| 响应中包含高频噪声 | 加强至 $\alpha = -0.1$ |
| 低频精度很重要(颤振等) | 恢复为 $\alpha = 0$(Newmark法) |
| 接触冲击产生尖峰噪声 | 设为 $\alpha = -0.05 \sim -0.1$ |
| 默认设置没有问题 | 无需更改 |