diff options
author | Oded Shimon <ods15@ods15.dyndns.org> | 2006-10-01 11:59:33 +0000 |
---|---|---|
committer | Oded Shimon <ods15@ods15.dyndns.org> | 2006-10-01 11:59:33 +0000 |
commit | 6c29d7c8f33b1aa7d02e9c9fdd41f8ced43b153f (patch) | |
tree | beb4066b9ab38c1f24c988fdb38c3e4c497abcac /libavcodec/vorbis.h | |
parent | 9f963af5a0dae0e24285dca8b3a2e936e42afd96 (diff) | |
download | ffmpeg-6c29d7c8f33b1aa7d02e9c9fdd41f8ced43b153f.tar.gz |
make some more functions global so they can be shared with vorbis_enc.c
Originally committed as revision 6402 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/vorbis.h')
-rw-r--r-- | libavcodec/vorbis.h | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/libavcodec/vorbis.h b/libavcodec/vorbis.h index 5cdcb652af..beb1aab8fe 100644 --- a/libavcodec/vorbis.h +++ b/libavcodec/vorbis.h @@ -30,5 +30,36 @@ typedef struct { } floor1_entry_t; void ff_vorbis_ready_floor1_list(floor1_entry_t * list, int values); +unsigned int ff_vorbis_nth_root(unsigned int x, unsigned int n); // x^(1/n) +int ff_vorbis_len2vlc(uint8_t *bits, uint32_t *codes, uint_fast32_t num); + +static void render_line(int x0, int y0, int x1, int y1, float * buf, int n) { + int dy = y1 - y0; + int adx = x1 - x0; + int ady = ABS(dy); + int base = dy / adx; + int x = x0; + int y = y0; + int err = 0; + int sy; + if (dy < 0) sy = base - 1; + else sy = base + 1; + ady = ady - ABS(base) * adx; + if (x >= n) return; + buf[x] = ff_vorbis_floor1_inverse_db_table[y]; + for (x = x0 + 1; x < x1; x++) { + if (x >= n) return; + err += ady; + if (err >= adx) { + err -= adx; + y += sy; + } else { + y += base; + } + buf[x] = ff_vorbis_floor1_inverse_db_table[y]; + } +} + +#define ilog(i) av_log2(2*(i)) #endif |