1 // SPDX-License-Identifier: Apache-2.0 2 // ---------------------------------------------------------------------------- 3 // Copyright 2011-2020 Arm Limited 4 // 5 // Licensed under the Apache License, Version 2.0 (the "License"); you may not 6 // use this file except in compliance with the License. You may obtain a copy 7 // of the License at: 8 // 9 // http://www.apache.org/licenses/LICENSE-2.0 10 // 11 // Unless required by applicable law or agreed to in writing, software 12 // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 13 // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 14 // License for the specific language governing permissions and limitations 15 // under the License. 16 // ---------------------------------------------------------------------------- 17 18 /** 19 * @brief Data tables for quantization transfer. 20 */ 21 22 #include "astc_codec_internals.h" 23 24 #define _ 0 // using _ to indicate an entry that will not be used. 25 26 const quantization_and_transfer_table quant_and_xfer_tables[12] = { 27 // quantization method 0, range 0..1 28 { 29 QUANT_2, 30 {0, 64, 255}, 31 {0, 1}, 32 {0, 64}, 33 {0x01004000,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_, 34 _,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_, 35 0x01004000} 36 }, 37 // quantization method 1, range 0..2 38 { 39 QUANT_3, 40 {0, 32, 64, 255}, 41 {0, 1, 2}, 42 {0, 32, 64}, 43 {0x01002000,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_, 44 _,_,0x02004000,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_, 45 _,_,_,_,0x02014020} 46 }, 47 // quantization method 2, range 0..3 48 { 49 QUANT_4, 50 {0, 21, 43, 64, 255}, 51 {0, 1, 2, 3}, 52 {0, 21, 43, 64}, 53 {0x01001500,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,0x02002b00,_,_,_,_, 54 _,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,0x03014015,_,_,_,_,_,_,_,_,_,_,_,_, 55 _,_,_,_,_,_,_,_,0x0302402b} 56 }, 57 // quantization method 3, range 0..4 58 { 59 QUANT_5, 60 {0, 16, 32, 48, 64, 255}, 61 {0, 1, 2, 3, 4}, 62 {0, 16, 32, 48, 64}, 63 {0x01001000,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,0x02002000,_,_,_,_,_,_,_,_,_, 64 _,_,_,_,_,_,0x03013010,_,_,_,_,_,_,_,_,_,_,_,_,_,_,_,0x04024020,_,_,_, 65 _,_,_,_,_,_,_,_,_,_,_,_,0x04034030} 66 }, 67 // quantization method 4, range 0..5 68 { 69 QUANT_6, 70 {0, 12, 25, 39, 52, 64, 255}, 71 {0, 2, 4, 5, 3, 1}, 72 {0, 64, 12, 52, 25, 39}, 73 {0x02000c00,_,_,_,_,_,_,_,_,_,_,_,0x04001900,_,_,_,_,_,_,_,_,_,_,_,_, 74 0x0502270c,_,_,_,_,_,_,_,_,_,_,_,_,_,0x03043419,_,_,_,_,_,_,_,_,_,_, 75 _,_,0x01054027,_,_,_,_,_,_,_,_,_,_,_,0x01034034} 76 }, 77 // quantization method 5, range 0..7 78 { 79 QUANT_8, 80 {0, 9, 18, 27, 37, 46, 55, 64, 255}, 81 {0, 1, 2, 3, 4, 5, 6, 7}, 82 {0, 9, 18, 27, 37, 46, 55, 64}, 83 {0x01000900,_,_,_,_,_,_,_,_,0x02001200,_,_,_,_,_,_,_,_,0x03011b09,_,_, 84 _,_,_,_,_,_,0x04022512,_,_,_,_,_,_,_,_,_,0x05032e1b,_,_,_,_,_,_,_,_, 85 0x06043725,_,_,_,_,_,_,_,_,0x0705402e,_,_,_,_,_,_,_,_,0x07064037} 86 }, 87 // quantization method 6, range 0..9 88 { 89 QUANT_10, 90 {0, 7, 14, 21, 28, 36, 43, 50, 57, 64, 255}, 91 {0, 2, 4, 6, 8, 9, 7, 5, 3, 1}, 92 {0, 64, 7, 57, 14, 50, 21, 43, 28, 36}, 93 {0x02000700,_,_,_,_,_,_,0x04000e00,_,_,_,_,_,_,0x06021507,_,_,_,_,_,_, 94 0x08041c0e,_,_,_,_,_,_,0x09062415,_,_,_,_,_,_,_,0x07082b1c,_,_,_,_,_, 95 _,0x05093224,_,_,_,_,_,_,0x0307392b,_,_,_,_,_,_,0x01054032,_,_,_,_,_, 96 _,0x01034039} 97 }, 98 // quantization method 7, range 0..11 99 { 100 QUANT_12, 101 {0, 5, 11, 17, 23, 28, 36, 41, 47, 53, 59, 64, 255}, 102 {0, 4, 8, 2, 6, 10, 11, 7, 3, 9, 5, 1}, 103 {0, 64, 17, 47, 5, 59, 23, 41, 11, 53, 28, 36}, 104 {0x04000500,_,_,_,_,0x08000b00,_,_,_,_,_,0x02041105,_,_,_,_,_, 105 0x0608170b,_,_,_,_,_,0x0a021c11,_,_,_,_,0x0b062417,_,_,_,_,_,_,_, 106 0x070a291c,_,_,_,_,0x030b2f24,_,_,_,_,_,0x09073529,_,_,_,_,_, 107 0x05033b2f,_,_,_,_,_,0x01094035,_,_,_,_,0x0105403b} 108 }, 109 // quantization method 8, range 0..15 110 { 111 QUANT_16, 112 {0, 4, 8, 12, 17, 21, 25, 29, 35, 39, 43, 47, 52, 56, 60, 64, 255}, 113 {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15}, 114 {0, 4, 8, 12, 17, 21, 25, 29, 35, 39, 43, 47, 52, 56, 60, 64}, 115 {0x01000400,_,_,_,0x02000800,_,_,_,0x03010c04,_,_,_,0x04021108,_,_,_,_, 116 0x0503150c,_,_,_,0x06041911,_,_,_,0x07051d15,_,_,_,0x08062319,_,_,_,_, 117 _,0x0907271d,_,_,_,0x0a082b23,_,_,_,0x0b092f27,_,_,_,0x0c0a342b,_,_,_, 118 _,0x0d0b382f,_,_,_,0x0e0c3c34,_,_,_,0x0f0d4038,_,_,_,0x0f0e403c} 119 }, 120 // quantization method 9, range 0..19 121 { 122 QUANT_20, 123 {0, 3, 6, 9, 13, 16, 19, 23, 26, 29, 35, 38, 41, 45, 48, 51, 55, 58, 124 61, 64, 255}, 125 {0, 4, 8, 12, 16, 2, 6, 10, 14, 18, 19, 15, 11, 7, 3, 17, 13, 9, 5, 1}, 126 {0, 64, 16, 48, 3, 61, 19, 45, 6, 58, 23, 41, 9, 55, 26, 38, 13, 51, 127 29, 35}, 128 {0x04000300,_,_,0x08000600,_,_,0x0c040903,_,_,0x10080d06,_,_,_, 129 0x020c1009,_,_,0x0610130d,_,_,0x0a021710,_,_,_,0x0e061a13,_,_, 130 0x120a1d17,_,_,0x130e231a,_,_,_,_,_,0x0f12261d,_,_,0x0b132923,_,_, 131 0x070f2d26,_,_,_,0x030b3029,_,_,0x1107332d,_,_,0x0d033730,_,_,_, 132 0x09113a33,_,_,0x050d3d37,_,_,0x0109403a,_,_,0x0105403d} 133 }, 134 // quantization method 10, range 0..23 135 { 136 QUANT_24, 137 {0, 2, 5, 8, 11, 13, 16, 19, 22, 24, 27, 30, 34, 37, 40, 42, 45, 48, 138 51, 53, 56, 59, 62, 64, 255}, 139 {0, 8, 16, 2, 10, 18, 4, 12, 20, 6, 14, 22, 23, 15, 7, 21, 13, 5, 19, 140 11, 3, 17, 9, 1}, 141 {0, 64, 8, 56, 16, 48, 24, 40, 2, 62, 11, 53, 19, 45, 27, 37, 5, 59, 142 13, 51, 22, 42, 30, 34}, 143 {0x08000200,_,0x10000500,_,_,0x02080802,_,_,0x0a100b05,_,_,0x12020d08, 144 _,0x040a100b,_,_,0x0c12130d,_,_,0x14041610,_,_,0x060c1813,_, 145 0x0e141b16,_,_,0x16061e18,_,_,0x170e221b,_,_,_,0x0f16251e,_,_, 146 0x07172822,_,_,0x150f2a25,_,0x0d072d28,_,_,0x0515302a,_,_,0x130d332d, 147 _,_,0x0b053530,_,0x03133833,_,_,0x110b3b35,_,_,0x09033e38,_,_, 148 0x0111403b,_,0x0109403e} 149 }, 150 // quantization method 11, range 0..31 151 { 152 QUANT_32, 153 {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 34, 36, 38, 154 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 255}, 155 {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 156 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31}, 157 {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 34, 36, 38, 158 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64}, 159 {0x01000200,_,0x02000400,_,0x03010602,_,0x04020804,_,0x05030a06,_, 160 0x06040c08,_,0x07050e0a,_,0x0806100c,_,0x0907120e,_,0x0a081410,_, 161 0x0b091612,_,0x0c0a1814,_,0x0d0b1a16,_,0x0e0c1c18,_,0x0f0d1e1a,_, 162 0x100e221c,_,_,_,0x110f241e,_,0x12102622,_,0x13112824,_,0x14122a26,_, 163 0x15132c28,_,0x16142e2a,_,0x1715302c,_,0x1816322e,_,0x19173430,_, 164 0x1a183632,_,0x1b193834,_,0x1c1a3a36,_,0x1d1b3c38,_,0x1e1c3e3a,_, 165 0x1f1d403c,_,0x1f1e403e} 166 } 167 }; 168