|  | // Copyright (c) 2020, the Dart project authors.  Please see the AUTHORS file | 
|  | // for details. All rights reserved. Use of this source code is governed by a | 
|  | // BSD-style license that can be found in the LICENSE file. | 
|  |  | 
|  | /// A Dart implementation of two computation kernels used for skeletal | 
|  | /// animation. SIMD version. | 
|  |  | 
|  | // @dart=2.9 | 
|  |  | 
|  | import 'dart:typed_data'; | 
|  |  | 
|  | import 'package:benchmark_harness/benchmark_harness.dart'; | 
|  | import 'package:vector_math/vector_math_operations.dart'; | 
|  |  | 
|  | void main() { | 
|  | SkeletalAnimationSIMD().report(); | 
|  | } | 
|  |  | 
|  | class SkeletalAnimationSIMD extends BenchmarkBase { | 
|  | SkeletalAnimationSIMD() : super('SkeletalAnimationSIMD'); | 
|  |  | 
|  | final Float32x4List A = Float32x4List(4); | 
|  | final Float32x4List B = Float32x4List(4); | 
|  | final Float32x4List C = Float32x4List(4); | 
|  | final Float32x4List D = Float32x4List(1); | 
|  | final Float32x4List E = Float32x4List(1); | 
|  |  | 
|  | @override | 
|  | void run() { | 
|  | for (int i = 0; i < 100; i++) { | 
|  | Matrix44SIMDOperations.multiply(C, 0, A, 0, B, 0); | 
|  | Matrix44SIMDOperations.transform4(E, 0, A, 0, D, 0); | 
|  | } | 
|  | } | 
|  | } |