• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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