yuv.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #include "yuv.h"
  15. #include "esp_attr.h"
  16. typedef struct {
  17. int16_t vY;
  18. int16_t vVr;
  19. int16_t vVg;
  20. int16_t vUg;
  21. int16_t vUb;
  22. } yuv_table_row;
  23. static const yuv_table_row yuv_table[256] = {
  24. // Y Vr Vg Ug Ub // #
  25. { -18, -204, 50, 104, -258 }, // 0
  26. { -17, -202, 49, 103, -256 }, // 1
  27. { -16, -201, 49, 102, -254 }, // 2
  28. { -15, -199, 48, 101, -252 }, // 3
  29. { -13, -197, 48, 100, -250 }, // 4
  30. { -12, -196, 48, 99, -248 }, // 5
  31. { -11, -194, 47, 99, -246 }, // 6
  32. { -10, -193, 47, 98, -244 }, // 7
  33. { -9, -191, 46, 97, -242 }, // 8
  34. { -8, -189, 46, 96, -240 }, // 9
  35. { -6, -188, 46, 95, -238 }, // 10
  36. { -5, -186, 45, 95, -236 }, // 11
  37. { -4, -185, 45, 94, -234 }, // 12
  38. { -3, -183, 44, 93, -232 }, // 13
  39. { -2, -181, 44, 92, -230 }, // 14
  40. { -1, -180, 44, 91, -228 }, // 15
  41. { 0, -178, 43, 91, -226 }, // 16
  42. { 1, -177, 43, 90, -223 }, // 17
  43. { 2, -175, 43, 89, -221 }, // 18
  44. { 3, -173, 42, 88, -219 }, // 19
  45. { 4, -172, 42, 87, -217 }, // 20
  46. { 5, -170, 41, 86, -215 }, // 21
  47. { 6, -169, 41, 86, -213 }, // 22
  48. { 8, -167, 41, 85, -211 }, // 23
  49. { 9, -165, 40, 84, -209 }, // 24
  50. { 10, -164, 40, 83, -207 }, // 25
  51. { 11, -162, 39, 82, -205 }, // 26
  52. { 12, -161, 39, 82, -203 }, // 27
  53. { 13, -159, 39, 81, -201 }, // 28
  54. { 15, -158, 38, 80, -199 }, // 29
  55. { 16, -156, 38, 79, -197 }, // 30
  56. { 17, -154, 37, 78, -195 }, // 31
  57. { 18, -153, 37, 78, -193 }, // 32
  58. { 19, -151, 37, 77, -191 }, // 33
  59. { 20, -150, 36, 76, -189 }, // 34
  60. { 22, -148, 36, 75, -187 }, // 35
  61. { 23, -146, 35, 74, -185 }, // 36
  62. { 24, -145, 35, 73, -183 }, // 37
  63. { 25, -143, 35, 73, -181 }, // 38
  64. { 26, -142, 34, 72, -179 }, // 39
  65. { 27, -140, 34, 71, -177 }, // 40
  66. { 29, -138, 34, 70, -175 }, // 41
  67. { 30, -137, 33, 69, -173 }, // 42
  68. { 31, -135, 33, 69, -171 }, // 43
  69. { 32, -134, 32, 68, -169 }, // 44
  70. { 33, -132, 32, 67, -167 }, // 45
  71. { 34, -130, 32, 66, -165 }, // 46
  72. { 36, -129, 31, 65, -163 }, // 47
  73. { 37, -127, 31, 65, -161 }, // 48
  74. { 38, -126, 30, 64, -159 }, // 49
  75. { 39, -124, 30, 63, -157 }, // 50
  76. { 40, -122, 30, 62, -155 }, // 51
  77. { 41, -121, 29, 61, -153 }, // 52
  78. { 43, -119, 29, 60, -151 }, // 53
  79. { 44, -118, 28, 60, -149 }, // 54
  80. { 45, -116, 28, 59, -147 }, // 55
  81. { 46, -114, 28, 58, -145 }, // 56
  82. { 47, -113, 27, 57, -143 }, // 57
  83. { 48, -111, 27, 56, -141 }, // 58
  84. { 50, -110, 26, 56, -139 }, // 59
  85. { 51, -108, 26, 55, -137 }, // 60
  86. { 52, -106, 26, 54, -135 }, // 61
  87. { 53, -105, 25, 53, -133 }, // 62
  88. { 54, -103, 25, 52, -131 }, // 63
  89. { 55, -102, 25, 52, -129 }, // 64
  90. { 57, -100, 24, 51, -127 }, // 65
  91. { 58, -98, 24, 50, -125 }, // 66
  92. { 59, -97, 23, 49, -123 }, // 67
  93. { 60, -95, 23, 48, -121 }, // 68
  94. { 61, -94, 23, 47, -119 }, // 69
  95. { 62, -92, 22, 47, -117 }, // 70
  96. { 64, -90, 22, 46, -115 }, // 71
  97. { 65, -89, 21, 45, -113 }, // 72
  98. { 66, -87, 21, 44, -110 }, // 73
  99. { 67, -86, 21, 43, -108 }, // 74
  100. { 68, -84, 20, 43, -106 }, // 75
  101. { 69, -82, 20, 42, -104 }, // 76
  102. { 71, -81, 19, 41, -102 }, // 77
  103. { 72, -79, 19, 40, -100 }, // 78
  104. { 73, -78, 19, 39, -98 }, // 79
  105. { 74, -76, 18, 39, -96 }, // 80
  106. { 75, -75, 18, 38, -94 }, // 81
  107. { 76, -73, 17, 37, -92 }, // 82
  108. { 77, -71, 17, 36, -90 }, // 83
  109. { 79, -70, 17, 35, -88 }, // 84
  110. { 80, -68, 16, 34, -86 }, // 85
  111. { 81, -67, 16, 34, -84 }, // 86
  112. { 82, -65, 16, 33, -82 }, // 87
  113. { 83, -63, 15, 32, -80 }, // 88
  114. { 84, -62, 15, 31, -78 }, // 89
  115. { 86, -60, 14, 30, -76 }, // 90
  116. { 87, -59, 14, 30, -74 }, // 91
  117. { 88, -57, 14, 29, -72 }, // 92
  118. { 89, -55, 13, 28, -70 }, // 93
  119. { 90, -54, 13, 27, -68 }, // 94
  120. { 91, -52, 12, 26, -66 }, // 95
  121. { 93, -51, 12, 26, -64 }, // 96
  122. { 94, -49, 12, 25, -62 }, // 97
  123. { 95, -47, 11, 24, -60 }, // 98
  124. { 96, -46, 11, 23, -58 }, // 99
  125. { 97, -44, 10, 22, -56 }, // 100
  126. { 98, -43, 10, 21, -54 }, // 101
  127. { 100, -41, 10, 21, -52 }, // 102
  128. { 101, -39, 9, 20, -50 }, // 103
  129. { 102, -38, 9, 19, -48 }, // 104
  130. { 103, -36, 8, 18, -46 }, // 105
  131. { 104, -35, 8, 17, -44 }, // 106
  132. { 105, -33, 8, 17, -42 }, // 107
  133. { 107, -31, 7, 16, -40 }, // 108
  134. { 108, -30, 7, 15, -38 }, // 109
  135. { 109, -28, 7, 14, -36 }, // 110
  136. { 110, -27, 6, 13, -34 }, // 111
  137. { 111, -25, 6, 13, -32 }, // 112
  138. { 112, -23, 5, 12, -30 }, // 113
  139. { 114, -22, 5, 11, -28 }, // 114
  140. { 115, -20, 5, 10, -26 }, // 115
  141. { 116, -19, 4, 9, -24 }, // 116
  142. { 117, -17, 4, 8, -22 }, // 117
  143. { 118, -15, 3, 8, -20 }, // 118
  144. { 119, -14, 3, 7, -18 }, // 119
  145. { 121, -12, 3, 6, -16 }, // 120
  146. { 122, -11, 2, 5, -14 }, // 121
  147. { 123, -9, 2, 4, -12 }, // 122
  148. { 124, -7, 1, 4, -10 }, // 123
  149. { 125, -6, 1, 3, -8 }, // 124
  150. { 126, -4, 1, 2, -6 }, // 125
  151. { 128, -3, 0, 1, -4 }, // 126
  152. { 129, -1, 0, 0, -2 }, // 127
  153. { 130, 0, 0, 0, 0 }, // 128
  154. { 131, 1, 0, 0, 2 }, // 129
  155. { 132, 3, 0, -1, 4 }, // 130
  156. { 133, 4, -1, -2, 6 }, // 131
  157. { 135, 6, -1, -3, 8 }, // 132
  158. { 136, 7, -1, -4, 10 }, // 133
  159. { 137, 9, -2, -4, 12 }, // 134
  160. { 138, 11, -2, -5, 14 }, // 135
  161. { 139, 12, -3, -6, 16 }, // 136
  162. { 140, 14, -3, -7, 18 }, // 137
  163. { 142, 15, -3, -8, 20 }, // 138
  164. { 143, 17, -4, -8, 22 }, // 139
  165. { 144, 19, -4, -9, 24 }, // 140
  166. { 145, 20, -5, -10, 26 }, // 141
  167. { 146, 22, -5, -11, 28 }, // 142
  168. { 147, 23, -5, -12, 30 }, // 143
  169. { 148, 25, -6, -13, 32 }, // 144
  170. { 150, 27, -6, -13, 34 }, // 145
  171. { 151, 28, -7, -14, 36 }, // 146
  172. { 152, 30, -7, -15, 38 }, // 147
  173. { 153, 31, -7, -16, 40 }, // 148
  174. { 154, 33, -8, -17, 42 }, // 149
  175. { 155, 35, -8, -17, 44 }, // 150
  176. { 157, 36, -8, -18, 46 }, // 151
  177. { 158, 38, -9, -19, 48 }, // 152
  178. { 159, 39, -9, -20, 50 }, // 153
  179. { 160, 41, -10, -21, 52 }, // 154
  180. { 161, 43, -10, -21, 54 }, // 155
  181. { 162, 44, -10, -22, 56 }, // 156
  182. { 164, 46, -11, -23, 58 }, // 157
  183. { 165, 47, -11, -24, 60 }, // 158
  184. { 166, 49, -12, -25, 62 }, // 159
  185. { 167, 51, -12, -26, 64 }, // 160
  186. { 168, 52, -12, -26, 66 }, // 161
  187. { 169, 54, -13, -27, 68 }, // 162
  188. { 171, 55, -13, -28, 70 }, // 163
  189. { 172, 57, -14, -29, 72 }, // 164
  190. { 173, 59, -14, -30, 74 }, // 165
  191. { 174, 60, -14, -30, 76 }, // 166
  192. { 175, 62, -15, -31, 78 }, // 167
  193. { 176, 63, -15, -32, 80 }, // 168
  194. { 178, 65, -16, -33, 82 }, // 169
  195. { 179, 67, -16, -34, 84 }, // 170
  196. { 180, 68, -16, -34, 86 }, // 171
  197. { 181, 70, -17, -35, 88 }, // 172
  198. { 182, 71, -17, -36, 90 }, // 173
  199. { 183, 73, -17, -37, 92 }, // 174
  200. { 185, 75, -18, -38, 94 }, // 175
  201. { 186, 76, -18, -39, 96 }, // 176
  202. { 187, 78, -19, -39, 98 }, // 177
  203. { 188, 79, -19, -40, 100 }, // 178
  204. { 189, 81, -19, -41, 102 }, // 179
  205. { 190, 82, -20, -42, 104 }, // 180
  206. { 192, 84, -20, -43, 106 }, // 181
  207. { 193, 86, -21, -43, 108 }, // 182
  208. { 194, 87, -21, -44, 110 }, // 183
  209. { 195, 89, -21, -45, 113 }, // 184
  210. { 196, 90, -22, -46, 115 }, // 185
  211. { 197, 92, -22, -47, 117 }, // 186
  212. { 199, 94, -23, -47, 119 }, // 187
  213. { 200, 95, -23, -48, 121 }, // 188
  214. { 201, 97, -23, -49, 123 }, // 189
  215. { 202, 98, -24, -50, 125 }, // 190
  216. { 203, 100, -24, -51, 127 }, // 191
  217. { 204, 102, -25, -52, 129 }, // 192
  218. { 206, 103, -25, -52, 131 }, // 193
  219. { 207, 105, -25, -53, 133 }, // 194
  220. { 208, 106, -26, -54, 135 }, // 195
  221. { 209, 108, -26, -55, 137 }, // 196
  222. { 210, 110, -26, -56, 139 }, // 197
  223. { 211, 111, -27, -56, 141 }, // 198
  224. { 213, 113, -27, -57, 143 }, // 199
  225. { 214, 114, -28, -58, 145 }, // 200
  226. { 215, 116, -28, -59, 147 }, // 201
  227. { 216, 118, -28, -60, 149 }, // 202
  228. { 217, 119, -29, -60, 151 }, // 203
  229. { 218, 121, -29, -61, 153 }, // 204
  230. { 219, 122, -30, -62, 155 }, // 205
  231. { 221, 124, -30, -63, 157 }, // 206
  232. { 222, 126, -30, -64, 159 }, // 207
  233. { 223, 127, -31, -65, 161 }, // 208
  234. { 224, 129, -31, -65, 163 }, // 209
  235. { 225, 130, -32, -66, 165 }, // 210
  236. { 226, 132, -32, -67, 167 }, // 211
  237. { 228, 134, -32, -68, 169 }, // 212
  238. { 229, 135, -33, -69, 171 }, // 213
  239. { 230, 137, -33, -69, 173 }, // 214
  240. { 231, 138, -34, -70, 175 }, // 215
  241. { 232, 140, -34, -71, 177 }, // 216
  242. { 233, 142, -34, -72, 179 }, // 217
  243. { 235, 143, -35, -73, 181 }, // 218
  244. { 236, 145, -35, -73, 183 }, // 219
  245. { 237, 146, -35, -74, 185 }, // 220
  246. { 238, 148, -36, -75, 187 }, // 221
  247. { 239, 150, -36, -76, 189 }, // 222
  248. { 240, 151, -37, -77, 191 }, // 223
  249. { 242, 153, -37, -78, 193 }, // 224
  250. { 243, 154, -37, -78, 195 }, // 225
  251. { 244, 156, -38, -79, 197 }, // 226
  252. { 245, 158, -38, -80, 199 }, // 227
  253. { 246, 159, -39, -81, 201 }, // 228
  254. { 247, 161, -39, -82, 203 }, // 229
  255. { 249, 162, -39, -82, 205 }, // 230
  256. { 250, 164, -40, -83, 207 }, // 231
  257. { 251, 165, -40, -84, 209 }, // 232
  258. { 252, 167, -41, -85, 211 }, // 233
  259. { 253, 169, -41, -86, 213 }, // 234
  260. { 254, 170, -41, -86, 215 }, // 235
  261. { 256, 172, -42, -87, 217 }, // 236
  262. { 257, 173, -42, -88, 219 }, // 237
  263. { 258, 175, -43, -89, 221 }, // 238
  264. { 259, 177, -43, -90, 223 }, // 239
  265. { 260, 178, -43, -91, 226 }, // 240
  266. { 261, 180, -44, -91, 228 }, // 241
  267. { 263, 181, -44, -92, 230 }, // 242
  268. { 264, 183, -44, -93, 232 }, // 243
  269. { 265, 185, -45, -94, 234 }, // 244
  270. { 266, 186, -45, -95, 236 }, // 245
  271. { 267, 188, -46, -95, 238 }, // 246
  272. { 268, 189, -46, -96, 240 }, // 247
  273. { 270, 191, -46, -97, 242 }, // 248
  274. { 271, 193, -47, -98, 244 }, // 249
  275. { 272, 194, -47, -99, 246 }, // 250
  276. { 273, 196, -48, -99, 248 }, // 251
  277. { 274, 197, -48, -100, 250 }, // 252
  278. { 275, 199, -48, -101, 252 }, // 253
  279. { 277, 201, -49, -102, 254 }, // 254
  280. { 278, 202, -49, -103, 256 } // 255
  281. };
  282. #define YUYV_CONSTRAIN(v) ((v)<0)?0:(((v)>255)?255:(v))
  283. void IRAM_ATTR yuv2rgb(uint8_t y, uint8_t u, uint8_t v, uint8_t *r, uint8_t *g, uint8_t *b)
  284. {
  285. int16_t ri, gi, bi;
  286. ri = yuv_table[y].vY + yuv_table[v].vVr;
  287. gi = yuv_table[y].vY + yuv_table[u].vUg + yuv_table[v].vVg;
  288. bi = yuv_table[y].vY + yuv_table[u].vUb;
  289. *r = YUYV_CONSTRAIN(ri);
  290. *g = YUYV_CONSTRAIN(gi);
  291. *b = YUYV_CONSTRAIN(bi);
  292. }