Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
b9d2085b
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,发现更多精彩内容 >>
提交
b9d2085b
编写于
6月 30, 2004
作者:
M
Michael Niedermayer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
various resampling fixes
Originally committed as revision 3271 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
2d48eddd
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
8 addition
and
6 deletion
+8
-6
libavcodec/resample.c
libavcodec/resample.c
+1
-1
libavcodec/resample2.c
libavcodec/resample2.c
+7
-5
未找到文件。
libavcodec/resample.c
浏览文件 @
b9d2085b
...
...
@@ -175,7 +175,7 @@ int audio_resample(ReSampleContext *s, short *output, short *input, int nb_sampl
short
*
buftmp2
[
2
],
*
buftmp3
[
2
];
int
lenout
;
if
(
s
->
input_channels
==
s
->
output_channels
&&
s
->
ratio
==
1
.
0
)
{
if
(
s
->
input_channels
==
s
->
output_channels
&&
s
->
ratio
==
1
.
0
&&
0
)
{
/* nothing to do */
memcpy
(
output
,
input
,
nb_samples
*
s
->
input_channels
*
sizeof
(
short
));
return
nb_samples
;
...
...
libavcodec/resample2.c
浏览文件 @
b9d2085b
...
...
@@ -123,8 +123,8 @@ AVResampleContext *av_resample_init(int out_rate, int in_rate){
c
->
filter_length
=
ceil
(
16
.
0
/
factor
);
c
->
filter_bank
=
av_mallocz
(
c
->
filter_length
*
(
PHASE_COUNT
+
1
)
*
sizeof
(
short
));
av_build_filter
(
c
->
filter_bank
,
factor
,
c
->
filter_length
,
PHASE_COUNT
,
1
<<
FILTER_SHIFT
,
1
);
c
->
filter_bank
[
c
->
filter_length
*
PHASE_COUNT
+
(
c
->
filter_length
-
1
)
+
1
]
=
(
1
<<
FILTER_SHIFT
)
-
1
;
c
->
filter_bank
[
c
->
filter_length
*
PHASE_COUNT
+
(
c
->
filter_length
-
1
)
+
2
]
=
1
;
c
->
filter_bank
[
c
->
filter_length
*
PHASE_COUNT
+
(
c
->
filter_length
-
1
)
/
2
+
1
]
=
(
1
<<
FILTER_SHIFT
)
-
1
;
c
->
filter_bank
[
c
->
filter_length
*
PHASE_COUNT
+
(
c
->
filter_length
-
1
)
/
2
+
2
]
=
1
;
c
->
src_incr
=
out_rate
;
c
->
ideal_dst_incr
=
c
->
dst_incr
=
in_rate
*
PHASE_COUNT
;
...
...
@@ -170,7 +170,7 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int
if
(
sample_index
<
0
){
for
(
i
=
0
;
i
<
c
->
filter_length
;
i
++
)
val
+=
src
[
ABS
(
sample_index
+
i
)]
*
filter
[
i
];
val
+=
src
[
ABS
(
sample_index
+
i
)
%
src_size
]
*
filter
[
i
];
}
else
if
(
sample_index
+
c
->
filter_length
>
src_size
){
break
;
}
else
{
...
...
@@ -199,6 +199,9 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int
index
++
;
}
}
*
consumed
=
FFMAX
(
index
,
0
)
>>
PHASE_SHIFT
;
index
=
FFMIN
(
index
,
0
);
if
(
update_ctx
){
if
(
c
->
compensation_distance
){
c
->
compensation_distance
-=
dst_index
;
...
...
@@ -206,9 +209,8 @@ int av_resample(AVResampleContext *c, short *dst, short *src, int *consumed, int
c
->
dst_incr
=
c
->
ideal_dst_incr
;
}
c
->
frac
=
frac
;
c
->
index
=
0
;
c
->
index
=
index
;
}
*
consumed
=
index
>>
PHASE_SHIFT
;
#if 0
if(update_ctx && !c->compensation_distance){
#undef rand
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录