source: 3DVCSoftware/trunk/source/Lib/TLibCommon/CommonDef.h @ 1356

Last change on this file since 1356 was 1356, checked in by tech, 9 years ago

Merged 15.1-dev0-NICT@1355.

  • Property svn:eol-style set to native
File size: 21.6 KB
Line 
1/* The copyright in this software is being made available under the BSD
2 * License, included below. This software may be subject to other third party
3 * and contributor rights, including patent rights, and no such rights are
4 * granted under this license.
5 *
6 * Copyright (c) 2010-2015, ITU/ISO/IEC
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 *  * Redistributions of source code must retain the above copyright notice,
13 *    this list of conditions and the following disclaimer.
14 *  * Redistributions in binary form must reproduce the above copyright notice,
15 *    this list of conditions and the following disclaimer in the documentation
16 *    and/or other materials provided with the distribution.
17 *  * Neither the name of the ITU/ISO/IEC nor the names of its contributors may
18 *    be used to endorse or promote products derived from this software without
19 *    specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
25 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
31 * THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34/** \file     CommonDef.h
35    \brief    Defines version information, constants and small in-line functions
36*/
37
38#ifndef __COMMONDEF__
39#define __COMMONDEF__
40
41#include <algorithm>
42#include <iostream>
43#include <assert.h>
44
45#if _MSC_VER > 1000
46// disable "signed and unsigned mismatch"
47#pragma warning( disable : 4018 )
48// disable Bool coercion "performance warning"
49#pragma warning( disable : 4800 )
50// NH_MV
51// disabled decorated name length warning issued for IntAry5d
52#pragma warning(disable : 4503)
53//
54#endif // _MSC_VER > 1000
55
56
57#include "TypeDef.h"
58#ifdef _MSC_VER
59#if _MSC_VER <= 1500
60inline Int64 abs (Int64 x) { return _abs64(x); };
61#endif
62#endif
63#if NH_MV
64#include <assert.h>
65#endif
66
67//! \ingroup TLibCommon
68//! \{
69
70// ====================================================================================================================
71// Version information
72// ====================================================================================================================
73#if NH_MV
74#define NV_VERSION        "15.1"                ///< Current software version
75#define HM_VERSION        "16.6"                ///<
76#else
77#define NV_VERSION        "16.6"                 ///< Current software version
78#endif
79// ====================================================================================================================
80// Platform information
81// ====================================================================================================================
82
83#ifdef __GNUC__
84#define NVM_COMPILEDBY  "[GCC %d.%d.%d]", __GNUC__, __GNUC_MINOR__, __GNUC_PATCHLEVEL__
85#ifdef __IA64__
86#define NVM_ONARCH    "[on 64-bit] "
87#else
88#define NVM_ONARCH    "[on 32-bit] "
89#endif
90#endif
91
92#ifdef __INTEL_COMPILER
93#define NVM_COMPILEDBY  "[ICC %d]", __INTEL_COMPILER
94#elif  _MSC_VER
95#define NVM_COMPILEDBY  "[VS %d]", _MSC_VER
96#endif
97
98#ifndef NVM_COMPILEDBY
99#define NVM_COMPILEDBY "[Unk-CXX]"
100#endif
101
102#ifdef _WIN32
103#define NVM_ONOS        "[Windows]"
104#elif  __linux
105#define NVM_ONOS        "[Linux]"
106#elif  __CYGWIN__
107#define NVM_ONOS        "[Cygwin]"
108#elif __APPLE__
109#define NVM_ONOS        "[Mac OS X]"
110#else
111#define NVM_ONOS "[Unk-OS]"
112#endif
113
114#define NVM_BITS          "[%d bit] ", (sizeof(Void*) == 8 ? 64 : 32) ///< used for checking 64-bit O/S
115
116#ifndef NULL
117#define NULL              0
118#endif
119
120// ====================================================================================================================
121// Common constants
122// ====================================================================================================================
123
124static const UInt   MAX_UINT =                            0xFFFFFFFFU; ///< max. value of unsigned 32-bit integer
125static const Int    MAX_INT =                              2147483647; ///< max. value of signed 32-bit integer
126#if NH_MV
127static const Int    MIN_INT =                         (- MAX_INT - 1); ///< max. value of signed 32-bit integer
128#endif
129static const Double MAX_DOUBLE =                             1.7e+308; ///< max. value of Double-type value
130
131// ====================================================================================================================
132// Coding tool configuration
133// ====================================================================================================================
134// Most of these should not be changed - they resolve the meaning of otherwise magic numbers.
135
136static const Int MAX_GOP =                                         64; ///< max. value of hierarchical GOP size
137static const Int MAX_NUM_REF_PICS =                                16; ///< max. number of pictures used for reference
138static const Int MAX_NUM_REF =                                     16; ///< max. number of entries in picture reference list
139static const Int MAX_QP =                                          51;
140static const Int NOT_VALID =                                       -1;
141
142static const Int AMVP_MAX_NUM_CANDS =                               2; ///< AMVP: advanced motion vector prediction - max number of final candidates
143static const Int AMVP_MAX_NUM_CANDS_MEM =                           3; ///< AMVP: advanced motion vector prediction - max number of candidates
144static const Int AMVP_DECIMATION_FACTOR =                           4;
145static const Int MRG_MAX_NUM_CANDS =                                5; ///< MERGE
146
147
148static const Int MAX_TLAYER =                                       7; ///< Explicit temporal layer QP offset - max number of temporal layer
149
150static const Int ADAPT_SR_SCALE =                                   1; ///< division factor for adaptive search range
151
152static const Int MAX_NUM_PICS_IN_SOP =                           1024;
153
154static const Int MAX_NESTING_NUM_OPS =                           1024;
155static const Int MAX_NESTING_NUM_LAYER =                           64;
156
157#if NH_MV
158static const Int MAX_VPS_NUM_HRD_PARAMETERS =                    1024;
159#else
160static const Int MAX_VPS_NUM_HRD_PARAMETERS =                       1;
161#endif
162static const Int MAX_VPS_OP_SETS_PLUS1 =                         1024;
163#if NH_MV
164static const Int MAX_VPS_NUH_LAYER_ID_PLUS1 =                      63;               
165#else
166static const Int MAX_VPS_NUH_RESERVED_ZERO_LAYER_ID_PLUS1 =         1;
167#endif
168
169static const Int MAXIMUM_INTRA_FILTERED_WIDTH =                    16;
170static const Int MAXIMUM_INTRA_FILTERED_HEIGHT =                   16;
171
172static const Int MAX_CPB_CNT =                                     32; ///< Upper bound of (cpb_cnt_minus1 + 1)
173#if NH_MV
174static const Int MAX_NUM_LAYER_IDS =                               63;
175#if NH_MV_SEI
176static const Int MAX_NUM_SEIS      =                               1000;
177#endif
178#else
179static const Int MAX_NUM_LAYER_IDS =                               64;
180#endif
181
182static const Int COEF_REMAIN_BIN_REDUCTION =                        3; ///< indicates the level at which the VLC transitions from Golomb-Rice to TU+EG(k)
183
184static const Int CU_DQP_TU_CMAX =                                   5; ///< max number bins for truncated unary
185static const Int CU_DQP_EG_k =                                      0; ///< expgolomb order
186
187static const Int SBH_THRESHOLD =                                    4; ///< value of the fixed SBH controlling threshold
188
189static const Int C1FLAG_NUMBER =                                    8; // maximum number of largerThan1 flag coded in one chunk:  16 in HM5
190static const Int C2FLAG_NUMBER =                                    1; // maximum number of largerThan2 flag coded in one chunk:  16 in HM5
191
192static const Int MAX_NUM_VPS =                                     16;
193static const Int MAX_NUM_SPS =                                     16;
194static const Int MAX_NUM_PPS =                                     64;
195
196
197static const Int MLS_GRP_NUM =                                     64; ///< Max number of coefficient groups, max(16, 64)
198static const Int MLS_CG_LOG2_WIDTH =                                2;
199static const Int MLS_CG_LOG2_HEIGHT =                               2;
200static const Int MLS_CG_SIZE =                                      4; ///< Coefficient group size of 4x4; = MLS_CG_LOG2_WIDTH + MLS_CG_LOG2_HEIGHT
201
202#if ADAPTIVE_QP_SELECTION
203static const Int ARL_C_PRECISION =                                  7; ///< G382: 7-bit arithmetic precision
204static const Int LEVEL_RANGE =                                     30; ///< G382: max coefficient level in statistics collection
205#endif
206
207static const Int RVM_VCEGAM10_M =                                   4;
208
209static const Int FAST_UDI_MAX_RDMODE_NUM =                         35; ///< maximum number of RD comparison in fast-UDI estimation loop
210
211static const Int NUM_INTRA_MODE =                                  36;
212static const Int PLANAR_IDX =                                       0;
213static const Int VER_IDX =                                         26; ///< index for intra VERTICAL   mode
214static const Int HOR_IDX =                                         10; ///< index for intra HORIZONTAL mode
215static const Int DC_IDX =                                           1; ///< index for intra DC mode
216static const Int NUM_CHROMA_MODE =                                  5; ///< total number of chroma modes
217static const Int DM_CHROMA_IDX =                                   36; ///< chroma mode index for derived from luma intra mode
218
219static const Int MDCS_ANGLE_LIMIT =                                 4; ///< 0 = Horizontal/vertical only, 1 = Horizontal/vertical +/- 1, 2 = Horizontal/vertical +/- 2 etc...
220static const Int MDCS_MAXIMUM_WIDTH =                               8; ///< (measured in pixels) TUs with width greater than this can only use diagonal scan
221static const Int MDCS_MAXIMUM_HEIGHT =                              8; ///< (measured in pixels) TUs with height greater than this can only use diagonal scan
222
223
224static const Int LOG2_MAX_NUM_COLUMNS_MINUS1 =                      7;
225static const Int LOG2_MAX_NUM_ROWS_MINUS1 =                         7;
226
227static const Int CABAC_INIT_PRESENT_FLAG =                          1;
228
229static const Int LUMA_INTERPOLATION_FILTER_SUB_SAMPLE_POSITIONS =   4;
230static const Int CHROMA_INTERPOLATION_FILTER_SUB_SAMPLE_POSITIONS = 8;
231
232static const Int MAX_NUM_LONG_TERM_REF_PICS =                      33;
233static const Int NUM_LONG_TERM_REF_PIC_SPS =                        0;
234
235
236static const Int MAX_QP_OFFSET_LIST_SIZE =                          6; ///< Maximum size of QP offset list is 6 entries
237
238// Cost mode support
239static const Int LOSSLESS_AND_MIXED_LOSSLESS_RD_COST_TEST_QP =      0; ///< QP to use for lossless coding.
240static const Int LOSSLESS_AND_MIXED_LOSSLESS_RD_COST_TEST_QP_PRIME =4; ///< QP' to use for mixed_lossy_lossless coding.
241
242static const Int RExt__GOLOMB_RICE_ADAPTATION_STATISTICS_SETS =     4;
243static const Int RExt__GOLOMB_RICE_INCREMENT_DIVISOR =              4;
244
245static const Int RExt__PREDICTION_WEIGHTING_ANALYSIS_DC_PRECISION = 0; ///< Additional fixed bit precision used during encoder-side weighting prediction analysis. Currently only used when high_precision_prediction_weighting_flag is set, for backwards compatibility reasons.
246
247static const Int MAX_TIMECODE_SEI_SETS =                            3; ///< Maximum number of time sets
248
249static const Int MAX_CU_DEPTH =                                     6; ///< log2(CTUSize)
250static const Int MAX_CU_SIZE =                                     64; ///< = 1<<(MAX_CU_DEPTH)
251static const Int MIN_PU_SIZE =                                      4;
252static const Int MIN_TU_SIZE =                                      4;
253static const Int MAX_TU_SIZE =                                     32;
254static const Int MAX_NUM_PART_IDXS_IN_CTU_WIDTH = MAX_CU_SIZE/MIN_PU_SIZE; ///< maximum number of partition indices across the width of a CTU (or height of a CTU)
255static const Int SCALING_LIST_REM_NUM =                             6;
256
257static const Int QUANT_SHIFT =                                     14; ///< Q(4) = 2^14
258static const Int IQUANT_SHIFT =                                     6;
259static const Int SCALE_BITS =                                      15; ///< For fractional bit estimates in RDOQ
260
261static const Int SCALING_LIST_NUM = MAX_NUM_COMPONENT * NUMBER_OF_PREDICTION_MODES; ///< list number for quantization matrix
262
263static const Int SCALING_LIST_START_VALUE =                        8 ; ///< start value for dpcm mode
264static const Int MAX_MATRIX_COEF_NUM =                            64 ; ///< max coefficient number for quantization matrix
265static const Int MAX_MATRIX_SIZE_NUM =                             8 ; ///< max size number for quantization matrix
266static const Int SCALING_LIST_BITS =                               8 ; ///< bit depth of scaling list entries
267static const Int LOG2_SCALING_LIST_NEUTRAL_VALUE =                 4 ; ///< log2 of the value that, when used in a scaling list, has no effect on quantisation
268static const Int SCALING_LIST_DC =                                16 ; ///< default DC value
269
270static const Int CONTEXT_STATE_BITS =                              6 ;
271static const Int LAST_SIGNIFICANT_GROUPS =                        10 ;
272
273#if NH_MV
274static const Int  MAX_VPS_NUM_ADD_LAYER_SETS =                  1024 ;
275static const Int  MAX_NUM_SCALABILITY_TYPES =                     16 ;
276static const Int  ENC_CFG_CONSOUT_SPACE =                         34 ;           
277static const Int  MAX_NUM_LAYERS =                                63 ;
278static const Int  MAX_VPS_PROFILE_TIER_LEVEL =                    64 ;
279static const Int  MAX_VPS_ADD_OUTPUT_LAYER_SETS =               1024 ;
280static const Int  MAX_VPS_OUTPUTLAYER_SETS =  MAX_VPS_ADD_OUTPUT_LAYER_SETS + MAX_VPS_OP_SETS_PLUS1 + MAX_VPS_OP_SETS_PLUS1 ;
281static const Int  MAX_NUM_VIDEO_SIGNAL_INFO =                     16 ;
282static const Int  MAX_NUM_SCALED_REF_LAYERS =     MAX_NUM_LAYERS - 1 ; 
283static const Int  MAX_NUM_PICS_RPS          =                     16 ; 
284static const Int  MAX_NUM_REF_LAYERS        =                     63 ; 
285#if NH_MV_SEI
286static IntAry1d getRangeVec( Int rngStart, Int rngEnd ) { IntAry1d rng; for (Int i = rngStart; i<=rngEnd; i++) rng.push_back(i);  return rng; };
287static const IntAry1d IDR_NAL_UNIT_TYPES   = getRangeVec( NAL_UNIT_CODED_SLICE_IDR_W_RADL, NAL_UNIT_CODED_SLICE_IDR_N_LP ); 
288static const IntAry1d IRAP_NAL_UNIT_TYPES  = getRangeVec( NAL_UNIT_CODED_SLICE_BLA_W_LP  , NAL_UNIT_CODED_SLICE_CRA      ); 
289
290#endif
291#endif
292
293// ====================================================================================================================
294// Macro functions
295// ====================================================================================================================
296
297template <typename T> inline T Clip3 (const T minVal, const T maxVal, const T a) { return std::min<T> (std::max<T> (minVal, a) , maxVal); }  ///< general min/max clip
298template <typename T> inline T ClipBD(const T x, const Int bitDepth)             { return Clip3(T(0), T((1 << bitDepth)-1), x);           }
299
300template <typename T> inline Void Check3( T minVal, T maxVal, T a)
301{
302  if ((a > maxVal) || (a < minVal))
303  {
304    std::cerr << "ERROR: Range check " << minVal << " >= " << a << " <= " << maxVal << " failed" << std::endl;
305    assert(false);
306    exit(1);
307  }
308}  ///< general min/max clip
309
310#define DATA_ALIGN                  1                                                                 ///< use 32-bit aligned malloc/free
311#if     DATA_ALIGN && _WIN32 && ( _MSC_VER > 1300 )
312#define xMalloc( type, len )        _aligned_malloc( sizeof(type)*(len), 32 )
313#define xFree( ptr )                _aligned_free  ( ptr )
314#else
315#define xMalloc( type, len )        malloc   ( sizeof(type)*(len) )
316#define xFree( ptr )                free     ( ptr )
317#endif
318
319#define FATAL_ERROR_0(MESSAGE, EXITCODE)                      \
320{                                                             \
321  printf(MESSAGE);                                            \
322  exit(EXITCODE);                                             \
323}
324
325template <typename ValueType> inline ValueType leftShift       (const ValueType value, const Int shift) { return (shift >= 0) ? ( value                                  << shift) : ( value                                   >> -shift); }
326template <typename ValueType> inline ValueType rightShift      (const ValueType value, const Int shift) { return (shift >= 0) ? ( value                                  >> shift) : ( value                                   << -shift); }
327template <typename ValueType> inline ValueType leftShift_round (const ValueType value, const Int shift) { return (shift >= 0) ? ( value                                  << shift) : ((value + (ValueType(1) << (-shift - 1))) >> -shift); }
328template <typename ValueType> inline ValueType rightShift_round(const ValueType value, const Int shift) { return (shift >= 0) ? ((value + (ValueType(1) << (shift - 1))) >> shift) : ( value                                   << -shift); }
329#if O0043_BEST_EFFORT_DECODING
330// when shift = 0, returns value
331// when shift = 1, (value + 0 + value[1]) >> 1
332// when shift = 2, (value + 1 + value[2]) >> 2
333// when shift = 3, (value + 3 + value[3]) >> 3
334template <typename ValueType> inline ValueType rightShiftEvenRounding(const ValueType value, const UInt shift) { return (shift == 0) ? value : ((value + (1<<(shift-1))-1 + ((value>>shift)&1)) >> shift) ; }
335#endif
336#if NH_MV
337
338#define AOF( exp )                  \
339{                                   \
340  if( !( exp ) )                    \
341{                                 \
342  assert( 0 );                    \
343}                                 \
344}
345
346#define AOT( exp )            \
347{                             \
348  if( ( exp ) )               \
349{                           \
350  assert( 0 );              \
351}                           \
352}
353
354template <typename T>
355__inline T gSign(const T& t)
356{
357  if( t == 0 )
358    return T(0);
359  else
360    return (t < 0) ? T(-1) : T(1);
361}
362
363template <typename T>
364__inline T gCeilLog2( T val )
365{
366  assert( val > 0 ); 
367  Int ceilLog2 = 0;
368  while( val > ( 1 << ceilLog2 ) ) ceilLog2++;
369  return ceilLog2;
370}
371
372#define RemoveBitIncrement( exp ) ( exp >> ( REN_BIT_DEPTH - 8 ) )
373
374#endif
375
376#if NH_3D_MLC  || NH_3D_ARP
377#define MRG_MAX_NUM_CANDS_MEM       (MRG_MAX_NUM_CANDS+1) // one extra for inter-view motion prediction
378#endif
379
380#if NH_MV
381static const std::string NALU_TYPE_STR[] = { 
382    "CODED_SLICE_TRAIL_N   ",  // 0
383    "CODED_SLICE_TRAIL_R   ",  // 1
384    "CODED_SLICE_TSA_N     ",  // 2
385    "CODED_SLICE_TSA_R     ",  // 3
386    "CODED_SLICE_STSA_N    ",  // 4
387    "CODED_SLICE_STSA_R    ",  // 5
388    "CODED_SLICE_RADL_N    ",  // 6
389    "CODED_SLICE_RADL_R    ",  // 7
390    "CODED_SLICE_RASL_N    ",  // 8
391    "CODED_SLICE_RASL_R    ",  // 9
392    "RESERVED_VCL_N10      ",
393    "RESERVED_VCL_R11      ",
394    "RESERVED_VCL_N12      ",
395    "RESERVED_VCL_R13      ",
396    "RESERVED_VCL_N14      ",
397    "RESERVED_VCL_R15      ",
398    "CODED_SLICE_BLA_W_LP  ",  // 16
399    "CODED_SLICE_BLA_W_RADL",  // 17
400    "CODED_SLICE_BLA_N_LP  ",  // 18
401    "CODED_SLICE_IDR_W_RADL",  // 19
402    "CODED_SLICE_IDR_N_LP  ",  // 20
403    "CODED_SLICE_CRA       ",  // 21
404    "RESERVED_IRAP_VCL22   ",
405    "RESERVED_IRAP_VCL23   ",
406    "RESERVED_VCL24        ",
407    "RESERVED_VCL25        ",
408    "RESERVED_VCL26        ",
409    "RESERVED_VCL27        ",
410    "RESERVED_VCL28        ",
411    "RESERVED_VCL29        ",
412    "RESERVED_VCL30        ",
413    "RESERVED_VCL31        ",
414    "VPS                   ",   // 32
415    "SPS                   ",   // 33
416    "PPS                   ",   // 34
417    "ACCESS_UNIT_DELIMITER ",   // 35
418    "EOS                   ",   // 36
419    "EOB                   ",   // 37
420    "FILLER_DATA           ",   // 38
421    "PREFIX_SEI            ",   // 39
422    "SUFFIX_SEI            ",   // 40
423    "RESERVED_NVCL41       ",
424    "RESERVED_NVCL42       ",
425    "RESERVED_NVCL43       ",
426    "RESERVED_NVCL44       ",
427    "RESERVED_NVCL45       ",
428    "RESERVED_NVCL46       ",
429    "RESERVED_NVCL47       ",
430    "UNSPECIFIED_48        ",
431    "UNSPECIFIED_49        ",
432    "UNSPECIFIED_50        ",
433    "UNSPECIFIED_51        ",
434    "UNSPECIFIED_52        ",
435    "UNSPECIFIED_53        ",
436    "UNSPECIFIED_54        ",
437    "UNSPECIFIED_55        ",
438    "UNSPECIFIED_56        ",
439    "UNSPECIFIED_57        ",
440    "UNSPECIFIED_58        ",
441    "UNSPECIFIED_59        ",
442    "UNSPECIFIED_60        ",
443    "UNSPECIFIED_61        ",
444    "UNSPECIFIED_62        ",
445    "UNSPECIFIED_63        ",
446    "INVALID               "               
447  };
448#endif
449
450#if NH_3D
451//PICYUV
452#define PICYUV_PAD         16
453
454//RENDERER
455
456
457#define REN_BIT_DEPTH     8
458#define REN_LUMA_MARGIN   ( PICYUV_PAD + 1 ) // + g_uiMaxCuWidth instead of 1 ???
459#define REN_VDWEIGHT_PREC  8
460#define REN_IS_FILLED     ( 1 << REN_VDWEIGHT_PREC )
461#define REN_USED_PEL       ( (1 << REN_BIT_DEPTH) - 1 )
462#define REN_UNUSED_PEL     0
463#define REN_IS_HOLE        0
464#if NH_3D_VSO
465#define ENC_INTERNAL_BIT_DEPTH  REN_BIT_DEPTH // consider making this a variable
466#endif
467
468
469// CAMERA PARAMETERS
470#define LOG2_DISP_PREC_LUT           2           ///< log2 of disparity precision used in integer disparity LUTs
471#define STD_CAM_PARAMETERS_PRECISION 5        ///< quarter luma sample accuarcy for derived disparities (as default)
472
473#endif // end of NH_3D
474//! \}
475
476#endif // end of #ifndef  __COMMONDEF__
477
Note: See TracBrowser for help on using the repository browser.