Twiddle算法的简单Demo

本文介绍了Twiddle算法在PID控制器参数调优中的应用。该算法通过逐步调整参数,寻找最优参数集,避免了计算高维函数梯度的复杂性。以伪Python代码展示了如何使用Twiddle算法对PID参数进行优化,通过迭代和比较误差,不断更新参数,直至误差低于预设阈值。相比梯度下降法,Twiddle算法的优势在于其简单易实现。

1.简单说明

Twiddle算法可以为一个计算误差的算法A去找到一个好的参数P。比如在PID调参中,一次调整一个参数,最终生成最优参数集,实现最优参数的搜索。

相较于梯度下降之类的算法的话,最大的优点就应该是简单了吧,不用去计算高维函数的梯度。

Talk is cheap, show me the code!

2.代码说明

下面写一段伪Python代码来说明一下,在这里的话以PID为例。

# 我们为PID算法选取初始化参数构成参数向量p,顺序依次为拍P->I->D
# 因为这也符合PID整定的一般规则,先比例,后积分,再微分。
p = [0, 0, 0]
# 在这里我们定义初始的变化量
dp = [1, 1, 1]
# 这里的A(p)是计算误差的算法
best_err = A(p)

# 我们将误差的阈值设置为0.1,
threshold = 0.1

#如果dp的变化量和比我们设置的阈值大的话,执行循环操作
while sum(dp) > threshold:
    for i in range(len(p)):
        p[i] += dp[i]
        err = A(p)

        if err < best_err:  # 误差比目前最好的误差更小则更新最好误差值
            best_err = err
            dp[i] *= 1.1
        else:  # 不然的话我们就将目前的参数朝另一个方向进行计算(这里减去2倍是因为刚才加了1次)
            p[i] -= 2 * dp[i]  
            err = A(p)

            if err < best_err:  # 误差变优的话则更新
                best_err = err
                dp[i] *= 1.05
            else:  # 不然的话就说明目前的变化值设计的太大,既不能There was no improvement
                p[i] += dp[i] # 这一步是为了让p[i]返回到这次循环前的值,即不加不减
                dp[i] *= 0.95 # 减小变化值继续反复更新参数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值