求多个四元数的平均数

四元数平均算法

最近要对前几帧数据进行平均数采样。所以又造了一个轮子

 

此方法经过一些单数和双数的基本测试,并且解决了无效四元数的问题,基本可用:

public static Quaternion Average(Quaternion[] quatArray)
{
    var result = new Quaternion();
    var count = quatArray.Length;
    var error = 0;

    while (count > 1)
    {
        if (error >= 10000) break;
        error++;
        var k = 0;
        for (int i = 0; i + 1 < count; i += 2)
        {
            var a = quatArray[i];
            var b = quatArray[i + 1];

            if (Quaternion.Dot(a, a) < Quaternion.kEpsilon)
                a = Quaternion.identity;

            if (Quaternion.Dot(b, b) < Quaternion.kEpsilon)
                b = Quaternion.identity;

            var avgQuat = Quaternion.LerpUnclamped(a, b, 0.5f);

            quatArray[k] = avgQuat;
            k++;
        }

        var lastCount = count;
        count = k;

        if ((lastCount & 1) == 1)
        {
            k++;
            count++;
            quatArray[k] = quatArray[lastCount - 1];
        }
    }

    result = quatArray[0];

    return result;
}

 

转载于:https://www.cnblogs.com/hont/p/6295311.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值