Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
ESP32-audioI2S
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
xpstem
ESP32-audioI2S
Commits
bb360ea0
Unverified
Commit
bb360ea0
authored
Feb 05, 2023
by
Wolle
Committed by
GitHub
Feb 05, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add files via upload
parent
3874b510
Changes
3
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
137 additions
and
235 deletions
+137
-235
src/opus_decoder/celt.cpp
src/opus_decoder/celt.cpp
+119
-213
src/opus_decoder/celt.h
src/opus_decoder/celt.h
+18
-21
src/opus_decoder/opus_decoder.cpp
src/opus_decoder/opus_decoder.cpp
+0
-1
No files found.
src/opus_decoder/celt.cpp
View file @
bb360ea0
This diff is collapsed.
Click to expand it.
src/opus_decoder/celt.h
View file @
bb360ea0
...
@@ -97,7 +97,6 @@ typedef struct _band_ctx{
...
@@ -97,7 +97,6 @@ typedef struct _band_ctx{
int32_t
spread
;
int32_t
spread
;
int32_t
tf_change
;
int32_t
tf_change
;
int32_t
remaining_bits
;
int32_t
remaining_bits
;
const
int32_t
*
bandE
;
uint32_t
seed
;
uint32_t
seed
;
int32_t
theta_round
;
int32_t
theta_round
;
int32_t
disable_inv
;
int32_t
disable_inv
;
...
@@ -213,8 +212,6 @@ inline int32_t S_MUL(int32_t a, int16_t b){return (int64_t)b * a >> 15;}
...
@@ -213,8 +212,6 @@ inline int32_t S_MUL(int32_t a, int16_t b){return (int64_t)b * a >> 15;}
#define COMBFILTER_MAXPERIOD 1024
#define COMBFILTER_MAXPERIOD 1024
#define COMBFILTER_MINPERIOD 15
#define COMBFILTER_MINPERIOD 15
#define VALIDATE_CELT_DECODER(st)
#define EPSILON 1
#define EPSILON 1
#define VERY_SMALL 0
#define VERY_SMALL 0
#define VERY_LARGE16 ((int16_t)32767)
#define VERY_LARGE16 ((int16_t)32767)
...
@@ -522,10 +519,10 @@ void init_caps(int32_t *cap, int32_t LM, int32_t C);
...
@@ -522,10 +519,10 @@ void init_caps(int32_t *cap, int32_t LM, int32_t C);
uint32_t
celt_lcg_rand
(
uint32_t
seed
);
uint32_t
celt_lcg_rand
(
uint32_t
seed
);
int16_t
bitexact_cos
(
int16_t
x
);
int16_t
bitexact_cos
(
int16_t
x
);
int32_t
bitexact_log2tan
(
int32_t
isin
,
int32_t
icos
);
int32_t
bitexact_log2tan
(
int32_t
isin
,
int32_t
icos
);
void
denormalise_bands
(
const
int16_t
*
X
,
int32_t
*
freq
,
const
int16_t
*
bandLogE
,
int32_t
start
,
int32_t
end
,
int32_t
M
,
void
denormalise_bands
(
const
int16_t
*
X
,
int32_t
*
freq
,
const
int16_t
*
bandLogE
,
int32_t
end
,
int32_t
M
,
int32_t
silence
);
int32_t
silence
);
void
anti_collapse
(
int16_t
*
X_
,
uint8_t
*
collapse_masks
,
int32_t
LM
,
int32_t
C
,
int32_t
size
,
int32_t
start
,
void
anti_collapse
(
int16_t
*
X_
,
uint8_t
*
collapse_masks
,
int32_t
LM
,
int32_t
C
,
int32_t
size
,
int32_t
end
,
int32_t
end
,
const
int16_t
*
logE
,
const
int16_t
*
prev1logE
,
const
int16_t
*
prev2logE
,
const
int16_t
*
logE
,
const
int16_t
*
prev1logE
,
const
int16_t
*
prev2logE
,
const
int32_t
*
pulses
,
uint32_t
seed
);
const
int32_t
*
pulses
,
uint32_t
seed
);
void
compute_channel_weights
(
int32_t
Ex
,
int32_t
Ey
,
int16_t
w
[
2
]);
void
compute_channel_weights
(
int32_t
Ex
,
int32_t
Ey
,
int16_t
w
[
2
]);
void
stereo_split
(
int16_t
*
X
,
int16_t
*
Y
,
int32_t
N
);
void
stereo_split
(
int16_t
*
X
,
int16_t
*
Y
,
int32_t
N
);
...
@@ -543,18 +540,18 @@ uint32_t quant_band(int16_t *X, int32_t N, int32_t b, int32_t B, int16_t *lowban
...
@@ -543,18 +540,18 @@ uint32_t quant_band(int16_t *X, int32_t N, int32_t b, int32_t B, int16_t *lowban
int16_t
gain
,
int16_t
*
lowband_scratch
,
int32_t
fill
);
int16_t
gain
,
int16_t
*
lowband_scratch
,
int32_t
fill
);
uint32_t
quant_band_stereo
(
int16_t
*
X
,
int16_t
*
Y
,
int32_t
N
,
int32_t
b
,
int32_t
B
,
int16_t
*
lowband
,
int32_t
LM
,
uint32_t
quant_band_stereo
(
int16_t
*
X
,
int16_t
*
Y
,
int32_t
N
,
int32_t
b
,
int32_t
B
,
int16_t
*
lowband
,
int32_t
LM
,
int16_t
*
lowband_out
,
int16_t
*
lowband_scratch
,
int32_t
fill
);
int16_t
*
lowband_out
,
int16_t
*
lowband_scratch
,
int32_t
fill
);
void
special_hybrid_folding
(
int16_t
*
norm
,
int16_t
*
norm2
,
int32_t
start
,
int32_t
M
,
int32_t
dual_stereo
);
void
special_hybrid_folding
(
int16_t
*
norm
,
int16_t
*
norm2
,
int32_t
M
,
int32_t
dual_stereo
);
void
quant_all_bands
(
int32_t
start
,
int32_t
end
,
int16_t
*
X_
,
int16_t
*
Y_
,
uint8_t
*
collapse_masks
,
void
quant_all_bands
(
int32_t
end
,
int16_t
*
X_
,
int16_t
*
Y_
,
uint8_t
*
collapse_masks
,
const
int32_t
*
bandE
,
int32_t
*
pulses
,
int32_t
shortBlocks
,
int32_t
spread
,
int32_t
dual_stereo
,
int32_t
*
pulses
,
int32_t
shortBlocks
,
int32_t
spread
,
int32_t
dual_stereo
,
int32_t
intensity
,
int32_t
*
tf_res
,
int32_t
total_bits
,
int32_t
balance
,
int32_t
LM
,
int32_t
intensity
,
int32_t
*
tf_res
,
int32_t
total_bits
,
int32_t
balance
,
int32_t
LM
,
int32_t
codedBands
,
uint32_t
*
seed
,
int32_t
complexity
,
int32_t
disable_inv
);
int32_t
codedBands
,
int32_t
disable_inv
);
int32_t
celt_decoder_get_size
(
int32_t
channels
);
int32_t
celt_decoder_get_size
(
int32_t
channels
);
int32_t
celt_decoder_init
(
int32_t
channels
);
int32_t
celt_decoder_init
(
int32_t
channels
);
void
deemphasis_stereo_simple
(
int32_t
*
in
[],
int16_t
*
pcm
,
int32_t
N
,
const
int16_t
coef0
,
int32_t
*
mem
);
void
deemphasis_stereo_simple
(
int32_t
*
in
[],
int16_t
*
pcm
,
int32_t
N
,
const
int16_t
coef0
,
int32_t
*
mem
);
void
deemphasis
(
int32_t
*
in
[],
int16_t
*
pcm
,
int32_t
N
,
int32_t
C
,
const
int16_t
*
coef
,
int32_t
*
mem
);
void
deemphasis
(
int32_t
*
in
[],
int16_t
*
pcm
,
int32_t
N
,
const
int16_t
*
coef
,
int32_t
*
mem
);
void
celt_synthesis
(
int16_t
*
X
,
int32_t
*
out_syn
[],
int16_t
*
oldBandE
,
int32_t
start
,
int32_t
effEnd
,
int32_t
C
,
void
celt_synthesis
(
int16_t
*
X
,
int32_t
*
out_syn
[],
int16_t
*
oldBandE
,
int32_t
effEnd
,
int32_t
C
,
int32_t
CC
,
int32_t
isTransient
,
int32_t
LM
,
int32_t
silence
);
int32_t
isTransient
,
int32_t
LM
,
int32_t
silence
);
void
tf_decode
(
int32_t
start
,
int32_t
end
,
int32_t
isTransient
,
int32_t
*
tf_res
,
int32_t
LM
);
void
tf_decode
(
int32_t
end
,
int32_t
isTransient
,
int32_t
*
tf_res
,
int32_t
LM
);
int32_t
celt_decode_with_ec
(
const
uint8_t
*
inbuf
,
int32_t
len
,
int16_t
*
outbuf
,
int32_t
frame_size
);
int32_t
celt_decode_with_ec
(
const
uint8_t
*
inbuf
,
int32_t
len
,
int16_t
*
outbuf
,
int32_t
frame_size
);
int32_t
celt_decoder_ctl
(
int32_t
request
,
...);
int32_t
celt_decoder_ctl
(
int32_t
request
,
...);
int32_t
cwrsi
(
int32_t
_n
,
int32_t
_k
,
uint32_t
_i
,
int32_t
*
_y
);
int32_t
cwrsi
(
int32_t
_n
,
int32_t
_k
,
uint32_t
_i
,
int32_t
*
_y
);
...
@@ -590,18 +587,18 @@ void normalise_residual(int32_t *iy, int16_t *X, int32_t N, int32_t Ryy, int
...
@@ -590,18 +587,18 @@ void normalise_residual(int32_t *iy, int16_t *X, int32_t N, int32_t Ryy, int
uint32_t
extract_collapse_mask
(
int32_t
*
iy
,
int32_t
N
,
int32_t
B
);
uint32_t
extract_collapse_mask
(
int32_t
*
iy
,
int32_t
N
,
int32_t
B
);
uint32_t
alg_unquant
(
int16_t
*
X
,
int32_t
N
,
int32_t
K
,
int32_t
spread
,
int32_t
B
,
int16_t
gain
);
uint32_t
alg_unquant
(
int16_t
*
X
,
int32_t
N
,
int32_t
K
,
int32_t
spread
,
int32_t
B
,
int16_t
gain
);
void
renormalise_vector
(
int16_t
*
X
,
int32_t
N
,
int16_t
gain
);
void
renormalise_vector
(
int16_t
*
X
,
int32_t
N
,
int16_t
gain
);
int32_t
interp_bits2pulses
(
int32_t
start
,
int32_t
end
,
int32_t
skip_start
,
const
int32_t
*
bits1
,
const
int32_t
*
bits2
,
int32_t
interp_bits2pulses
(
int32_t
end
,
int32_t
skip_start
,
const
int32_t
*
bits1
,
const
int32_t
*
bits2
,
const
int32_t
*
thresh
,
const
int32_t
*
cap
,
int32_t
total
,
int32_t
*
_balance
,
const
int32_t
*
thresh
,
const
int32_t
*
cap
,
int32_t
total
,
int32_t
*
_balance
,
int32_t
skip_rsv
,
int32_t
*
intensity
,
int32_t
intensity_rsv
,
int32_t
*
dual_stereo
,
int32_t
skip_rsv
,
int32_t
*
intensity
,
int32_t
intensity_rsv
,
int32_t
*
dual_stereo
,
int32_t
dual_stereo_rsv
,
int32_t
*
bits
,
int32_t
*
ebits
,
int32_t
*
fine_priority
,
int32_t
C
,
int32_t
dual_stereo_rsv
,
int32_t
*
bits
,
int32_t
*
ebits
,
int32_t
*
fine_priority
,
int32_t
C
,
int32_t
LM
,
int32_t
prev
,
int32_t
signalBandwidth
);
int32_t
LM
);
int32_t
clt_compute_allocation
(
int32_t
start
,
int32_t
end
,
const
int32_t
*
offsets
,
const
int32_t
*
cap
,
int32_t
clt_compute_allocation
(
int32_t
end
,
const
int32_t
*
offsets
,
const
int32_t
*
cap
,
int32_t
alloc_trim
,
int32_t
*
intensity
,
int32_t
*
dual_stereo
,
int32_t
total
,
int32_t
alloc_trim
,
int32_t
*
intensity
,
int32_t
*
dual_stereo
,
int32_t
total
,
int32_t
*
balance
,
int32_t
*
pulses
,
int32_t
*
ebits
,
int32_t
*
fine_priority
,
int32_t
C
,
int32_t
*
balance
,
int32_t
*
pulses
,
int32_t
*
ebits
,
int32_t
*
fine_priority
,
int32_t
C
,
int32_t
LM
,
int32_t
prev
,
int32_t
signalBandwidth
);
int32_t
LM
);
void
unquant_coarse_energy
(
int32_t
start
,
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
intra
,
int32_t
C
,
int32_t
LM
);
void
unquant_coarse_energy
(
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
intra
,
int32_t
C
,
int32_t
LM
);
void
unquant_fine_energy
(
int32_t
start
,
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
*
fine_quant
,
int32_t
C
);
void
unquant_fine_energy
(
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
*
fine_quant
,
int32_t
C
);
void
unquant_energy_finalise
(
int32_t
start
,
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
*
fine_quant
,
void
unquant_energy_finalise
(
int32_t
end
,
int16_t
*
oldEBands
,
int32_t
*
fine_quant
,
int32_t
*
fine_priority
,
int32_t
bits_left
,
int32_t
C
);
int32_t
*
fine_priority
,
int32_t
bits_left
,
int32_t
C
);
uint32_t
celt_pvq_u_row
(
uint32_t
row
,
uint32_t
data
);
uint32_t
celt_pvq_u_row
(
uint32_t
row
,
uint32_t
data
);
...
...
src/opus_decoder/opus_decoder.cpp
View file @
bb360ea0
...
@@ -51,7 +51,6 @@ void OPUSDecoder_ClearBuffers(){
...
@@ -51,7 +51,6 @@ void OPUSDecoder_ClearBuffers(){
int
OPUSDecode
(
uint8_t
*
inbuf
,
int
*
bytesLeft
,
short
*
outbuf
){
int
OPUSDecode
(
uint8_t
*
inbuf
,
int
*
bytesLeft
,
short
*
outbuf
){
if
(
f_m_parseOgg
){
if
(
f_m_parseOgg
){
log_i
(
"highWatermark %i"
,
uxTaskGetStackHighWaterMark
(
NULL
));
int
ret
=
OPUSparseOGG
(
inbuf
,
bytesLeft
);
int
ret
=
OPUSparseOGG
(
inbuf
,
bytesLeft
);
if
(
ret
==
ERR_OPUS_NONE
)
return
OPUS_PARSE_OGG_DONE
;
// ok
if
(
ret
==
ERR_OPUS_NONE
)
return
OPUS_PARSE_OGG_DONE
;
// ok
else
return
ret
;
// error
else
return
ret
;
// error
...
...
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