Mercurial > libavcodec.hg
annotate ffv1.c @ 4979:e103cbf64b76 libavcodec
make compilation of pnm.c optional
| author | aurel |
|---|---|
| date | Thu, 10 May 2007 23:16:56 +0000 |
| parents | f99e40a7155b |
| children | 2b72f9bc4f06 |
| rev | line source |
|---|---|
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1 /* |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
2 * FFV1 codec for libavcodec |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
3 * |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
4 * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at> |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
5 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
6 * This file is part of FFmpeg. |
|
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
7 * |
|
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
8 * FFmpeg is free software; you can redistribute it and/or |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
9 * modify it under the terms of the GNU Lesser General Public |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
10 * License as published by the Free Software Foundation; either |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
11 * version 2.1 of the License, or (at your option) any later version. |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
12 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
13 * FFmpeg is distributed in the hope that it will be useful, |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
16 * Lesser General Public License for more details. |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
17 * |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
18 * You should have received a copy of the GNU Lesser General Public |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3777
diff
changeset
|
19 * License along with FFmpeg; if not, write to the Free Software |
|
3036
0b546eab515d
Update licensing information: The FSF changed postal address.
diego
parents:
2967
diff
changeset
|
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
21 * |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
22 */ |
| 2967 | 23 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
24 /** |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
25 * @file ffv1.c |
|
1545
b340e83b8d0d
gcc->C99 and warning fixes patch by (Dan Christiansen <danchr at daimi dot au dot dk>)
michael
parents:
1522
diff
changeset
|
26 * FF Video Codec 1 (an experimental lossless codec) |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
27 */ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
28 |
|
4962
f99e40a7155b
Remove redundant #inclusion of common.h, avcodec.h already #includes it.
diego
parents:
4494
diff
changeset
|
29 #include "avcodec.h" |
|
2398
582e635cfa08
common.c -> bitstream.c (and the single non bitstream func -> utils.c)
michael
parents:
2339
diff
changeset
|
30 #include "bitstream.h" |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
31 #include "dsputil.h" |
| 2338 | 32 #include "rangecoder.h" |
| 1306 | 33 #include "golomb.h" |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
34 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
35 #define MAX_PLANES 4 |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
36 #define CONTEXT_SIZE 32 |
|
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
37 |
| 1306 | 38 static const int8_t quant3[256]={ |
| 39 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
| 40 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
| 41 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
| 42 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
| 43 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
| 44 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
45 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
46 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, |
| 1306 | 47 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, |
| 48 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 49 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 50 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 51 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 52 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 53 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, | |
| 54 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, 0, | |
| 55 }; | |
| 56 static const int8_t quant5[256]={ | |
| 57 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
58 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, |
| 1306 | 59 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, |
| 60 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 61 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 62 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 63 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 64 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 65 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 66 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 67 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 68 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 69 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 70 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 71 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 72 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-1,-1,-1, | |
| 73 }; | |
| 74 static const int8_t quant7[256]={ | |
| 75 0, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 76 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, | |
| 77 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 78 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 79 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 80 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 81 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 82 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 83 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, | |
| 84 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, | |
| 85 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, | |
| 86 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, | |
| 87 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, | |
| 88 -3,-3,-3,-3,-3,-3,-3,-3,-3,-2,-2,-2,-2,-2,-2,-2, | |
| 89 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, | |
| 90 -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-1,-1, | |
| 91 }; | |
| 92 static const int8_t quant9[256]={ | |
| 93 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, | |
| 94 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 95 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 96 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 97 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 98 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 99 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 100 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 101 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 102 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 103 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 104 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 105 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 106 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 107 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-3,-3,-3,-3, | |
| 108 -3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-2,-2,-2,-2,-1,-1, | |
| 109 }; | |
| 110 static const int8_t quant11[256]={ | |
| 111 0, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, | |
| 112 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 113 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 114 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 115 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 116 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 117 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 118 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 119 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 120 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 121 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 122 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 123 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 124 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-4,-4, | |
| 125 -4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, | |
| 126 -4,-4,-4,-4,-4,-3,-3,-3,-3,-3,-3,-3,-2,-2,-2,-1, | |
| 127 }; | |
| 128 static const int8_t quant13[256]={ | |
| 129 0, 1, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, | |
| 130 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 131 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, | |
| 132 5, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | |
| 133 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | |
| 134 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | |
| 135 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | |
| 136 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | |
| 137 -6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6, | |
| 138 -6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6, | |
| 139 -6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6, | |
| 140 -6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6, | |
| 141 -6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-6,-5, | |
| 142 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 143 -5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, | |
| 144 -4,-4,-4,-4,-4,-4,-4,-4,-4,-3,-3,-3,-3,-2,-2,-1, | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
145 }; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
146 |
| 1306 | 147 static const uint8_t log2_run[32]={ |
| 2967 | 148 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, |
| 149 4, 4, 5, 5, 6, 6, 7, 7, | |
| 1306 | 150 8, 9,10,11,12,13,14,15, |
| 151 }; | |
| 152 | |
| 153 typedef struct VlcState{ | |
| 154 int16_t drift; | |
| 155 uint16_t error_sum; | |
| 156 int8_t bias; | |
| 157 uint8_t count; | |
| 158 } VlcState; | |
| 159 | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
160 typedef struct PlaneContext{ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
161 int context_count; |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
162 uint8_t (*state)[CONTEXT_SIZE]; |
| 1306 | 163 VlcState *vlc_state; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
164 uint8_t interlace_bit_state[2]; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
165 } PlaneContext; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
166 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
167 typedef struct FFV1Context{ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
168 AVCodecContext *avctx; |
| 2338 | 169 RangeCoder c; |
| 1306 | 170 GetBitContext gb; |
| 171 PutBitContext pb; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
172 int version; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
173 int width, height; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
174 int chroma_h_shift, chroma_v_shift; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
175 int flags; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
176 int picture_number; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
177 AVFrame picture; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
178 int plane_count; |
| 1306 | 179 int ac; ///< 1-> CABAC 0-> golomb rice |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
180 PlaneContext plane[MAX_PLANES]; |
| 1306 | 181 int16_t quant_table[5][256]; |
| 1593 | 182 int run_index; |
| 183 int colorspace; | |
| 2967 | 184 |
| 185 DSPContext dsp; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
186 }FFV1Context; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
187 |
|
4283
d6f83e2f8804
rename always_inline to av_always_inline and move to common.h
mru
parents:
4001
diff
changeset
|
188 static av_always_inline int fold(int diff, int bits){ |
| 1593 | 189 if(bits==8) |
| 190 diff= (int8_t)diff; | |
| 191 else{ | |
| 192 diff+= 1<<(bits-1); | |
| 193 diff&=(1<<bits)-1; | |
| 194 diff-= 1<<(bits-1); | |
| 195 } | |
| 196 | |
| 197 return diff; | |
| 198 } | |
| 199 | |
| 200 static inline int predict(int_fast16_t *src, int_fast16_t *last){ | |
| 1306 | 201 const int LT= last[-1]; |
| 202 const int T= last[ 0]; | |
| 203 const int L = src[-1]; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
204 |
| 1360 | 205 return mid_pred(L, L + T - LT, T); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
206 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
207 |
| 1593 | 208 static inline int get_context(FFV1Context *f, int_fast16_t *src, int_fast16_t *last, int_fast16_t *last2){ |
| 1306 | 209 const int LT= last[-1]; |
| 210 const int T= last[ 0]; | |
| 211 const int RT= last[ 1]; | |
| 212 const int L = src[-1]; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
213 |
| 1306 | 214 if(f->quant_table[3][127]){ |
| 215 const int TT= last2[0]; | |
| 216 const int LL= src[-2]; | |
| 217 return f->quant_table[0][(L-LT) & 0xFF] + f->quant_table[1][(LT-T) & 0xFF] + f->quant_table[2][(T-RT) & 0xFF] | |
| 218 +f->quant_table[3][(LL-L) & 0xFF] + f->quant_table[4][(TT-T) & 0xFF]; | |
| 219 }else | |
| 220 return f->quant_table[0][(L-LT) & 0xFF] + f->quant_table[1][(LT-T) & 0xFF] + f->quant_table[2][(T-RT) & 0xFF]; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
221 } |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
222 |
| 2339 | 223 static inline void put_symbol(RangeCoder *c, uint8_t *state, int v, int is_signed){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
224 int i; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
225 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
226 if(v){ |
| 4001 | 227 const int a= FFABS(v); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
228 const int e= av_log2(a); |
| 2338 | 229 put_rac(c, state+0, 0); |
| 2967 | 230 |
| 2339 | 231 assert(e<=9); |
| 232 | |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
233 for(i=0; i<e; i++){ |
| 2339 | 234 put_rac(c, state+1+i, 1); //1..10 |
| 235 } | |
| 236 put_rac(c, state+1+i, 0); | |
| 237 | |
| 238 for(i=e-1; i>=0; i--){ | |
| 239 put_rac(c, state+22+i, (a>>i)&1); //22..31 | |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
240 } |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
241 |
| 2339 | 242 if(is_signed) |
| 243 put_rac(c, state+11 + e, v < 0); //11..21 | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
244 }else{ |
| 2338 | 245 put_rac(c, state+0, 1); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
246 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
247 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
248 |
| 2339 | 249 static inline int get_symbol(RangeCoder *c, uint8_t *state, int is_signed){ |
| 2338 | 250 if(get_rac(c, state+0)) |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
251 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
252 else{ |
| 2339 | 253 int i, e, a; |
| 254 e= 0; | |
| 255 while(get_rac(c, state+1 + e)){ //1..10 | |
| 256 e++; | |
| 257 } | |
| 258 assert(e<=9); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
259 |
| 2339 | 260 a= 1; |
| 261 for(i=e-1; i>=0; i--){ | |
| 262 a += a + get_rac(c, state+22 + i); //22..31 | |
| 263 } | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
264 |
| 2339 | 265 if(is_signed && get_rac(c, state+11 + e)) //11..21 |
| 266 return -a; | |
| 267 else | |
| 268 return a; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
269 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
270 } |
| 1306 | 271 |
| 272 static inline void update_vlc_state(VlcState * const state, const int v){ | |
| 273 int drift= state->drift; | |
| 274 int count= state->count; | |
| 4001 | 275 state->error_sum += FFABS(v); |
| 1306 | 276 drift += v; |
| 277 | |
| 278 if(count == 128){ //FIXME variable | |
| 279 count >>= 1; | |
| 280 drift >>= 1; | |
| 281 state->error_sum >>= 1; | |
| 282 } | |
| 283 count++; | |
| 284 | |
| 285 if(drift <= -count){ | |
| 286 if(state->bias > -128) state->bias--; | |
| 2967 | 287 |
| 1306 | 288 drift += count; |
| 289 if(drift <= -count) | |
| 290 drift= -count + 1; | |
| 291 }else if(drift > 0){ | |
| 292 if(state->bias < 127) state->bias++; | |
| 2967 | 293 |
| 1306 | 294 drift -= count; |
| 2967 | 295 if(drift > 0) |
| 1306 | 296 drift= 0; |
| 297 } | |
| 298 | |
| 299 state->drift= drift; | |
| 300 state->count= count; | |
| 301 } | |
| 302 | |
| 1593 | 303 static inline void put_vlc_symbol(PutBitContext *pb, VlcState * const state, int v, int bits){ |
| 1306 | 304 int i, k, code; |
| 305 //printf("final: %d ", v); | |
| 1593 | 306 v = fold(v - state->bias, bits); |
| 307 | |
| 1306 | 308 i= state->count; |
| 309 k=0; | |
| 310 while(i < state->error_sum){ //FIXME optimize | |
| 311 k++; | |
| 312 i += i; | |
| 313 } | |
|
1361
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
314 |
|
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
315 assert(k<=8); |
|
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
316 |
| 1306 | 317 #if 0 // JPEG LS |
| 318 if(k==0 && 2*state->drift <= - state->count) code= v ^ (-1); | |
| 319 else code= v; | |
| 320 #else | |
| 321 code= v ^ ((2*state->drift + state->count)>>31); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
322 #endif |
| 2967 | 323 |
| 1306 | 324 //printf("v:%d/%d bias:%d error:%d drift:%d count:%d k:%d\n", v, code, state->bias, state->error_sum, state->drift, state->count, k); |
| 2220 | 325 set_sr_golomb(pb, code, k, 12, bits); |
| 1306 | 326 |
| 327 update_vlc_state(state, v); | |
| 328 } | |
| 329 | |
| 1593 | 330 static inline int get_vlc_symbol(GetBitContext *gb, VlcState * const state, int bits){ |
| 1306 | 331 int k, i, v, ret; |
| 332 | |
| 333 i= state->count; | |
| 334 k=0; | |
| 335 while(i < state->error_sum){ //FIXME optimize | |
| 336 k++; | |
| 337 i += i; | |
| 338 } | |
|
1361
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
339 |
|
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
340 assert(k<=8); |
|
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
341 |
| 2220 | 342 v= get_sr_golomb(gb, k, 12, bits); |
| 1306 | 343 //printf("v:%d bias:%d error:%d drift:%d count:%d k:%d", v, state->bias, state->error_sum, state->drift, state->count, k); |
|
1361
8479b875a989
golomb rice code cleanup / simplify (~0.5% compression gain and slightly faster)
michaelni
parents:
1360
diff
changeset
|
344 |
| 1306 | 345 #if 0 // JPEG LS |
| 346 if(k==0 && 2*state->drift <= - state->count) v ^= (-1); | |
| 347 #else | |
| 348 v ^= ((2*state->drift + state->count)>>31); | |
| 349 #endif | |
| 350 | |
| 1593 | 351 ret= fold(v + state->bias, bits); |
| 2967 | 352 |
| 1306 | 353 update_vlc_state(state, v); |
| 354 //printf("final: %d\n", ret); | |
| 355 return ret; | |
| 356 } | |
| 357 | |
| 3777 | 358 #ifdef CONFIG_ENCODERS |
| 2422 | 359 static inline int encode_line(FFV1Context *s, int w, int_fast16_t *sample[2], int plane_index, int bits){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
360 PlaneContext * const p= &s->plane[plane_index]; |
| 2338 | 361 RangeCoder * const c= &s->c; |
| 1593 | 362 int x; |
| 363 int run_index= s->run_index; | |
| 364 int run_count=0; | |
| 365 int run_mode=0; | |
| 366 | |
| 2422 | 367 if(s->ac){ |
| 368 if(c->bytestream_end - c->bytestream < w*20){ | |
| 369 av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n"); | |
| 370 return -1; | |
| 371 } | |
| 372 }else{ | |
| 373 if(s->pb.buf_end - s->pb.buf - (put_bits_count(&s->pb)>>3) < w*4){ | |
| 374 av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n"); | |
| 375 return -1; | |
| 376 } | |
| 377 } | |
| 378 | |
| 1593 | 379 for(x=0; x<w; x++){ |
| 380 int diff, context; | |
| 2967 | 381 |
| 1999 | 382 context= get_context(s, sample[0]+x, sample[1]+x, sample[2]+x); |
| 383 diff= sample[0][x] - predict(sample[0]+x, sample[1]+x); | |
| 1593 | 384 |
| 385 if(context < 0){ | |
| 386 context = -context; | |
| 387 diff= -diff; | |
| 388 } | |
| 389 | |
| 390 diff= fold(diff, bits); | |
| 2967 | 391 |
| 1593 | 392 if(s->ac){ |
| 2339 | 393 put_symbol(c, p->state[context], diff, 1); |
| 1593 | 394 }else{ |
| 395 if(context == 0) run_mode=1; | |
| 2967 | 396 |
| 1593 | 397 if(run_mode){ |
| 398 | |
| 399 if(diff){ | |
| 400 while(run_count >= 1<<log2_run[run_index]){ | |
| 401 run_count -= 1<<log2_run[run_index]; | |
| 402 run_index++; | |
| 403 put_bits(&s->pb, 1, 1); | |
| 404 } | |
| 2967 | 405 |
| 1593 | 406 put_bits(&s->pb, 1 + log2_run[run_index], run_count); |
| 407 if(run_index) run_index--; | |
| 408 run_count=0; | |
| 409 run_mode=0; | |
| 410 if(diff>0) diff--; | |
| 411 }else{ | |
| 412 run_count++; | |
| 413 } | |
| 414 } | |
| 2967 | 415 |
| 1786 | 416 // printf("count:%d index:%d, mode:%d, x:%d y:%d pos:%d\n", run_count, run_index, run_mode, x, y, (int)put_bits_count(&s->pb)); |
| 1593 | 417 |
| 418 if(run_mode == 0) | |
| 419 put_vlc_symbol(&s->pb, &p->vlc_state[context], diff, bits); | |
| 420 } | |
| 421 } | |
| 422 if(run_mode){ | |
| 423 while(run_count >= 1<<log2_run[run_index]){ | |
| 424 run_count -= 1<<log2_run[run_index]; | |
| 425 run_index++; | |
| 426 put_bits(&s->pb, 1, 1); | |
| 427 } | |
| 428 | |
| 429 if(run_count) | |
| 430 put_bits(&s->pb, 1, 1); | |
| 431 } | |
| 432 s->run_index= run_index; | |
| 2967 | 433 |
| 2422 | 434 return 0; |
| 1593 | 435 } |
| 436 | |
| 437 static void encode_plane(FFV1Context *s, uint8_t *src, int w, int h, int stride, int plane_index){ | |
| 1999 | 438 int x,y,i; |
| 2162 | 439 const int ring_size= s->avctx->context_model ? 3 : 2; |
| 1999 | 440 int_fast16_t sample_buffer[ring_size][w+6], *sample[ring_size]; |
| 1593 | 441 s->run_index=0; |
| 2967 | 442 |
| 1337 | 443 memset(sample_buffer, 0, sizeof(sample_buffer)); |
| 2967 | 444 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
445 for(y=0; y<h; y++){ |
| 1999 | 446 for(i=0; i<ring_size; i++) |
| 447 sample[i]= sample_buffer[(h+i-y)%ring_size]+3; | |
| 2967 | 448 |
| 1999 | 449 sample[0][-1]= sample[1][0 ]; |
| 450 sample[1][ w]= sample[1][w-1]; | |
| 1593 | 451 //{START_TIMER |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
452 for(x=0; x<w; x++){ |
| 1999 | 453 sample[0][x]= src[x + stride*y]; |
| 1593 | 454 } |
| 455 encode_line(s, w, sample, plane_index, 8); | |
| 456 //STOP_TIMER("encode line")} | |
| 457 } | |
| 458 } | |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
459 |
| 1593 | 460 static void encode_rgb_frame(FFV1Context *s, uint32_t *src, int w, int h, int stride){ |
| 1999 | 461 int x, y, p, i; |
| 2162 | 462 const int ring_size= s->avctx->context_model ? 3 : 2; |
| 1999 | 463 int_fast16_t sample_buffer[3][ring_size][w+6], *sample[3][ring_size]; |
| 1593 | 464 s->run_index=0; |
| 2967 | 465 |
| 1593 | 466 memset(sample_buffer, 0, sizeof(sample_buffer)); |
| 2967 | 467 |
| 1593 | 468 for(y=0; y<h; y++){ |
| 1999 | 469 for(i=0; i<ring_size; i++) |
| 470 for(p=0; p<3; p++) | |
| 471 sample[p][i]= sample_buffer[p][(h+i-y)%ring_size]+3; | |
| 472 | |
| 1593 | 473 for(x=0; x<w; x++){ |
| 474 int v= src[x + stride*y]; | |
| 475 int b= v&0xFF; | |
| 476 int g= (v>>8)&0xFF; | |
| 477 int r= (v>>16)&0xFF; | |
| 2967 | 478 |
| 1593 | 479 b -= g; |
| 480 r -= g; | |
| 481 g += (b + r)>>2; | |
| 482 b += 0x100; | |
| 483 r += 0x100; | |
| 2967 | 484 |
| 1593 | 485 // assert(g>=0 && b>=0 && r>=0); |
| 486 // assert(g<256 && b<512 && r<512); | |
| 487 sample[0][0][x]= g; | |
| 488 sample[1][0][x]= b; | |
| 489 sample[2][0][x]= r; | |
| 490 } | |
| 491 for(p=0; p<3; p++){ | |
| 1999 | 492 sample[p][0][-1]= sample[p][1][0 ]; |
| 493 sample[p][1][ w]= sample[p][1][w-1]; | |
| 1593 | 494 encode_line(s, w, sample[p], FFMIN(p, 1), 9); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
495 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
496 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
497 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
498 |
| 2338 | 499 static void write_quant_table(RangeCoder *c, int16_t *quant_table){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
500 int last=0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
501 int i; |
| 2338 | 502 uint8_t state[CONTEXT_SIZE]; |
| 503 memset(state, 128, sizeof(state)); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
504 |
| 1306 | 505 for(i=1; i<128 ; i++){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
506 if(quant_table[i] != quant_table[i-1]){ |
| 2339 | 507 put_symbol(c, state, i-last-1, 0); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
508 last= i; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
509 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
510 } |
| 2339 | 511 put_symbol(c, state, i-last-1, 0); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
512 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
513 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
514 static void write_header(FFV1Context *f){ |
| 2338 | 515 uint8_t state[CONTEXT_SIZE]; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
516 int i; |
| 2338 | 517 RangeCoder * const c= &f->c; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
518 |
| 2338 | 519 memset(state, 128, sizeof(state)); |
| 2967 | 520 |
| 2339 | 521 put_symbol(c, state, f->version, 0); |
| 522 put_symbol(c, state, f->avctx->coder_type, 0); | |
| 2967 | 523 put_symbol(c, state, f->colorspace, 0); //YUV cs type |
| 2338 | 524 put_rac(c, state, 1); //chroma planes |
| 2339 | 525 put_symbol(c, state, f->chroma_h_shift, 0); |
| 526 put_symbol(c, state, f->chroma_v_shift, 0); | |
| 2338 | 527 put_rac(c, state, 0); //no transparency plane |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
528 |
| 1306 | 529 for(i=0; i<5; i++) |
| 530 write_quant_table(c, f->quant_table[i]); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
531 } |
| 3777 | 532 #endif /* CONFIG_ENCODERS */ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
533 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
534 static int common_init(AVCodecContext *avctx){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
535 FFV1Context *s = avctx->priv_data; |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
536 int width, height; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
537 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
538 s->avctx= avctx; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
539 s->flags= avctx->flags; |
| 2967 | 540 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
541 dsputil_init(&s->dsp, avctx); |
| 2967 | 542 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
543 width= s->width= avctx->width; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
544 height= s->height= avctx->height; |
| 2967 | 545 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
546 assert(width && height); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
547 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
548 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
549 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
550 |
| 3777 | 551 #ifdef CONFIG_ENCODERS |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
552 static int encode_init(AVCodecContext *avctx) |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
553 { |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
554 FFV1Context *s = avctx->priv_data; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
555 int i; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
556 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
557 common_init(avctx); |
| 2967 | 558 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
559 s->version=0; |
| 1306 | 560 s->ac= avctx->coder_type; |
| 2967 | 561 |
|
1345
daf951f32697
merge U and V statistics, 33% reduction in memory requirement, compression rate better for some files worse for others, worst compression rate loss 0.05%
michaelni
parents:
1337
diff
changeset
|
562 s->plane_count=2; |
| 1306 | 563 for(i=0; i<256; i++){ |
| 564 s->quant_table[0][i]= quant11[i]; | |
| 565 s->quant_table[1][i]= 11*quant11[i]; | |
| 566 if(avctx->context_model==0){ | |
| 567 s->quant_table[2][i]= 11*11*quant11[i]; | |
| 568 s->quant_table[3][i]= | |
| 569 s->quant_table[4][i]=0; | |
| 570 }else{ | |
| 571 s->quant_table[2][i]= 11*11*quant5 [i]; | |
| 572 s->quant_table[3][i]= 5*11*11*quant5 [i]; | |
| 573 s->quant_table[4][i]= 5*5*11*11*quant5 [i]; | |
| 574 } | |
| 575 } | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
576 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
577 for(i=0; i<s->plane_count; i++){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
578 PlaneContext * const p= &s->plane[i]; |
| 2967 | 579 |
| 1306 | 580 if(avctx->context_model==0){ |
| 581 p->context_count= (11*11*11+1)/2; | |
| 2967 | 582 }else{ |
| 1306 | 583 p->context_count= (11*11*5*5*5+1)/2; |
| 584 } | |
| 585 | |
| 586 if(s->ac){ | |
| 587 if(!p->state) p->state= av_malloc(CONTEXT_SIZE*p->context_count*sizeof(uint8_t)); | |
| 588 }else{ | |
| 589 if(!p->vlc_state) p->vlc_state= av_malloc(p->context_count*sizeof(VlcState)); | |
| 590 } | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
591 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
592 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
593 avctx->coded_frame= &s->picture; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
594 switch(avctx->pix_fmt){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
595 case PIX_FMT_YUV444P: |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
596 case PIX_FMT_YUV422P: |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
597 case PIX_FMT_YUV420P: |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
598 case PIX_FMT_YUV411P: |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
599 case PIX_FMT_YUV410P: |
| 1593 | 600 s->colorspace= 0; |
| 601 break; | |
|
4494
ce643a22f049
Replace deprecated PIX_FMT names by the newer variants.
diego
parents:
4283
diff
changeset
|
602 case PIX_FMT_RGB32: |
| 1593 | 603 s->colorspace= 1; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
604 break; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
605 default: |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
606 av_log(avctx, AV_LOG_ERROR, "format not supported\n"); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
607 return -1; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
608 } |
| 1593 | 609 avcodec_get_chroma_sub_sample(avctx->pix_fmt, &s->chroma_h_shift, &s->chroma_v_shift); |
| 610 | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
611 s->picture_number=0; |
| 2967 | 612 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
613 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
614 } |
| 3777 | 615 #endif /* CONFIG_ENCODERS */ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
616 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
617 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
618 static void clear_state(FFV1Context *f){ |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
619 int i, j; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
620 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
621 for(i=0; i<f->plane_count; i++){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
622 PlaneContext *p= &f->plane[i]; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
623 |
| 2338 | 624 p->interlace_bit_state[0]= 128; |
| 625 p->interlace_bit_state[1]= 128; | |
| 2967 | 626 |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
627 for(j=0; j<p->context_count; j++){ |
| 1306 | 628 if(f->ac){ |
| 2338 | 629 memset(p->state[j], 128, sizeof(uint8_t)*CONTEXT_SIZE); |
| 1306 | 630 }else{ |
| 631 p->vlc_state[j].drift= 0; | |
| 632 p->vlc_state[j].error_sum= 4; //FFMAX((RANGE + 32)/64, 2); | |
| 633 p->vlc_state[j].bias= 0; | |
| 634 p->vlc_state[j].count= 1; | |
| 635 } | |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
636 } |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
637 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
638 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
639 |
| 3777 | 640 #ifdef CONFIG_ENCODERS |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
641 static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size, void *data){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
642 FFV1Context *f = avctx->priv_data; |
| 2338 | 643 RangeCoder * const c= &f->c; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
644 AVFrame *pict = data; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
645 const int width= f->width; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
646 const int height= f->height; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
647 AVFrame * const p= &f->picture; |
| 1306 | 648 int used_count= 0; |
| 2338 | 649 uint8_t keystate=128; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
650 |
| 2338 | 651 ff_init_range_encoder(c, buf, buf_size); |
| 652 // ff_init_cabac_states(c, ff_h264_lps_range, ff_h264_mps_state, ff_h264_lps_state, 64); | |
| 653 ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); | |
| 654 | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
655 *p = *pict; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
656 p->pict_type= FF_I_TYPE; |
| 2967 | 657 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
658 if(avctx->gop_size==0 || f->picture_number % avctx->gop_size == 0){ |
| 2338 | 659 put_rac(c, &keystate, 1); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
660 p->key_frame= 1; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
661 write_header(f); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
662 clear_state(f); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
663 }else{ |
| 2338 | 664 put_rac(c, &keystate, 0); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
665 p->key_frame= 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
666 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
667 |
| 1306 | 668 if(!f->ac){ |
| 2338 | 669 used_count += ff_rac_terminate(c); |
| 1306 | 670 //printf("pos=%d\n", used_count); |
|
1522
79dddc5cd990
removed the obsolete and unused parameters of init_put_bits
alex
parents:
1453
diff
changeset
|
671 init_put_bits(&f->pb, buf + used_count, buf_size - used_count); |
| 1306 | 672 } |
| 2967 | 673 |
| 1593 | 674 if(f->colorspace==0){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
675 const int chroma_width = -((-width )>>f->chroma_h_shift); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
676 const int chroma_height= -((-height)>>f->chroma_v_shift); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
677 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
678 encode_plane(f, p->data[0], width, height, p->linesize[0], 0); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
679 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
680 encode_plane(f, p->data[1], chroma_width, chroma_height, p->linesize[1], 1); |
|
1345
daf951f32697
merge U and V statistics, 33% reduction in memory requirement, compression rate better for some files worse for others, worst compression rate loss 0.05%
michaelni
parents:
1337
diff
changeset
|
681 encode_plane(f, p->data[2], chroma_width, chroma_height, p->linesize[2], 1); |
| 1593 | 682 }else{ |
| 683 encode_rgb_frame(f, (uint32_t*)(p->data[0]), width, height, p->linesize[0]/4); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
684 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
685 emms_c(); |
| 2967 | 686 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
687 f->picture_number++; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
688 |
| 1306 | 689 if(f->ac){ |
| 2338 | 690 return ff_rac_terminate(c); |
| 1306 | 691 }else{ |
| 692 flush_put_bits(&f->pb); //nicer padding FIXME | |
| 1786 | 693 return used_count + (put_bits_count(&f->pb)+7)/8; |
| 1306 | 694 } |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
695 } |
| 3777 | 696 #endif /* CONFIG_ENCODERS */ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
697 |
| 3283 | 698 static int common_end(AVCodecContext *avctx){ |
| 699 FFV1Context *s = avctx->priv_data; | |
| 2967 | 700 int i; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
701 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
702 for(i=0; i<s->plane_count; i++){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
703 PlaneContext *p= &s->plane[i]; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
704 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
705 av_freep(&p->state); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
706 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
707 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
708 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
709 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
710 |
| 1605 | 711 static inline void decode_line(FFV1Context *s, int w, int_fast16_t *sample[2], int plane_index, int bits){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
712 PlaneContext * const p= &s->plane[plane_index]; |
| 2338 | 713 RangeCoder * const c= &s->c; |
| 1593 | 714 int x; |
| 715 int run_count=0; | |
| 716 int run_mode=0; | |
| 717 int run_index= s->run_index; | |
| 718 | |
| 719 for(x=0; x<w; x++){ | |
| 720 int diff, context, sign; | |
| 2967 | 721 |
| 1593 | 722 context= get_context(s, sample[1] + x, sample[0] + x, sample[1] + x); |
| 723 if(context < 0){ | |
| 724 context= -context; | |
| 725 sign=1; | |
| 726 }else | |
| 727 sign=0; | |
| 2967 | 728 |
| 1593 | 729 |
| 2339 | 730 if(s->ac){ |
| 731 diff= get_symbol(c, p->state[context], 1); | |
| 732 }else{ | |
| 1593 | 733 if(context == 0 && run_mode==0) run_mode=1; |
| 2967 | 734 |
| 1593 | 735 if(run_mode){ |
| 736 if(run_count==0 && run_mode==1){ | |
| 737 if(get_bits1(&s->gb)){ | |
| 738 run_count = 1<<log2_run[run_index]; | |
| 739 if(x + run_count <= w) run_index++; | |
| 740 }else{ | |
| 741 if(log2_run[run_index]) run_count = get_bits(&s->gb, log2_run[run_index]); | |
| 742 else run_count=0; | |
| 743 if(run_index) run_index--; | |
| 744 run_mode=2; | |
| 745 } | |
| 746 } | |
| 747 run_count--; | |
| 748 if(run_count < 0){ | |
| 749 run_mode=0; | |
| 750 run_count=0; | |
| 751 diff= get_vlc_symbol(&s->gb, &p->vlc_state[context], bits); | |
| 752 if(diff>=0) diff++; | |
| 753 }else | |
| 754 diff=0; | |
| 755 }else | |
| 756 diff= get_vlc_symbol(&s->gb, &p->vlc_state[context], bits); | |
| 2967 | 757 |
| 1593 | 758 // printf("count:%d index:%d, mode:%d, x:%d y:%d pos:%d\n", run_count, run_index, run_mode, x, y, get_bits_count(&s->gb)); |
| 759 } | |
| 760 | |
| 761 if(sign) diff= -diff; | |
| 762 | |
| 763 sample[1][x]= (predict(sample[1] + x, sample[0] + x) + diff) & ((1<<bits)-1); | |
| 764 } | |
| 2967 | 765 s->run_index= run_index; |
| 1593 | 766 } |
| 767 | |
| 768 static void decode_plane(FFV1Context *s, uint8_t *src, int w, int h, int stride, int plane_index){ | |
| 769 int x, y; | |
| 770 int_fast16_t sample_buffer[2][w+6]; | |
| 771 int_fast16_t *sample[2]= {sample_buffer[0]+3, sample_buffer[1]+3}; | |
| 772 | |
| 773 s->run_index=0; | |
| 2967 | 774 |
| 1337 | 775 memset(sample_buffer, 0, sizeof(sample_buffer)); |
| 2967 | 776 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
777 for(y=0; y<h; y++){ |
| 1593 | 778 int_fast16_t *temp= sample[0]; //FIXME try a normal buffer |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
779 |
| 1337 | 780 sample[0]= sample[1]; |
| 781 sample[1]= temp; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
782 |
| 1337 | 783 sample[1][-1]= sample[0][0 ]; |
| 784 sample[0][ w]= sample[0][w-1]; | |
| 2967 | 785 |
| 1593 | 786 //{START_TIMER |
| 787 decode_line(s, w, sample, plane_index, 8); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
788 for(x=0; x<w; x++){ |
| 1593 | 789 src[x + stride*y]= sample[1][x]; |
| 790 } | |
| 791 //STOP_TIMER("decode-line")} | |
| 792 } | |
| 793 } | |
| 794 | |
| 795 static void decode_rgb_frame(FFV1Context *s, uint32_t *src, int w, int h, int stride){ | |
| 796 int x, y, p; | |
| 797 int_fast16_t sample_buffer[3][2][w+6]; | |
| 798 int_fast16_t *sample[3][2]= { | |
| 799 {sample_buffer[0][0]+3, sample_buffer[0][1]+3}, | |
| 800 {sample_buffer[1][0]+3, sample_buffer[1][1]+3}, | |
| 801 {sample_buffer[2][0]+3, sample_buffer[2][1]+3}}; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
802 |
| 1593 | 803 s->run_index=0; |
| 2967 | 804 |
| 1593 | 805 memset(sample_buffer, 0, sizeof(sample_buffer)); |
| 2967 | 806 |
| 1593 | 807 for(y=0; y<h; y++){ |
| 808 for(p=0; p<3; p++){ | |
| 809 int_fast16_t *temp= sample[p][0]; //FIXME try a normal buffer | |
| 810 | |
| 811 sample[p][0]= sample[p][1]; | |
| 812 sample[p][1]= temp; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
813 |
| 1593 | 814 sample[p][1][-1]= sample[p][0][0 ]; |
| 815 sample[p][0][ w]= sample[p][0][w-1]; | |
| 816 decode_line(s, w, sample[p], FFMIN(p, 1), 9); | |
| 817 } | |
| 818 for(x=0; x<w; x++){ | |
| 819 int g= sample[0][1][x]; | |
| 820 int b= sample[1][1][x]; | |
| 821 int r= sample[2][1][x]; | |
| 1306 | 822 |
| 1593 | 823 // assert(g>=0 && b>=0 && r>=0); |
| 824 // assert(g<256 && b<512 && r<512); | |
| 2967 | 825 |
| 1593 | 826 b -= 0x100; |
| 827 r -= 0x100; | |
| 828 g -= (b + r)>>2; | |
| 829 b += g; | |
| 830 r += g; | |
| 2967 | 831 |
| 1593 | 832 src[x + stride*y]= b + (g<<8) + (r<<16); |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
833 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
834 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
835 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
836 |
| 2338 | 837 static int read_quant_table(RangeCoder *c, int16_t *quant_table, int scale){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
838 int v; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
839 int i=0; |
| 2338 | 840 uint8_t state[CONTEXT_SIZE]; |
| 841 | |
| 842 memset(state, 128, sizeof(state)); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
843 |
| 1306 | 844 for(v=0; i<128 ; v++){ |
| 2339 | 845 int len= get_symbol(c, state, 0) + 1; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
846 |
| 1306 | 847 if(len + i > 128) return -1; |
| 2967 | 848 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
849 while(len--){ |
| 1306 | 850 quant_table[i] = scale*v; |
| 851 i++; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
852 //printf("%2d ",v); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
853 //if(i%16==0) printf("\n"); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
854 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
855 } |
| 1306 | 856 |
| 857 for(i=1; i<128; i++){ | |
| 858 quant_table[256-i]= -quant_table[i]; | |
| 859 } | |
| 860 quant_table[128]= -quant_table[127]; | |
| 2967 | 861 |
| 1306 | 862 return 2*v - 1; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
863 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
864 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
865 static int read_header(FFV1Context *f){ |
| 2338 | 866 uint8_t state[CONTEXT_SIZE]; |
| 1306 | 867 int i, context_count; |
| 2338 | 868 RangeCoder * const c= &f->c; |
| 2967 | 869 |
| 2338 | 870 memset(state, 128, sizeof(state)); |
| 871 | |
| 2339 | 872 f->version= get_symbol(c, state, 0); |
| 873 f->ac= f->avctx->coder_type= get_symbol(c, state, 0); | |
| 874 f->colorspace= get_symbol(c, state, 0); //YUV cs type | |
| 2338 | 875 get_rac(c, state); //no chroma = false |
| 2339 | 876 f->chroma_h_shift= get_symbol(c, state, 0); |
| 877 f->chroma_v_shift= get_symbol(c, state, 0); | |
| 2338 | 878 get_rac(c, state); //transparency plane |
|
1345
daf951f32697
merge U and V statistics, 33% reduction in memory requirement, compression rate better for some files worse for others, worst compression rate loss 0.05%
michaelni
parents:
1337
diff
changeset
|
879 f->plane_count= 2; |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
880 |
| 1593 | 881 if(f->colorspace==0){ |
| 882 switch(16*f->chroma_h_shift + f->chroma_v_shift){ | |
| 883 case 0x00: f->avctx->pix_fmt= PIX_FMT_YUV444P; break; | |
| 884 case 0x10: f->avctx->pix_fmt= PIX_FMT_YUV422P; break; | |
| 885 case 0x11: f->avctx->pix_fmt= PIX_FMT_YUV420P; break; | |
| 886 case 0x20: f->avctx->pix_fmt= PIX_FMT_YUV411P; break; | |
|
2512
a7779d61c8ce
Fixed decoding of 410p ffv1 files patch by (Milan Cutka <cutka szm sk>)
michael
parents:
2453
diff
changeset
|
887 case 0x22: f->avctx->pix_fmt= PIX_FMT_YUV410P; break; |
| 1593 | 888 default: |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
889 av_log(f->avctx, AV_LOG_ERROR, "format not supported\n"); |
| 1593 | 890 return -1; |
| 891 } | |
| 892 }else if(f->colorspace==1){ | |
| 893 if(f->chroma_h_shift || f->chroma_v_shift){ | |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
894 av_log(f->avctx, AV_LOG_ERROR, "chroma subsampling not supported in this colorspace\n"); |
| 1593 | 895 return -1; |
| 896 } | |
|
4494
ce643a22f049
Replace deprecated PIX_FMT names by the newer variants.
diego
parents:
4283
diff
changeset
|
897 f->avctx->pix_fmt= PIX_FMT_RGB32; |
| 1593 | 898 }else{ |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
899 av_log(f->avctx, AV_LOG_ERROR, "colorspace not supported\n"); |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
900 return -1; |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
901 } |
| 1593 | 902 |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
903 //printf("%d %d %d\n", f->chroma_h_shift, f->chroma_v_shift,f->avctx->pix_fmt); |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
904 |
| 1306 | 905 context_count=1; |
| 906 for(i=0; i<5; i++){ | |
| 907 context_count*= read_quant_table(c, f->quant_table[i], context_count); | |
| 2422 | 908 if(context_count < 0 || context_count > 32768){ |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
909 av_log(f->avctx, AV_LOG_ERROR, "read_quant_table error\n"); |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
910 return -1; |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
911 } |
| 1306 | 912 } |
| 913 context_count= (context_count+1)/2; | |
| 2967 | 914 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
915 for(i=0; i<f->plane_count; i++){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
916 PlaneContext * const p= &f->plane[i]; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
917 |
| 1306 | 918 p->context_count= context_count; |
| 919 | |
| 920 if(f->ac){ | |
| 921 if(!p->state) p->state= av_malloc(CONTEXT_SIZE*p->context_count*sizeof(uint8_t)); | |
| 922 }else{ | |
| 923 if(!p->vlc_state) p->vlc_state= av_malloc(p->context_count*sizeof(VlcState)); | |
| 924 } | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
925 } |
| 2967 | 926 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
927 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
928 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
929 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
930 static int decode_init(AVCodecContext *avctx) |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
931 { |
| 1306 | 932 // FFV1Context *s = avctx->priv_data; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
933 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
934 common_init(avctx); |
| 2967 | 935 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
936 return 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
937 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
938 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
939 static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, uint8_t *buf, int buf_size){ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
940 FFV1Context *f = avctx->priv_data; |
| 2338 | 941 RangeCoder * const c= &f->c; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
942 const int width= f->width; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
943 const int height= f->height; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
944 AVFrame * const p= &f->picture; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
945 int bytes_read; |
| 2338 | 946 uint8_t keystate= 128; |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
947 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
948 AVFrame *picture = data; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
949 |
| 2338 | 950 ff_init_range_decoder(c, buf, buf_size); |
| 951 ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); | |
|
1908
e20fd60b215c
h264 - progressive I frame CABAC support patch by (Laurent Aimar <fenrir at via dot ecp dot fr>)
michael
parents:
1786
diff
changeset
|
952 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
953 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
954 p->pict_type= FF_I_TYPE; //FIXME I vs. P |
| 2338 | 955 if(get_rac(c, &keystate)){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
956 p->key_frame= 1; |
| 3103 | 957 if(read_header(f) < 0) |
| 958 return -1; | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
959 clear_state(f); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
960 }else{ |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
961 p->key_frame= 0; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
962 } |
| 3103 | 963 if(!f->plane[0].state && !f->plane[0].vlc_state) |
| 964 return -1; | |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
965 |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
966 p->reference= 0; |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
967 if(avctx->get_buffer(avctx, p) < 0){ |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
968 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); |
|
1336
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
969 return -1; |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
970 } |
|
c16ac5b7ac79
20% less memory needed for 8bit AC state (worst compression rate loss was 0.2%, all other files had <=0.1% loss)
michaelni
parents:
1325
diff
changeset
|
971 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
972 if(avctx->debug&FF_DEBUG_PICT_INFO) |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
973 av_log(avctx, AV_LOG_ERROR, "keyframe:%d coder:%d\n", p->key_frame, f->ac); |
| 2967 | 974 |
| 1306 | 975 if(!f->ac){ |
| 2338 | 976 bytes_read = c->bytestream - c->bytestream_start - 1; |
| 977 if(bytes_read ==0) av_log(avctx, AV_LOG_ERROR, "error at end of AC stream\n"); //FIXME | |
| 1306 | 978 //printf("pos=%d\n", bytes_read); |
| 979 init_get_bits(&f->gb, buf + bytes_read, buf_size - bytes_read); | |
| 1453 | 980 } else { |
| 981 bytes_read = 0; /* avoid warning */ | |
| 1306 | 982 } |
| 2967 | 983 |
| 1593 | 984 if(f->colorspace==0){ |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
985 const int chroma_width = -((-width )>>f->chroma_h_shift); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
986 const int chroma_height= -((-height)>>f->chroma_v_shift); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
987 decode_plane(f, p->data[0], width, height, p->linesize[0], 0); |
| 2967 | 988 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
989 decode_plane(f, p->data[1], chroma_width, chroma_height, p->linesize[1], 1); |
|
1345
daf951f32697
merge U and V statistics, 33% reduction in memory requirement, compression rate better for some files worse for others, worst compression rate loss 0.05%
michaelni
parents:
1337
diff
changeset
|
990 decode_plane(f, p->data[2], chroma_width, chroma_height, p->linesize[2], 1); |
| 1593 | 991 }else{ |
| 992 decode_rgb_frame(f, (uint32_t*)p->data[0], width, height, p->linesize[0]/4); | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
993 } |
| 2967 | 994 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
995 emms_c(); |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
996 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
997 f->picture_number++; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
998 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
999 *picture= *p; |
| 2967 | 1000 |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1001 avctx->release_buffer(avctx, p); //FIXME |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1002 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1003 *data_size = sizeof(AVFrame); |
| 2967 | 1004 |
| 1306 | 1005 if(f->ac){ |
| 2338 | 1006 bytes_read= c->bytestream - c->bytestream_start - 1; |
|
1598
932d306bf1dc
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1593
diff
changeset
|
1007 if(bytes_read ==0) av_log(f->avctx, AV_LOG_ERROR, "error at end of frame\n"); |
| 1306 | 1008 }else{ |
| 1009 bytes_read+= (get_bits_count(&f->gb)+7)/8; | |
| 1010 } | |
| 1011 | |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1012 return bytes_read; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1013 } |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1014 |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1015 AVCodec ffv1_decoder = { |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1016 "ffv1", |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1017 CODEC_TYPE_VIDEO, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1018 CODEC_ID_FFV1, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1019 sizeof(FFV1Context), |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1020 decode_init, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1021 NULL, |
| 3283 | 1022 common_end, |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1023 decode_frame, |
|
1302
c41f51b5d5d6
reducing memory consumption (reducing number of contexts and other stuff, no noticeable loss in compression rate)
michaelni
parents:
1300
diff
changeset
|
1024 CODEC_CAP_DR1 /*| CODEC_CAP_DRAW_HORIZ_BAND*/, |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1025 NULL |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1026 }; |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1027 |
| 1325 | 1028 #ifdef CONFIG_ENCODERS |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1029 AVCodec ffv1_encoder = { |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1030 "ffv1", |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1031 CODEC_TYPE_VIDEO, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1032 CODEC_ID_FFV1, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1033 sizeof(FFV1Context), |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1034 encode_init, |
|
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1035 encode_frame, |
| 3283 | 1036 common_end, |
|
4494
ce643a22f049
Replace deprecated PIX_FMT names by the newer variants.
diego
parents:
4283
diff
changeset
|
1037 .pix_fmts= (enum PixelFormat[]){PIX_FMT_YUV420P, PIX_FMT_YUV444P, PIX_FMT_YUV422P, PIX_FMT_YUV411P, PIX_FMT_YUV410P, PIX_FMT_RGB32, -1}, |
|
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
diff
changeset
|
1038 }; |
| 1325 | 1039 #endif |
