Burst文档和示例较少,除了Job方式调用外,也是可以直接调用的。

以下是对球体的所有顶点生成uv的示例代码,用burst大概加速50%。

using System.Runtime.CompilerServices;
using Unity.Burst;
using Unity.Mathematics;

[BurstCompile]
public static class ParallelMethods
{
    [MethodImpl(MethodImplOptions.NoInlining)]
    [BurstCompile]
    public static unsafe void GenUVs([NoAlias] in float3* vertices, [NoAlias] float2* uvs,
        int count)
    {
        for (var i = 0; i < count; i += 1)
        {
            // Unity.Burst.CompilerServices.Loop.ExpectVectorized(); 无效

            var p = vertices[i];
            var longitude = math.atan2(p.z, p.x);
            var latitude = math.asin(p.y);
            uvs[i].x = longitude / math.PI2 + 0.5f;
            uvs[i].y = latitude / math.PI + 0.5f;
        }
    }

直接调用方法如下:

void Update()
{
    UVs = new Vector2[vertices.Length];
    unsafe
    {
        fixed (Vector3* vts = vertices)
        {
            fixed (Vector2* uvs = UVs)
            {
                ParallelMethods.GenUVs((float3*)vts, (float2*)uvs, vertices.Length);
            }
        }
    }
}

[NoAlias]是为了告诉Burst这个指针和其他指针没有交叉,可以放心向量化。如果用NativeArray会自动判断不需要这玩意,这里因为用的是自己的指针,所以最好加一下。

Burst生成向量化的代码限制很多,且并行数量少,建议还是用Computer Shader来做,还可以再加速50%。