File size: 8,397 Bytes
8b7c501
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/bin/sh
# Copyright 2021 Google LLC
#
# This source code is licensed under the BSD-style license found in the
# LICENSE file in the root directory of this source tree.

################################## ARM NEON ###################################
tools/xngen src/f16-f32-vcvt/neon-int16.c.in -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int16-x8.c &
tools/xngen src/f16-f32-vcvt/neon-int16.c.in -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int16-x16.c &
tools/xngen src/f16-f32-vcvt/neon-int16.c.in -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int16-x24.c &
tools/xngen src/f16-f32-vcvt/neon-int16.c.in -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int16-x32.c &

tools/xngen src/f16-f32-vcvt/neon-int32.c.in -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int32-x8.c &
tools/xngen src/f16-f32-vcvt/neon-int32.c.in -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int32-x16.c &
tools/xngen src/f16-f32-vcvt/neon-int32.c.in -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int32-x24.c &
tools/xngen src/f16-f32-vcvt/neon-int32.c.in -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neon-int32-x32.c &

tools/xngen src/f16-f32-vcvt/neonfp16.c.in -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neonfp16-x8.c &
tools/xngen src/f16-f32-vcvt/neonfp16.c.in -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-neonfp16-x16.c &

################################# x86 128-bit #################################
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int16-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int16-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int16-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int16-x32.c &

tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int32-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int32-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int32-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=2 -D AVX=0 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse2-int32-x32.c &

tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int16-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int16-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int16-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int16-x32.c &

tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int32-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int32-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int32-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=0 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-sse41-int32-x32.c &

tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int16-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int16-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int16-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int16.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int16-x32.c &

tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int32-x8.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int32-x16.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=24 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int32-x24.c &
tools/xngen src/f16-f32-vcvt/sse-int32.c.in -D SSE=4 -D AVX=1 -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx-int32-x32.c &

################################# x86 256-bit #################################
tools/xngen src/f16-f32-vcvt/f16c.c.in -D BATCH_TILE=8  -o src/f16-f32-vcvt/gen/f16-f32-vcvt-f16c-x8.c &
tools/xngen src/f16-f32-vcvt/f16c.c.in -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-f16c-x16.c &

################################# x86 512-bit #################################
tools/xngen src/f16-f32-vcvt/avx512skx.c.in -D BATCH_TILE=16 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx512skx-x16.c &
tools/xngen src/f16-f32-vcvt/avx512skx.c.in -D BATCH_TILE=32 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-avx512skx-x32.c &

################################## WAsm SIMD ##################################
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=8  -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int16-x8.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=16 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int16-x16.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=24 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int16-x24.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=32 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int16-x32.c &

tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=8  -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int16-x8.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=16 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int16-x16.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=24 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int16-x24.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int16.c.in -D BATCH_TILE=32 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int16-x32.c &

tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=8  -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int32-x8.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=16 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int32-x16.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=24 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int32-x24.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=32 -D RELAXED=0 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmsimd-int32-x32.c &

tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=8  -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int32-x8.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=16 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int32-x16.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=24 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int32-x24.c &
tools/xngen src/f16-f32-vcvt/wasmsimd-int32.c.in -D BATCH_TILE=32 -D RELAXED=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-wasmrelaxedsimd-int32-x32.c &

#################################### Scalar ###################################
tools/xngen src/f16-f32-vcvt/scalar.c.in -D BATCH_TILE=1 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-scalar-x1.c &
tools/xngen src/f16-f32-vcvt/scalar.c.in -D BATCH_TILE=2 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-scalar-x2.c &
tools/xngen src/f16-f32-vcvt/scalar.c.in -D BATCH_TILE=3 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-scalar-x3.c &
tools/xngen src/f16-f32-vcvt/scalar.c.in -D BATCH_TILE=4 -o src/f16-f32-vcvt/gen/f16-f32-vcvt-scalar-x4.c &

################################## Unit tests #################################
tools/generate-vcvt-test.py --spec test/f16-f32-vcvt.yaml --output test/f16-f32-vcvt.cc &

wait