]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Original Commit: r64 | ods15 | 2006-09-25 18:39:30 +0300 (Mon, 25 Sep 2006) | 2 lines
authorods15 <ods15@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 2 Oct 2006 06:07:55 +0000 (06:07 +0000)
committerods15 <ods15@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Mon, 2 Oct 2006 06:07:55 +0000 (06:07 +0000)
some fixes to floor

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@6469 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavcodec/vorbis_enc.c

index 43e0a18e0c299bdd57657c782c6ea5dfff28ed9f..cedaec9a1621844bb62bf13514206caa3a73b5c0 100644 (file)
@@ -717,13 +717,16 @@ static void floor_encode(venc_context_t * venc, floor_t * fc, PutBitContext * pb
         if (predicted == posts[i]) {
             coded[i] = 0; // must be used later as flag!
             continue;
+        } else {
+            if (!coded[fc->list[i].low]) coded[fc->list[i].low] = -1;
+            if (!coded[fc->list[i].high]) coded[fc->list[i].high] = -1;
         }
         if (posts[i] > predicted) {
             if (posts[i] - predicted > room) coded[i] = posts[i] - predicted + lowroom;
             else coded[i] = (posts[i] - predicted) << 1;
         } else {
             if (predicted - posts[i] > room) coded[i] = predicted - posts[i] + highroom - 1;
-            else coded[i] = ((predicted - posts[i]) << 1) + 1;
+            else coded[i] = ((predicted - posts[i]) << 1) - 1;
         }
     }
 
@@ -735,7 +738,7 @@ static void floor_encode(venc_context_t * venc, floor_t * fc, PutBitContext * pb
         assert(!c->subclass);
         for (k = 0; k < c->dim; k++) {
             int entry = coded[counter++];
-            if (entry >= book->nentries || entry < 0) av_log(NULL, AV_LOG_ERROR, "%d %d %d %d \n", entry, book->nentries, counter, fc->values);
+            if (entry == -1) entry = 0;
             assert(entry < book->nentries);
             assert(entry >= 0);
             put_bits(pb, book->entries[entry].len, book->entries[entry].codeword);