Wolfram Language

Audio computacional

Radio AM

Comience una señal de banda limitada.

In[1]:=
Click for copyable input
a = BandpassFilter[ AudioNormalize@ AudioResample[Import["ExampleData/rule30.wav"], 96000], {Quantity[ 10, "Hertz"], Quantity[5000, "Hertz"]}, 201]
Out[1]=
In[2]:=
Click for copyable input
Periodogram[a, 2000, ImageSize -> Small, PlotRange -> {{0, 10000}, All}]
Out[2]=

Module la amplitud con una sinusoide de 22.050 Hz para cambiar el contenido en el extremo superior del espectro. El resultado debería ser inaudible para la mayoría de las personas.

In[3]:=
Click for copyable input
amsignal = ((.5 + a) AudioGenerator[{"Sin", Quantity[22050, "Hertz"]}, Duration@a])/2
Out[3]=
In[4]:=
Click for copyable input
Periodogram[amsignal, 2200, ImageSize -> Small]
Out[4]=

Demodule la señal de AM smultiplicando el resultado por otro sinusoide en 22.050 Hz con la misma fase.

In[5]:=
Click for copyable input
result = BandpassFilter[ amsignal*AudioGenerator[{"Sin", Quantity[22050, "Hertz"]}, Duration@amsignal], {Quantity[100, "Hertz"], Quantity[5000, "Hertz"]}, 201]
Out[5]=

Use un filtro no lineal para demodular una señal de AM.

In[6]:=
Click for copyable input
BandpassFilter[# - Mean@# &@ MaxFilter[amsignal, 4], {Quantity[100, "Hertz"], Quantity[5000, "Hertz"]}, 201]
Out[6]=

Ejemplos relacionados

de en fr ja ko pt-br ru zh