Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
dd18c9a0
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
dd18c9a0
编写于
2月 03, 2011
作者:
J
Jason Garrett-Glaser
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
VP8: simplify lf_delta mb mode logic
上级
4359288c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
13 addition
and
29 deletion
+13
-29
libavcodec/vp8.c
libavcodec/vp8.c
+11
-25
libavcodec/vp8data.h
libavcodec/vp8data.h
+2
-4
未找到文件。
libavcodec/vp8.c
浏览文件 @
dd18c9a0
...
...
@@ -162,13 +162,14 @@ typedef struct {
/**
* filter strength adjustment for the following macroblock modes:
* [0] - i4x4
* [1] - zero mv
* [2] - inter modes except for zero or split mv
* [3] - split mv
* [0-3] - i16x16 (always zero)
* [4] - i4x4
* [5] - zero mv
* [6] - inter modes except for zero or split mv
* [7] - split mv
* i16x16 modes never have any adjustment
*/
int8_t
mode
[
4
];
int8_t
mode
[
VP8_MVMODE_SPLIT
+
1
];
/**
* filter strength adjustment for macroblocks that reference:
...
...
@@ -278,7 +279,7 @@ static void update_lf_deltas(VP8Context *s)
for
(
i
=
0
;
i
<
4
;
i
++
)
s
->
lf_delta
.
ref
[
i
]
=
vp8_rac_get_sint
(
c
,
6
);
for
(
i
=
0
;
i
<
4
;
i
++
)
for
(
i
=
MODE_I4x4
;
i
<=
VP8_MVMODE_SPLIT
;
i
++
)
s
->
lf_delta
.
mode
[
i
]
=
vp8_rac_get_sint
(
c
,
6
);
}
...
...
@@ -762,6 +763,7 @@ void decode_mb_mode(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y, uint8_
// motion vectors, 16.3
find_near_mvs
(
s
,
mb
,
near
,
&
best
,
cnt
);
if
(
vp56_rac_get_prob_branchy
(
c
,
vp8_mode_contexts
[
cnt
[
0
]][
0
]))
{
mb
->
mode
=
VP8_MVMODE_MV
;
if
(
vp56_rac_get_prob_branchy
(
c
,
vp8_mode_contexts
[
cnt
[
1
]][
1
]))
{
if
(
vp56_rac_get_prob_branchy
(
c
,
vp8_mode_contexts
[
cnt
[
2
]][
2
]))
{
if
(
vp56_rac_get_prob_branchy
(
c
,
vp8_mode_contexts
[
cnt
[
3
]][
3
]))
{
...
...
@@ -769,19 +771,14 @@ void decode_mb_mode(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y, uint8_
clamp_mv
(
s
,
&
mb
->
mv
,
&
mb
->
mv
,
mb_x
,
mb_y
);
mb
->
mv
=
mb
->
bmv
[
decode_splitmvs
(
s
,
c
,
mb
)
-
1
];
}
else
{
mb
->
mode
=
VP8_MVMODE_NEW
;
clamp_mv
(
s
,
&
mb
->
mv
,
&
mb
->
mv
,
mb_x
,
mb_y
);
mb
->
mv
.
y
+=
read_mv_component
(
c
,
s
->
prob
->
mvc
[
0
]);
mb
->
mv
.
x
+=
read_mv_component
(
c
,
s
->
prob
->
mvc
[
1
]);
}
}
else
{
mb
->
mode
=
VP8_MVMODE_NEAR
;
}
else
clamp_mv
(
s
,
&
mb
->
mv
,
&
near
[
1
],
mb_x
,
mb_y
);
}
}
else
{
mb
->
mode
=
VP8_MVMODE_NEAREST
;
}
else
clamp_mv
(
s
,
&
mb
->
mv
,
&
near
[
0
],
mb_x
,
mb_y
);
}
}
else
{
mb
->
mode
=
VP8_MVMODE_ZERO
;
AV_ZERO32
(
&
mb
->
mv
);
...
...
@@ -1481,18 +1478,7 @@ static av_always_inline void filter_level_for_mb(VP8Context *s, VP8Macroblock *m
if
(
s
->
lf_delta
.
enabled
)
{
filter_level
+=
s
->
lf_delta
.
ref
[
mb
->
ref_frame
];
if
(
mb
->
ref_frame
==
VP56_FRAME_CURRENT
)
{
if
(
mb
->
mode
==
MODE_I4x4
)
filter_level
+=
s
->
lf_delta
.
mode
[
0
];
}
else
{
if
(
mb
->
mode
==
VP8_MVMODE_ZERO
)
filter_level
+=
s
->
lf_delta
.
mode
[
1
];
else
if
(
mb
->
mode
==
VP8_MVMODE_SPLIT
)
filter_level
+=
s
->
lf_delta
.
mode
[
3
];
else
filter_level
+=
s
->
lf_delta
.
mode
[
2
];
}
filter_level
+=
s
->
lf_delta
.
mode
[
mb
->
mode
];
}
filter_level
=
av_clip
(
filter_level
,
0
,
63
);
...
...
libavcodec/vp8data.h
浏览文件 @
dd18c9a0
...
...
@@ -48,10 +48,8 @@ enum dct_token {
#define MODE_I4x4 4
enum
inter_mvmode
{
VP8_MVMODE_NEAREST
=
MODE_I4x4
+
1
,
VP8_MVMODE_NEAR
,
VP8_MVMODE_ZERO
,
VP8_MVMODE_NEW
,
VP8_MVMODE_ZERO
=
MODE_I4x4
+
1
,
VP8_MVMODE_MV
,
VP8_MVMODE_SPLIT
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录