View Javadoc
1   /*
2    *  Licensed to the Apache Software Foundation (ASF) under one or more
3    *  contributor license agreements.  See the NOTICE file distributed with
4    *  this work for additional information regarding copyright ownership.
5    *  The ASF licenses this file to You under the Apache License, Version 2.0
6    *  (the "License"); you may not use this file except in compliance with
7    *  the License.  You may obtain a copy 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,
13   *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   *  See the License for the specific language governing permissions and
15   *  limitations under the License.
16   */
17  package org.apache.commons.compress.harmony.pack200;
18  
19  /**
20   * Sets of codecs that share characteristics. Mainly used for different effort compression heuristics in BandSet.
21   */
22  public class CanonicalCodecFamilies {
23  
24      // Families of codecs for bands of positive integers that do not correlate
25      // well (i.e. would not benefit from delta encoding)
26  
27      public static BHSDCodec[] nonDeltaUnsignedCodecs1 = {
28              // (1,256) is a special case and is considered separately so shouldn't be included here
29  //        CodecEncoding.getCanonicalCodec(1), // (1,256)
30              CodecEncoding.getCanonicalCodec(5), // (2,256)
31              CodecEncoding.getCanonicalCodec(9), // (3,256)
32              CodecEncoding.getCanonicalCodec(13) // (4,256)
33      };
34  
35      public static BHSDCodec[] nonDeltaUnsignedCodecs2 = { CodecEncoding.getCanonicalCodec(17), // (5,4)
36              CodecEncoding.getCanonicalCodec(20), // (5,16)
37              CodecEncoding.getCanonicalCodec(23), // (5,32)
38              CodecEncoding.getCanonicalCodec(26), // (5,64)
39              CodecEncoding.getCanonicalCodec(29) // (5,128)
40      };
41  
42      public static BHSDCodec[] nonDeltaUnsignedCodecs3 = { CodecEncoding.getCanonicalCodec(47), // (2,192)
43              CodecEncoding.getCanonicalCodec(48), // (2,224)
44              CodecEncoding.getCanonicalCodec(49), // (2,240)
45              CodecEncoding.getCanonicalCodec(50), // (2,248)
46              CodecEncoding.getCanonicalCodec(51) // (2,252)
47      };
48  
49      public static BHSDCodec[] nonDeltaUnsignedCodecs4 = { CodecEncoding.getCanonicalCodec(70), // (3,192)
50              CodecEncoding.getCanonicalCodec(71), // (3,224)
51              CodecEncoding.getCanonicalCodec(72), // (3,240)
52              CodecEncoding.getCanonicalCodec(73), // (3,248)
53              CodecEncoding.getCanonicalCodec(74) // (3,252)
54      };
55  
56      public static BHSDCodec[] nonDeltaUnsignedCodecs5 = { CodecEncoding.getCanonicalCodec(93), // (4,192)
57              CodecEncoding.getCanonicalCodec(94), // (4,224)
58              CodecEncoding.getCanonicalCodec(95), // (4,240)
59              CodecEncoding.getCanonicalCodec(96), // (4,248)
60              CodecEncoding.getCanonicalCodec(97) // (4,252)
61      };
62  
63      // Families of codecs for bands of positive integers that do correlate well
64      // and would benefit from delta encoding
65  
66      public static BHSDCodec[] deltaUnsignedCodecs1 = { CodecEncoding.getCanonicalCodec(3), // (1,256,0,1)
67              CodecEncoding.getCanonicalCodec(7), // (2,256,0,1)
68              CodecEncoding.getCanonicalCodec(11), // (3,256,0,1)
69              CodecEncoding.getCanonicalCodec(15) // (4,256,0,1)
70      };
71  
72      public static BHSDCodec[] deltaUnsignedCodecs2 = { CodecEncoding.getCanonicalCodec(32), // (5,4,0,1)
73              CodecEncoding.getCanonicalCodec(35), // (5,16,0,1)
74              CodecEncoding.getCanonicalCodec(38), // (5,32,0,1)
75              CodecEncoding.getCanonicalCodec(41), // (5,64,0,1)
76              CodecEncoding.getCanonicalCodec(44) // (5,128,0,1)
77      };
78  
79      public static BHSDCodec[] deltaUnsignedCodecs3 = { CodecEncoding.getCanonicalCodec(52), // (2,8,0,1)
80              CodecEncoding.getCanonicalCodec(54), // (2,16,0,1)
81              CodecEncoding.getCanonicalCodec(56), // (2,32,0,1)
82              CodecEncoding.getCanonicalCodec(58), // (2,64,0,1)
83              CodecEncoding.getCanonicalCodec(60), // (2,128,0,1)
84              CodecEncoding.getCanonicalCodec(62), // (2,192,0,1)
85              CodecEncoding.getCanonicalCodec(64), // (2,224,0,1)
86              CodecEncoding.getCanonicalCodec(66), // (2,240,0,1)
87              CodecEncoding.getCanonicalCodec(68) // (2,248,0,1)
88      };
89  
90      public static BHSDCodec[] deltaUnsignedCodecs4 = { CodecEncoding.getCanonicalCodec(75), // (3,8,0,1)
91              CodecEncoding.getCanonicalCodec(77), // (3,16,0,1)
92              CodecEncoding.getCanonicalCodec(79), // (3,32,0,1)
93              CodecEncoding.getCanonicalCodec(81), // (3,64,0,1)
94              CodecEncoding.getCanonicalCodec(83), // (3,128,0,1)
95              CodecEncoding.getCanonicalCodec(85), // (3,192,0,1)
96              CodecEncoding.getCanonicalCodec(87), // (3,224,0,1)
97              CodecEncoding.getCanonicalCodec(89), // (3,240,0,1)
98              CodecEncoding.getCanonicalCodec(91) // (3,248,0,1)
99      };
100 
101     public static BHSDCodec[] deltaUnsignedCodecs5 = { CodecEncoding.getCanonicalCodec(98), // (4,8,0,1)
102             CodecEncoding.getCanonicalCodec(100), // (4,16,0,1)
103             CodecEncoding.getCanonicalCodec(102), // (4,32,0,1)
104             CodecEncoding.getCanonicalCodec(104), // (4,64,0,1)
105             CodecEncoding.getCanonicalCodec(106), // (4,128,0,1)
106             CodecEncoding.getCanonicalCodec(108), // (4,192,0,1)
107             CodecEncoding.getCanonicalCodec(110), // (4,224,0,1)
108             CodecEncoding.getCanonicalCodec(112), // (4,240,0,1)
109             CodecEncoding.getCanonicalCodec(114) // (4,248,0,1)
110     };
111 
112     // Families of codecs for bands containing positive and negative integers
113     // that do correlate well (i.e. delta encoding is used)
114 
115     public static BHSDCodec[] deltaSignedCodecs1 = { CodecEncoding.getCanonicalCodec(4), // (1,256,1,1)
116             CodecEncoding.getCanonicalCodec(8), // (2,256,1,1)
117             CodecEncoding.getCanonicalCodec(12), // (3,256,1,1)
118             CodecEncoding.getCanonicalCodec(16) // (4,256,1,1)
119     };
120 
121     public static BHSDCodec[] deltaSignedCodecs2 = { CodecEncoding.getCanonicalCodec(33), // (5,4,1,1)
122             CodecEncoding.getCanonicalCodec(36), // (5,16,1,1)
123             CodecEncoding.getCanonicalCodec(39), // (5,32,1,1)
124             CodecEncoding.getCanonicalCodec(42), // (5,64,1,1)
125             CodecEncoding.getCanonicalCodec(45) // (5,128,1,1)
126     };
127 
128     public static BHSDCodec[] deltaSignedCodecs3 = { CodecEncoding.getCanonicalCodec(53), // (2,8,1,1)
129             CodecEncoding.getCanonicalCodec(55), // (2,16,1,1)
130             CodecEncoding.getCanonicalCodec(57), // (2,32,1,1)
131             CodecEncoding.getCanonicalCodec(59), // (2,64,1,1)
132             CodecEncoding.getCanonicalCodec(61), // (2,128,1,1)
133             CodecEncoding.getCanonicalCodec(63), // (2,192,1,1)
134             CodecEncoding.getCanonicalCodec(65), // (2,224,1,1)
135             CodecEncoding.getCanonicalCodec(67), // (2,240,1,1)
136             CodecEncoding.getCanonicalCodec(69) // (2,248,1,1)
137     };
138 
139     public static BHSDCodec[] deltaSignedCodecs4 = { CodecEncoding.getCanonicalCodec(76), // (3,8,1,1)
140             CodecEncoding.getCanonicalCodec(78), // (3,16,1,1)
141             CodecEncoding.getCanonicalCodec(80), // (3,32,1,1)
142             CodecEncoding.getCanonicalCodec(82), // (3,64,1,1)
143             CodecEncoding.getCanonicalCodec(84), // (3,128,1,1)
144             CodecEncoding.getCanonicalCodec(86), // (3,192,1,1)
145             CodecEncoding.getCanonicalCodec(88), // (3,224,1,1)
146             CodecEncoding.getCanonicalCodec(90), // (3,240,1,1)
147             CodecEncoding.getCanonicalCodec(92) // (3,248,1,1)
148     };
149 
150     public static BHSDCodec[] deltaSignedCodecs5 = { CodecEncoding.getCanonicalCodec(99), // (4,8,1,1)
151             CodecEncoding.getCanonicalCodec(101), // (4,16,1,1)
152             CodecEncoding.getCanonicalCodec(103), // (4,32,1,1)
153             CodecEncoding.getCanonicalCodec(105), // (4,64,1,1)
154             CodecEncoding.getCanonicalCodec(107), // (4,128,1,1)
155             CodecEncoding.getCanonicalCodec(109), // (4,192,1,1)
156             CodecEncoding.getCanonicalCodec(111), // (4,224,1,1)
157             CodecEncoding.getCanonicalCodec(113), // (4,240,1,1)
158             CodecEncoding.getCanonicalCodec(115) // (4,248,1,1)
159     };
160 
161     public static BHSDCodec[] deltaDoubleSignedCodecs1 = { CodecEncoding.getCanonicalCodec(34), // (5,4,2,1)
162             CodecEncoding.getCanonicalCodec(37), // (5,16,2,1)
163             CodecEncoding.getCanonicalCodec(40), // (5,32,2,1)
164             CodecEncoding.getCanonicalCodec(43), // (5,64,2,1)
165             CodecEncoding.getCanonicalCodec(46) // (5,128,2,1)
166     };
167 
168     // Families of codecs for bands containing positive and negative values that
169     // do not correlate well (i.e. delta encoding is not used)
170 
171     public static BHSDCodec[] nonDeltaSignedCodecs1 = { CodecEncoding.getCanonicalCodec(2), // (1,256,1)
172             CodecEncoding.getCanonicalCodec(6), // (2,256,1)
173             CodecEncoding.getCanonicalCodec(10), // (3,256,1)
174             CodecEncoding.getCanonicalCodec(14) // (4,256,1)
175     };
176 
177     public static BHSDCodec[] nonDeltaSignedCodecs2 = { CodecEncoding.getCanonicalCodec(18), // (5,4,1)
178             CodecEncoding.getCanonicalCodec(21), // (5,16,1)
179             CodecEncoding.getCanonicalCodec(24), // (5,32,1)
180             CodecEncoding.getCanonicalCodec(27), // (5,64,1)
181             CodecEncoding.getCanonicalCodec(30) // (5,128,1)
182     };
183 
184     public static BHSDCodec[] nonDeltaDoubleSignedCodecs1 = { CodecEncoding.getCanonicalCodec(19), // (5,4,2)
185             CodecEncoding.getCanonicalCodec(22), // (5,16,2)
186             CodecEncoding.getCanonicalCodec(25), // (5,32,2)
187             CodecEncoding.getCanonicalCodec(28), // (5,64,2)
188             CodecEncoding.getCanonicalCodec(31) // (5,128,2)
189     };
190 
191 }