Detección de señales sordas y sonoras
Detecte los segmentos sordos y atenuelos.
In[1]:=
a = ExampleData[{"Audio", "NoisyTalk"}, "Audio"]
Use AudioIntervals para buscar segmentos con amplitud RMS baja y alta planitud espectral.
In[2]:=
nonVoicedIntervals =
AudioIntervals[
a, #RMSAmplitude < .02 && #SpectralFlatness > .0001 &, .1,
PartitionGranularity -> {.06, .01}]
Out[2]=
Visualice los intervalos detectados.
In[3]:=
AudioPlot[a,
Epilog -> {RGBColor[1, 0, 0, .3],
Rectangle[{#[[1]], -1}, {#[[2]], 1}] & /@ nonVoicedIntervals},
ImageSize -> Medium]
Out[3]=
Atenúe los intervalos detectados.
In[4]:=
AudioJoin[
Riffle[AudioFade /@ AudioTrim[a, Except@nonVoicedIntervals],
0.3*AudioTrim[a, nonVoicedIntervals]]]