官术网_书友最值得收藏!

Broadcasting NumPy arrays

NumPy attempts to execute a procedure even though the operands do not have the same shape.

In this recipe, we will multiply an array and a scalar. The scalar is broadened to the shape of the array operand and then the multiplication is executed. The process described here is called broadcasting. The following is the entire code for this recipe:

import scipy.io.wavfile as sw 
import matplotlib.pyplot as plt 
import urllib 
import numpy as np 
 
request = urllib.request.Request('http://www.thesoundarchive.com/austinpowers/smashingbaby.wav') 
response = urllib.request.urlopen(request) 
print(response.info()) 
WAV_FILE = 'smashingbaby.wav' 
filehandle = open(WAV_FILE, 'wb') 
filehandle.write(response.read()) 
filehandle.close() 
sample_rate, data = sw.read(WAV_FILE) 
print("Data type", data.dtype, "Shape", data.shape) 
 
plt.subplot(2, 1, 1) 
plt.title("Original") 
plt.plot(data) 
 
newdata = data * 0.2 
newdata = newdata.astype(np.uint8) 
print("Data type", newdata.dtype, "Shape", newdata.shape) 
 
sw.write("quiet.wav", sample_rate, newdata) 
 
plt.subplot(2, 1, 2) 
plt.title("Quiet") 
plt.plot(newdata)2 
 
plt.show() 

We will download a sound file and create a new version that is quieter:

  1. Reading a WAV file.

    We will use standard Python code to download a sound file of Austin Powers exclaiming, "Smashing, baby." SciPy has a wavfile subpackage, which lets you load audio data or generate WAV files. If SciPy is installed, then we should already have this subpackage. The read() function delivers a data array and sample rate. In this exercise, we are only concerned about the data:

              sample_rate, data = scipy.io.wavfile.read(WAV_FILE) 
    
  2. Plot the original WAV data.

    Plot the original WAV data with Matplotlib and give the subplot the title Original:

              plt.subplot(2, 1, 1) 
              plt.title("Original") 
              plt.plot(data) 
    
  3. Create a new array.

    Now, we will use NumPy to produce a hushed sound sample. It is just a matter of making a new array with smaller values by multiplying it with a constant. This is where the trick of broadcasting happens. At the end, we want to be certain that we have the same data type as in the original array because of the WAV format:

              newdata = data * 0.2 
              newdata = newdata.astype(np.uint8) 
    
  4. Write to a WAV file.

    This new array can be saved in a new WAV file as follows:

              scipy.io.wavfile.write("quiet.wav", 
                  sample_rate, newdata) 
    
  5. Plot the new WAV data.

    Plot the new data array with Matplotlib as follows:

              plt.subplot(2, 1, 2) 
              plt.title("Quiet") 
              plt.plot(newdata) 
              plt.show() 
    

    The result is a diagram of the original WAV file data and a new array with smaller values, as depicted in the following figure:

主站蜘蛛池模板: 扎鲁特旗| 双辽市| 密山市| 绥棱县| 昭苏县| 日照市| 舒城县| 三门县| 邯郸县| 宁乡县| 鄂伦春自治旗| 原阳县| 多伦县| 彭山县| 阜新市| 红安县| 昭通市| 绩溪县| 城口县| 灵石县| 名山县| 澄城县| 堆龙德庆县| 阳春市| 哈密市| 东明县| 临洮县| 迁安市| 科尔| 左云县| 吕梁市| 阿拉善盟| 南安市| 九江市| 丰县| 建德市| 平陆县| 昌黎县| 镇巴县| 息烽县| 维西|