Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in
Toggle navigation
ITACTC
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Iterations
Merge Requests
0
Merge Requests
0
Requirements
Requirements
List
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Operations
Operations
Incidents
Analytics
Analytics
Code Review
Insights
Issue
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Institute of Technical Acoustics (ITA)
ITACTC
Commits
bb09c185
Commit
bb09c185
authored
Sep 29, 2016
by
Dipl.-Ing. Jonas Stienen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Removing cepstrum
parent
010c9f2d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
12 deletions
+8
-12
src/ITANCTC.cpp
src/ITANCTC.cpp
+8
-12
No files found.
src/ITANCTC.cpp
View file @
bb09c185
...
@@ -262,36 +262,32 @@ bool ITANCTC::CalculateFilter( std::vector< ITAHDFTSpectra* >& vpCTCFilter )
...
@@ -262,36 +262,32 @@ bool ITANCTC::CalculateFilter( std::vector< ITAHDFTSpectra* >& vpCTCFilter )
// First, store original energy of HRTF (left channel)
// First, store original energy of HRTF (left channel)
float
fEnergy
=
(
*
pHRTF
)[
0
]
->
getEnergy
();
float
fEnergy
=
(
*
pHRTF
)[
0
]
->
getEnergy
();
// Apply WICK factor in cepstrum domain only on magnitudes (left channel)
// Apply WICK factor only on magnitudes (left channel)
(
*
pHRTF
)[
0
]
->
log
();
for
(
int
i
=
0
;
i
<
(
*
pHRTF
)[
0
]
->
getSize
();
i
++
)
for
(
int
i
=
0
;
i
<
(
*
pHRTF
)[
0
]
->
getSize
();
i
++
)
{
{
float
f
Cepstrum
Mag
=
(
*
pHRTF
)[
0
]
->
calcMagnitude
(
i
);
float
fMag
=
(
*
pHRTF
)[
0
]
->
calcMagnitude
(
i
);
(
*
pHRTF
)[
0
]
->
setMagnitudePreservePhase
(
i
,
fCepstrumMag
*
m_fWaveIncidenceAngleCompensationFactor
);
(
*
pHRTF
)[
0
]
->
setMagnitudePreservePhase
(
i
,
std
::
powf
(
fMag
,
m_fWaveIncidenceAngleCompensationFactor
)
);
}
}
(
*
pHRTF
)[
0
]
->
exp
();
// Compensate initial HRTF energy when WICK is used (left channel)
// Compensate initial HRTF energy when WICK is used (left channel)
assert
(
fEnergy
>
0
);
assert
(
fEnergy
>
0
);
float
fEnergyCompensation
=
powf
(
fEnergy
,
(
1
-
m_fWaveIncidenceAngleCompensationFactor
)
);
float
fEnergyCompensation
=
std
::
powf
(
fEnergy
,
(
1
-
m_fWaveIncidenceAngleCompensationFactor
)
);
(
*
pHRTF
)[
0
]
->
mul
(
fEnergyCompensation
);
(
*
pHRTF
)[
0
]
->
mul
(
fEnergyCompensation
);
// First, store original energy of HRTF only on magnitudes (right channel)
// First, store original energy of HRTF only on magnitudes (right channel)
fEnergy
=
(
*
pHRTF
)[
1
]
->
getEnergy
();
fEnergy
=
(
*
pHRTF
)[
1
]
->
getEnergy
();
// Apply WICK factor in cepstrum domain (right channel)
// Apply WICK factor only on magnitude (right channel)
(
*
pHRTF
)[
1
]
->
log
();
for
(
int
i
=
0
;
i
<
(
*
pHRTF
)[
1
]
->
getSize
();
i
++
)
for
(
int
i
=
0
;
i
<
(
*
pHRTF
)[
1
]
->
getSize
();
i
++
)
{
{
float
f
Cepstrum
Mag
=
(
*
pHRTF
)[
1
]
->
calcMagnitude
(
i
);
float
fMag
=
(
*
pHRTF
)[
1
]
->
calcMagnitude
(
i
);
(
*
pHRTF
)[
1
]
->
setMagnitudePreservePhase
(
i
,
fCepstrumMag
*
m_fWaveIncidenceAngleCompensationFactor
);
(
*
pHRTF
)[
1
]
->
setMagnitudePreservePhase
(
i
,
std
::
powf
(
fMag
,
m_fWaveIncidenceAngleCompensationFactor
)
);
}
}
(
*
pHRTF
)[
1
]
->
exp
();
// Compensate initial HRTF energy when WICK is used (right channel)
// Compensate initial HRTF energy when WICK is used (right channel)
assert
(
fEnergy
>
0
);
assert
(
fEnergy
>
0
);
fEnergyCompensation
=
powf
(
fEnergy
,
(
1
-
m_fWaveIncidenceAngleCompensationFactor
)
);
fEnergyCompensation
=
std
::
powf
(
fEnergy
,
(
1
-
m_fWaveIncidenceAngleCompensationFactor
)
);
(
*
pHRTF
)[
1
]
->
mul
(
fEnergyCompensation
);
(
*
pHRTF
)[
1
]
->
mul
(
fEnergyCompensation
);
...
...
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