Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
3ef06f34
Commit
3ef06f34
authored
Jan 09, 2013
by
Michael Niedermayer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
swr: split swri_dither_init() out
Signed-off-by:
Michael Niedermayer
<
michaelni@gmx.at
>
parent
dc60ecdb
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
51 additions
and
32 deletions
+51
-32
dither.c
libswresample/dither.c
+47
-31
swresample.c
libswresample/swresample.c
+3
-1
swresample_internal.h
libswresample/swresample_internal.h
+1
-0
No files found.
libswresample/dither.c
View file @
3ef06f34
...
@@ -24,7 +24,7 @@
...
@@ -24,7 +24,7 @@
#include "noise_shaping_data.c"
#include "noise_shaping_data.c"
void
swri_get_dither
(
SwrContext
*
s
,
void
*
dst
,
int
len
,
unsigned
seed
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
)
{
void
swri_get_dither
(
SwrContext
*
s
,
void
*
dst
,
int
len
,
unsigned
seed
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
)
{
double
scale
=
0
;
double
scale
=
s
->
dither
.
ns_scale
;
#define TMP_EXTRA 2
#define TMP_EXTRA 2
double
*
tmp
=
av_malloc
((
len
+
TMP_EXTRA
)
*
sizeof
(
double
));
double
*
tmp
=
av_malloc
((
len
+
TMP_EXTRA
)
*
sizeof
(
double
));
int
i
;
int
i
;
...
@@ -32,36 +32,6 @@ void swri_get_dither(SwrContext *s, void *dst, int len, unsigned seed, enum AVSa
...
@@ -32,36 +32,6 @@ void swri_get_dither(SwrContext *s, void *dst, int len, unsigned seed, enum AVSa
out_fmt
=
av_get_packed_sample_fmt
(
out_fmt
);
out_fmt
=
av_get_packed_sample_fmt
(
out_fmt
);
in_fmt
=
av_get_packed_sample_fmt
(
in_fmt
);
in_fmt
=
av_get_packed_sample_fmt
(
in_fmt
);
if
(
in_fmt
==
AV_SAMPLE_FMT_FLT
||
in_fmt
==
AV_SAMPLE_FMT_DBL
){
if
(
out_fmt
==
AV_SAMPLE_FMT_S32
)
scale
=
1
.
0
/
(
1L
<<
31
);
if
(
out_fmt
==
AV_SAMPLE_FMT_S16
)
scale
=
1
.
0
/
(
1L
<<
15
);
if
(
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1
.
0
/
(
1L
<<
7
);
}
if
(
in_fmt
==
AV_SAMPLE_FMT_S32
&&
out_fmt
==
AV_SAMPLE_FMT_S16
)
scale
=
1L
<<
16
;
if
(
in_fmt
==
AV_SAMPLE_FMT_S32
&&
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1L
<<
24
;
if
(
in_fmt
==
AV_SAMPLE_FMT_S16
&&
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1L
<<
8
;
scale
*=
s
->
dither
.
scale
;
s
->
dither
.
ns_pos
=
0
;
s
->
dither
.
ns_scale
=
scale
;
s
->
dither
.
ns_scale_1
=
1
/
scale
;
memset
(
s
->
dither
.
ns_errors
,
0
,
sizeof
(
s
->
dither
.
ns_errors
));
for
(
i
=
0
;
filters
[
i
].
coefs
;
i
++
)
{
const
filter_t
*
f
=
&
filters
[
i
];
if
(
fabs
(
s
->
out_sample_rate
-
f
->
rate
)
/
f
->
rate
<=
.
05
&&
f
->
name
==
s
->
dither
.
method
)
{
int
j
;
s
->
dither
.
ns_taps
=
f
->
len
;
for
(
j
=
0
;
j
<
f
->
len
;
j
++
)
s
->
dither
.
ns_coeffs
[
j
]
=
f
->
coefs
[
j
];
break
;
}
}
if
(
!
filters
[
i
].
coefs
&&
s
->
dither
.
method
>
SWR_DITHER_NS
)
{
av_log
(
s
,
AV_LOG_WARNING
,
"Requested noise shaping dither not available at this sampling rate, using triangular hp dither
\n
"
);
s
->
dither
.
method
=
SWR_DITHER_TRIANGULAR_HIGHPASS
;
}
for
(
i
=
0
;
i
<
len
+
TMP_EXTRA
;
i
++
){
for
(
i
=
0
;
i
<
len
+
TMP_EXTRA
;
i
++
){
double
v
;
double
v
;
seed
=
seed
*
1664525
+
1013904223
;
seed
=
seed
*
1664525
+
1013904223
;
...
@@ -105,6 +75,52 @@ void swri_get_dither(SwrContext *s, void *dst, int len, unsigned seed, enum AVSa
...
@@ -105,6 +75,52 @@ void swri_get_dither(SwrContext *s, void *dst, int len, unsigned seed, enum AVSa
av_free
(
tmp
);
av_free
(
tmp
);
}
}
int
swri_dither_init
(
SwrContext
*
s
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
)
{
int
i
;
double
scale
=
0
;
if
(
s
->
dither
.
method
>
SWR_DITHER_TRIANGULAR_HIGHPASS
&&
s
->
dither
.
method
<=
SWR_DITHER_NS
)
return
AVERROR
(
EINVAL
);
out_fmt
=
av_get_packed_sample_fmt
(
out_fmt
);
in_fmt
=
av_get_packed_sample_fmt
(
in_fmt
);
if
(
in_fmt
==
AV_SAMPLE_FMT_FLT
||
in_fmt
==
AV_SAMPLE_FMT_DBL
){
if
(
out_fmt
==
AV_SAMPLE_FMT_S32
)
scale
=
1
.
0
/
(
1L
<<
31
);
if
(
out_fmt
==
AV_SAMPLE_FMT_S16
)
scale
=
1
.
0
/
(
1L
<<
15
);
if
(
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1
.
0
/
(
1L
<<
7
);
}
if
(
in_fmt
==
AV_SAMPLE_FMT_S32
&&
out_fmt
==
AV_SAMPLE_FMT_S16
)
scale
=
1L
<<
16
;
if
(
in_fmt
==
AV_SAMPLE_FMT_S32
&&
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1L
<<
24
;
if
(
in_fmt
==
AV_SAMPLE_FMT_S16
&&
out_fmt
==
AV_SAMPLE_FMT_U8
)
scale
=
1L
<<
8
;
scale
*=
s
->
dither
.
scale
;
s
->
dither
.
ns_pos
=
0
;
s
->
dither
.
ns_scale
=
scale
;
s
->
dither
.
ns_scale_1
=
1
/
scale
;
memset
(
s
->
dither
.
ns_errors
,
0
,
sizeof
(
s
->
dither
.
ns_errors
));
for
(
i
=
0
;
filters
[
i
].
coefs
;
i
++
)
{
const
filter_t
*
f
=
&
filters
[
i
];
if
(
fabs
(
s
->
out_sample_rate
-
f
->
rate
)
/
f
->
rate
<=
.
05
&&
f
->
name
==
s
->
dither
.
method
)
{
int
j
;
s
->
dither
.
ns_taps
=
f
->
len
;
for
(
j
=
0
;
j
<
f
->
len
;
j
++
)
s
->
dither
.
ns_coeffs
[
j
]
=
f
->
coefs
[
j
];
break
;
}
}
if
(
!
filters
[
i
].
coefs
&&
s
->
dither
.
method
>
SWR_DITHER_NS
)
{
av_log
(
s
,
AV_LOG_WARNING
,
"Requested noise shaping dither not available at this sampling rate, using triangular hp dither
\n
"
);
s
->
dither
.
method
=
SWR_DITHER_TRIANGULAR_HIGHPASS
;
}
s
->
dither
.
noise
=
s
->
preout
;
return
0
;
}
#define TEMPLATE_DITHER_S16
#define TEMPLATE_DITHER_S16
#include "dither_template.c"
#include "dither_template.c"
#undef TEMPLATE_DITHER_S16
#undef TEMPLATE_DITHER_S16
...
...
libswresample/swresample.c
View file @
3ef06f34
...
@@ -230,6 +230,7 @@ av_cold void swr_free(SwrContext **ss){
...
@@ -230,6 +230,7 @@ av_cold void swr_free(SwrContext **ss){
}
}
av_cold
int
swr_init
(
struct
SwrContext
*
s
){
av_cold
int
swr_init
(
struct
SwrContext
*
s
){
int
ret
;
s
->
in_buffer_index
=
0
;
s
->
in_buffer_index
=
0
;
s
->
in_buffer_count
=
0
;
s
->
in_buffer_count
=
0
;
s
->
resample_in_constraint
=
0
;
s
->
resample_in_constraint
=
0
;
...
@@ -391,7 +392,8 @@ av_assert0(s->out.ch_count);
...
@@ -391,7 +392,8 @@ av_assert0(s->out.ch_count);
set_audiodata_fmt
(
&
s
->
in_buffer
,
s
->
int_sample_fmt
);
set_audiodata_fmt
(
&
s
->
in_buffer
,
s
->
int_sample_fmt
);
}
}
s
->
dither
.
noise
=
s
->
preout
;
if
((
ret
=
swri_dither_init
(
s
,
s
->
out_sample_fmt
,
s
->
int_sample_fmt
))
<
0
)
return
ret
;
if
(
s
->
rematrix
||
s
->
dither
.
method
)
if
(
s
->
rematrix
||
s
->
dither
.
method
)
return
swri_rematrix_init
(
s
);
return
swri_rematrix_init
(
s
);
...
...
libswresample/swresample_internal.h
View file @
3ef06f34
...
@@ -177,6 +177,7 @@ int swri_rematrix(SwrContext *s, AudioData *out, AudioData *in, int len, int mus
...
@@ -177,6 +177,7 @@ int swri_rematrix(SwrContext *s, AudioData *out, AudioData *in, int len, int mus
void
swri_rematrix_init_x86
(
struct
SwrContext
*
s
);
void
swri_rematrix_init_x86
(
struct
SwrContext
*
s
);
void
swri_get_dither
(
SwrContext
*
s
,
void
*
dst
,
int
len
,
unsigned
seed
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
);
void
swri_get_dither
(
SwrContext
*
s
,
void
*
dst
,
int
len
,
unsigned
seed
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
);
int
swri_dither_init
(
SwrContext
*
s
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
in_fmt
);
void
swri_audio_convert_init_arm
(
struct
AudioConvert
*
ac
,
void
swri_audio_convert_init_arm
(
struct
AudioConvert
*
ac
,
enum
AVSampleFormat
out_fmt
,
enum
AVSampleFormat
out_fmt
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment