1 /* 2 * Copyright (c) 2016, Alliance for Open Media. All rights reserved 3 * 4 * This source code is subject to the terms of the BSD 2 Clause License and 5 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License 6 * was not distributed with this source code in the LICENSE file, you can 7 * obtain it at www.aomedia.org/license/software. If the Alliance for Open 8 * Media Patent License 1.0 was not distributed with this source code in the 9 * PATENTS file, you can obtain it at www.aomedia.org/license/patent. 10 */ 11 12 #ifndef AOM_AV1_ENCODER_PUSTATS_H_ 13 #define AOM_AV1_ENCODER_PUSTATS_H_ 14 15 #ifdef __cplusplus 16 extern "C" { 17 #endif 18 19 #include "av1/encoder/ml.h" 20 21 #define NUM_FEATURES_PUSTATS 8 22 #define NUM_HIDDEN_LAYERS 2 23 #define HIDDEN_LAYERS_0_NODES 12 24 #define HIDDEN_LAYERS_1_NODES 10 25 #define LOGITS_NODES 1 26 27 static const float 28 av1_pustats_rate_hiddenlayer_0_kernel[NUM_FEATURES_PUSTATS * 29 HIDDEN_LAYERS_0_NODES] = { 30 -0.1758f, -0.0499f, -10.0069f, -2.2838f, -0.3359f, 0.3459f, -0.3285f, 31 -0.0515f, -0.5417f, 0.2357f, -0.0575f, -69.0782f, 0.5348f, 1.4068f, 32 0.2213f, -1.0490f, -0.0636f, 0.1654f, 1.1002f, 33.4924f, 0.4358f, 33 1.2499f, 0.1143f, 0.0592f, -1.6335f, -0.0092f, 1.2207f, -28.4543f, 34 -0.4973f, 0.4368f, 0.2341f, -0.1623f, -3.8986f, 0.1311f, -1.8789f, 35 -3.9079f, -0.8158f, -0.8420f, 1.4295f, -2.3629f, -1.4825f, 0.6498f, 36 -5.3669f, 6.4434f, 1.8393f, -35.0678f, 3.7459f, -2.8504f, 2.0502f, 37 -0.1812f, -3.9011f, -1.0155f, 1.8375f, -1.4517f, 1.3917f, 3.8664f, 38 0.8345f, -0.3472f, 5.7740f, -1.1196f, -0.3264f, -1.2481f, -0.9284f, 39 -4.9657f, 2.2831f, 0.7337f, 2.3176f, 0.6416f, 0.8804f, 1.9988f, 40 -1.3426f, 1.2728f, 1.2249f, -0.1551f, 5.6045f, 0.2046f, -2.1464f, 41 -2.4922f, -0.5334f, 12.1055f, 7.2467f, -0.0070f, 0.0234f, 0.0021f, 42 0.0215f, -0.0098f, -0.0682f, -6.1494f, -0.3176f, -1.6069f, -0.2119f, 43 -1.0533f, -0.3566f, 0.5294f, -0.4335f, 0.1626f, 44 }; 45 46 static const float av1_pustats_rate_hiddenlayer_0_bias[HIDDEN_LAYERS_0_NODES] = 47 { 48 10.5266f, 5.3268f, -1.0678f, 7.7411f, 8.7164f, -0.3235f, 49 7.3028f, 9.0874f, -6.4594f, -1.0102f, -1.1146f, 10.8419f, 50 }; 51 52 static const float 53 av1_pustats_rate_hiddenlayer_1_kernel[HIDDEN_LAYERS_0_NODES * 54 HIDDEN_LAYERS_1_NODES] = { 55 10.5932f, 2.5192f, -0.0015f, 5.9479f, 5.2426f, -0.4091f, 5.3220f, 56 6.0469f, 0.7200f, 3.3241f, 5.5006f, 12.8290f, -1.6396f, 0.5743f, 57 -0.8370f, 1.9956f, -4.9270f, -1.5295f, 2.1350f, -9.4415f, -0.7094f, 58 5.1822f, 19.7287f, -3.0444f, -0.3320f, 0.0031f, -0.2709f, -0.5249f, 59 0.3281f, -0.2240f, 0.2225f, -0.2386f, -0.4370f, -0.2438f, -0.4928f, 60 -0.2842f, -2.1772f, 9.2570f, -17.6655f, 3.5448f, -2.8394f, -1.0167f, 61 -0.5115f, -1.9260f, -0.2111f, -0.7528f, -1.2387f, -0.0401f, 5.0716f, 62 -3.3763f, -0.2898f, -0.4956f, -7.9993f, 0.1526f, -0.0242f, 0.7354f, 63 6.0432f, 4.8043f, 7.4790f, -0.6295f, 1.7565f, 3.7197f, -2.3963f, 64 6.8945f, 2.9717f, -3.1623f, 3.4241f, 4.4676f, -1.8154f, -2.9401f, 65 -8.5657f, -3.0240f, -1.4661f, 8.1145f, -12.7858f, 3.3624f, -1.0819f, 66 -4.2856f, 1.1801f, -0.5587f, -1.6062f, -1.1813f, -3.5882f, -0.2490f, 67 -24.9566f, -0.4140f, -0.1113f, 3.5537f, 4.4112f, 0.1367f, -1.5876f, 68 1.6605f, 1.3903f, -0.0253f, -2.1419f, -2.2197f, -0.7659f, -0.4249f, 69 -0.0424f, 0.1486f, 0.4643f, -0.9068f, -0.3619f, -0.7624f, -0.9132f, 70 -0.4947f, -0.3527f, -0.5445f, -0.4768f, -1.7761f, -1.0686f, 0.5462f, 71 1.3371f, 4.3116f, 0.0777f, -2.7216f, -1.8908f, 3.4989f, 7.7269f, 72 -2.7566f, 73 }; 74 75 static const float av1_pustats_rate_hiddenlayer_1_bias[HIDDEN_LAYERS_1_NODES] = 76 { 77 13.2435f, -8.5477f, -0.0998f, -1.5131f, -12.0187f, 78 6.1715f, 0.5094f, 7.6433f, -0.3992f, -1.3555f, 79 }; 80 81 static const float 82 av1_pustats_rate_logits_kernel[HIDDEN_LAYERS_1_NODES * LOGITS_NODES] = { 83 4.3078f, -17.3497f, 0.0195f, 34.6032f, -5.0127f, 84 5.3079f, 10.0077f, -13.129f, 0.0087f, -8.4009f, 85 }; 86 87 static const float av1_pustats_rate_logits_bias[LOGITS_NODES] = { 88 4.5103f, 89 }; 90 91 static const NN_CONFIG av1_pustats_rate_nnconfig = { 92 NUM_FEATURES_PUSTATS, // num_inputs 93 LOGITS_NODES, // num_outputs 94 NUM_HIDDEN_LAYERS, // num_hidden_layers 95 { HIDDEN_LAYERS_0_NODES, HIDDEN_LAYERS_1_NODES }, // num_hidden_nodes 96 { 97 av1_pustats_rate_hiddenlayer_0_kernel, 98 av1_pustats_rate_hiddenlayer_1_kernel, 99 av1_pustats_rate_logits_kernel, 100 }, 101 { 102 av1_pustats_rate_hiddenlayer_0_bias, 103 av1_pustats_rate_hiddenlayer_1_bias, 104 av1_pustats_rate_logits_bias, 105 }, 106 }; 107 108 static const float 109 av1_pustats_dist_hiddenlayer_0_kernel[NUM_FEATURES_PUSTATS * 110 HIDDEN_LAYERS_0_NODES] = { 111 -0.2560f, 0.1105f, -0.8434f, -0.0132f, -8.9371f, -1.1176f, -0.3655f, 112 0.4885f, 1.7518f, 0.4985f, 0.5582f, -0.3739f, 0.9403f, 0.3874f, 113 0.3265f, 1.7383f, 3.1747f, 0.0285f, 3.3942f, -0.0123f, 0.5057f, 114 0.1584f, 0.2697f, 4.6151f, 3.6251f, -0.0121f, -1.0047f, -0.0037f, 115 0.0127f, 0.1935f, -0.5277f, -2.7144f, 0.0729f, -0.1457f, -0.0816f, 116 -0.5462f, 0.4738f, 0.3599f, -0.0564f, 0.0910f, 0.0126f, -0.0310f, 117 -2.1311f, -0.4666f, -0.0074f, -0.0765f, 0.0287f, -0.2662f, -0.0999f, 118 -0.2983f, -0.4899f, -0.2314f, 0.2873f, -0.3614f, 0.1783f, -0.1210f, 119 0.3569f, 0.5436f, -8.0536f, -0.0044f, -1.5255f, -0.8247f, -0.4556f, 120 1.9045f, 0.5463f, 0.1102f, -0.9293f, -0.0185f, -0.8302f, -0.4378f, 121 -0.3531f, -1.3095f, 0.6099f, 0.7977f, 4.1950f, -0.0067f, -0.2762f, 122 -0.1574f, -0.2149f, 0.6104f, -1.7053f, 0.1904f, 4.2402f, -0.2671f, 123 0.8940f, 0.6820f, 0.2241f, -0.9459f, 1.4571f, 0.5255f, 2.3352f, 124 -0.0806f, 0.5231f, 0.3928f, 0.4146f, 2.0956f, 125 }; 126 127 static const float av1_pustats_dist_hiddenlayer_0_bias[HIDDEN_LAYERS_0_NODES] = 128 { 129 1.1597f, 0.0836f, -0.7471f, -0.2439f, -0.0438f, 2.4626f, 130 0.f, 1.1485f, 2.7085f, -4.7897f, 1.4093f, -1.657f, 131 }; 132 133 static const float 134 av1_pustats_dist_hiddenlayer_1_kernel[HIDDEN_LAYERS_0_NODES * 135 HIDDEN_LAYERS_1_NODES] = { 136 -0.5203f, -1.3468f, 0.3865f, -0.6859f, 0.0058f, 4.0682f, 0.4807f, 137 -0.1380f, 0.6050f, 0.8958f, 0.7748f, -0.1311f, 1.7317f, 1.1265f, 138 0.0827f, 0.1407f, -0.3605f, 0.5429f, 0.1880f, -0.1439f, 0.2837f, 139 1.6477f, 0.0832f, 0.0593f, -1.8464f, -0.7241f, -1.0672f, -0.3546f, 140 -0.3842f, -2.3637f, 0.2514f, 0.8263f, -0.1872f, 0.5774f, -0.3610f, 141 -0.0205f, 1.3977f, -0.1083f, 0.6923f, 1.3039f, -0.2870f, 1.0622f, 142 -0.0566f, 0.2697f, -0.5429f, -0.6193f, 1.7559f, 0.3246f, 1.9159f, 143 0.3744f, 0.0686f, 1.0191f, -0.4212f, 1.9591f, -0.0691f, -0.1085f, 144 -1.2034f, 0.0606f, 1.0116f, 0.5565f, -0.1874f, -0.7898f, 0.4796f, 145 0.2290f, 0.4334f, -0.5817f, -0.2949f, 0.1367f, -0.2932f, -1.1265f, 146 0.0133f, -0.5309f, -3.3191f, 0.0939f, 0.3895f, -2.5812f, -0.0066f, 147 -3.0063f, -0.2982f, 0.7309f, -0.2422f, -0.2770f, -0.7152f, 0.1700f, 148 1.9630f, 0.1988f, 0.4194f, 0.8762f, 0.3402f, 0.1051f, -0.1598f, 149 0.2405f, 0.0392f, 1.1256f, 1.5245f, 0.0950f, 0.2160f, -0.5023f, 150 0.2584f, 0.2074f, 0.2218f, 0.3966f, -0.0921f, -0.2435f, -0.4560f, 151 -1.1923f, -0.3716f, -0.3286f, -1.3225f, 0.1896f, -0.3342f, -0.7888f, 152 -0.4488f, -1.7168f, 0.3341f, 0.1146f, 0.5226f, 0.2610f, -0.4574f, 153 -0.4164f, 154 }; 155 156 static const float av1_pustats_dist_hiddenlayer_1_bias[HIDDEN_LAYERS_1_NODES] = 157 { 158 -2.3014f, -2.4292f, 1.3317f, -3.2361f, -1.918f, 159 2.7149f, -2.5649f, 2.7765f, 2.9617f, 2.7684f, 160 }; 161 162 static const float 163 av1_pustats_dist_logits_kernel[HIDDEN_LAYERS_1_NODES * LOGITS_NODES] = { 164 -0.6868f, -0.6715f, 0.449f, -1.293f, 0.6214f, 165 0.9894f, -0.4342f, 0.7002f, 1.4363f, 0.6951f, 166 }; 167 168 static const float av1_pustats_dist_logits_bias[LOGITS_NODES] = { 169 2.3371f, 170 }; 171 172 static const NN_CONFIG av1_pustats_dist_nnconfig = { 173 NUM_FEATURES_PUSTATS, // num_inputs 174 LOGITS_NODES, // num_outputs 175 NUM_HIDDEN_LAYERS, // num_hidden_layers 176 { HIDDEN_LAYERS_0_NODES, HIDDEN_LAYERS_1_NODES }, // num_hidden_nodes 177 { 178 av1_pustats_dist_hiddenlayer_0_kernel, 179 av1_pustats_dist_hiddenlayer_1_kernel, 180 av1_pustats_dist_logits_kernel, 181 }, 182 { 183 av1_pustats_dist_hiddenlayer_0_bias, 184 av1_pustats_dist_hiddenlayer_1_bias, 185 av1_pustats_dist_logits_bias, 186 }, 187 }; 188 189 #undef NUM_HIDDEN_LAYERS 190 #undef HIDDEN_LAYERS_0_NODES 191 #undef HIDDEN_LAYERS_1_NODES 192 #undef LOGITS_NODES 193 194 #ifdef __cplusplus 195 } // extern "C" 196 #endif 197 198 #endif // AOM_AV1_ENCODER_PUSTATS_H_ 199