vorbis_info.html 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <html>
  2. <head>
  3. <title>vorbis - datatype - vorbis_info</title>
  4. <link rel=stylesheet href="style.css" type="text/css">
  5. </head>
  6. <body bgcolor=white text=black link="#5555ff" alink="#5555ff" vlink="#5555ff">
  7. <table border=0 width=100%>
  8. <tr>
  9. <td><p class=tiny>vorbisfile documentation</p></td>
  10. <td align=right><p class=tiny>vorbisfile version 1.25 - 20000615</p></td>
  11. </tr>
  12. </table>
  13. <h1>vorbis_info</h1>
  14. <p><i>declared in "vorbis/codec.h"</i></p>
  15. <p>
  16. The vorbis_info structure contains information about a vorbis bitstream. Most of the information in this struct is more complex and in-depth than we need when using basic API calls.
  17. <p>
  18. <table border=0 width=100% color=black cellspacing=0 cellpadding=7>
  19. <tr bgcolor=#cccccc>
  20. <td>
  21. <pre><b>typedef struct vorbis_info{
  22. int version;
  23. int channels;
  24. long rate;
  25. long bitrate_upper;
  26. long bitrate_nominal;
  27. long bitrate_lower;
  28. long blocksizes[2];
  29. int modes;
  30. int maps;
  31. int times;
  32. int floors;
  33. int residues;
  34. int books;
  35. int psys; /* encode only */
  36. vorbis_info_mode *mode_param[64];
  37. int map_type[64];
  38. vorbis_info_mapping *map_param[64];
  39. int time_type[64];
  40. vorbis_info_time *time_param[64];
  41. int floor_type[64];
  42. vorbis_info_floor *floor_param[64];
  43. int residue_type[64];
  44. vorbis_info_residue *residue_param[64];
  45. static_codebook *book_param[256];
  46. vorbis_info_psy *psy_param[64]; /* encode only */
  47. /* for block long/sort tuning; encode only */
  48. int envelopesa;
  49. double preecho_thresh;
  50. double preecho_clamp;
  51. } vorbis_info;</b></pre>
  52. </td>
  53. </tr>
  54. </table>
  55. <h3>Relevant Struct Members</h3>
  56. <dl>
  57. <dt><i>version</i></dt>
  58. <dd>Vorbis encoder version used to create this bitstream.</dd>
  59. <dt><i>channels</i></dt>
  60. <dd>Int signifying number of channels in bitstream.</dd>
  61. <dt><i>rate</i></dt>
  62. <dd>Sampling rate of the bitstream.</dd>
  63. <dt><i>bitrate_upper</i></dt>
  64. <dd>Specifies the upper limit in a VBR bitstream. If the value matches the bitrate_nominal and bitrate_lower parameters, the stream is fixed bitrate. May be unset if no limit exists.</dd>
  65. <dt><i>bitrate_nominal</i></dt>
  66. <dd>Specifies the average bitrate for a VBR bitstream. May be unset. If the bitrate_upper and bitrate_lower parameters match, the stream is fixed bitrate.</dd>
  67. <dt><i>bitrate_lower</i></dt>
  68. <dd>Specifies the lower limit in a VBR bitstream. If the value matches the bitrate_nominal and bitrate_upper parameters, the stream is fixed bitrate. May be unset if no limit exists.</dd>
  69. <dt><i>blocksizes[2]</i></dt>
  70. <dd>Contains the sizes of the long and short blocks for this particular bitstream. These are variable and can be set by the encoder. Vorbis only supports two sizes, long and short.</dd>
  71. </dl>
  72. <br><br>
  73. <hr noshade>
  74. <table border=0 width=100%>
  75. <tr valign=top>
  76. <td><p class=tiny>copyright &copy; 2000 vorbis team</p></td>
  77. <td align=right><p class=tiny><a href="http://www.xiph.org/ogg/vorbis/index.html">Ogg Vorbis</a><br><a href="mailto:team@vorbis.org">team@vorbis.org</a></p></td>
  78. </tr><tr>
  79. <td><p class=tiny>vorbisfile documentation</p></td>
  80. <td align=right><p class=tiny>vorbisfile version 1.25 - 20000615</p></td>
  81. </tr>
  82. </table>
  83. </body>
  84. </html>