Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
16bbb8df
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,发现更多精彩内容 >>
提交
16bbb8df
编写于
6月 26, 2009
作者:
V
Vladimir Voroshilov
提交者:
Michael Niedermayer
9月 24, 2011
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Replace pitch_delay_int with array
上级
bfbfe56f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
6 addition
and
6 deletion
+6
-6
libavcodec/g729dec.c
libavcodec/g729dec.c
+6
-6
未找到文件。
libavcodec/g729dec.c
浏览文件 @
16bbb8df
...
...
@@ -380,7 +380,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
uint8_t
quantizer_2nd_lo
;
///< second stage lower vector of quantizer (size in bits)
uint8_t
quantizer_2nd_hi
;
///< second stage higher vector of quantizer (size in bits)
int
pitch_delay_int
;
// pitch delay, integer part
int
pitch_delay_int
[
2
];
// pitch delay, integer part
int
pitch_delay_3x
;
// pitch delay, multiplied by 3
int16_t
fc
[
SUBFRAME_SIZE
];
// fixed-codebook vector
int16_t
synth
[
SUBFRAME_SIZE
+
10
];
// fixed-codebook vector
...
...
@@ -475,7 +475,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
}
/* Round pitch delay to nearest (used everywhere except ff_acelp_interpolate). */
pitch_delay_int
=
(
pitch_delay_3x
+
1
)
/
3
;
pitch_delay_int
[
i
]
=
(
pitch_delay_3x
+
1
)
/
3
;
if
(
frame_erasure
)
{
ctx
->
rand_value
=
g729_prng
(
ctx
->
rand_value
);
...
...
@@ -508,12 +508,12 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
fc_v[i] = <
\ fc_v[i] + gain_pitch * fc_v[i-pitch_delay], i >= pitch_delay
*/
ff_acelp_weighted_vector_sum
(
fc
+
pitch_delay_int
,
fc
+
pitch_delay_int
,
ff_acelp_weighted_vector_sum
(
fc
+
pitch_delay_int
[
i
]
,
fc
+
pitch_delay_int
[
i
]
,
fc
,
1
<<
14
,
av_clip
(
ctx
->
past_gain_pitch
[
0
],
SHARP_MIN
,
SHARP_MAX
),
0
,
14
,
SUBFRAME_SIZE
-
pitch_delay_int
);
SUBFRAME_SIZE
-
pitch_delay_int
[
i
]
);
memmove
(
ctx
->
past_gain_pitch
+
1
,
ctx
->
past_gain_pitch
,
5
*
sizeof
(
int16_t
));
ctx
->
past_gain_code
[
1
]
=
ctx
->
past_gain_code
[
0
];
...
...
@@ -628,7 +628,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
if
(
frame_erasure
)
ctx
->
pitch_delay_int_prev
=
FFMIN
(
ctx
->
pitch_delay_int_prev
+
1
,
PITCH_DELAY_MAX
);
else
ctx
->
pitch_delay_int_prev
=
pitch_delay_int
;
ctx
->
pitch_delay_int_prev
=
pitch_delay_int
[
i
]
;
memcpy
(
synth
+
8
,
ctx
->
hpf_z
,
2
*
sizeof
(
int16_t
));
ff_acelp_high_pass_filter
(
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录