科学计算和可视化
Numpy
numpy支持大量的维度数组和矩阵运算,对数组运算提供了大量的数学函数库!
numpy比Python列表更具优势,其中一个优势便是速度。在对大型数组执行操作时,numpy的速度比Python列表的速度快了好几百。因为numpy数组本身能节省内存,并且numpy在执行算术、统计和线性代数运算时采用了优化算法。
numpy的另一个强大功能是具有可以表示向量和矩阵的多维数组数据结构。numpy对矩阵运算进行了优化,使我们能够高效地执行线性代数运算,使其非常适合解决机器学习问题。
与Python列表相比,numpy具有的另一个强大优势是具有大量优化的内置数学函数。这些函数使你能够非常快速地进行各种复杂的数学计算,并且用到很少代码(无需使用复杂的循环),使程序更容易读懂和理解。
1、简单创建数组
a = [1, 2, 3] b = np.array(a) c = np.array([[0, 1, 2, 10], [12, 13, 100, 101], [102, 110, 112, 113]], int) print(c) print(b)
2、创建随机数组
array_rand = np.random.rand(10, 10, 4) print(array_rand) print(array_rand.ndim)
3、数组的复制
after_array = array_normal[:3, 2:4].copy()
copy_array = np.copy(array_normal[:, 2:4])
4、数组运算
# 循环数组行和列,每一个数值都加5 score[:, :] = score[:, :]+5 print(score) # 循环数组行和列,每一个数值都减5 score[:, :] = score[:, :]-5 print(score) # 循环数组行和列,每一个数值都乘以5 score[:, :] = score[:, :]*5 print(score) # 循环数组行和列,每一个数值都除以5 score[:, :] = score[:, :]/5 print(score) # 循环数组行和列,每一个数值除以5取整 score[:, :] = score[:, :] // 5 print(score) # 循环数组行和列,每一个数值除以5取模 score[:, :] = score[:, :] % 5 print(score)
二、Matplotlib
Matplotlib 是Python中类似 MATLAB 的绘图工具,熟悉 MATLAB 也可以很快的上手 Matplotlib。
1、matplotlib图标正常显示中文
import matplotlib.pyplot as plt plt.rcParams['font.sas-serig']=['SimHei'] #用来正常显示中文标签 plt.rcParams['axes.unicode_minus']=False #用来正常显示负号
2、为项目设置matplotlib参数
配置文件包括以下配置项
axex: 设置坐标轴边界和表面的颜色、坐标刻度值大小和网格的显示
backend: 设置目标暑促TkAgg和GTKAgg
figure: 控制dpi、边界颜色、图形大小、和子区( subplot)设置
font: 字体集(font family)、字体大小和样式设置
grid: 设置网格颜色和线性
legend: 设置图例和其中的文本的显示
line: 设置线条(颜色、线型、宽度等)和标记
patch: 是填充2D空间的图形对象,如多边形和圆。控制线宽、颜色和抗锯齿设置等。
savefig: 可以对保存的图形进行单独设置。例如,设置渲染的文件的背景为白色。
verbose: 设置matplotlib在执行期间信息输出,如silent、helpful、debug和debug-annoying。
xticks和yticks: 为x,y轴的主刻度和次刻度设置颜色、大小、方向,以及标签大小。
3、颜色
可以通过调用matplotlib.pyplot.colors()得到matplotlib支持的所有颜色。
别名 |
颜色 |
别名 |
颜色 |
b |
蓝色 |
g |
绿色 |
r |
红色 |
y |
黄色 |
c |
青色 |
k |
黑色 |
m |
洋红色 |
w |
白色 |
三、雷达图
import numpy as np import matplotlib.pyplot as plt import matplotlib matplotlib.rcParams['font.family']='SimHei'#方便中文能够显示出来 matplotlib.rcParams['font.sans-serif']=['SimHei'] labels=np.array(['第一次作业','第二次作业','第三次作业','第四次作业','第五次作业','第六次作业'])#标签名 nAttr=6#雷达图中六边形边数 data = np.array([5,10,9,10,10,7])#雷达图中标签的数据值 angles = np.linspace(0,2*np.pi,nAttr,endpoint=False)#一哥标签点到另一个标签点画笔所需旋转的角度值,取决于nAttr的大小 data = np.concatenate((data,[data[0]])) angles = np.concatenate((angles,[angles[0]])) fig = plt.figure(facecolor="white" ) plt.subplot(111,polar=True) plt.plot(angles,data,'bo-',color='g',linewidth=2)#画出雷达图中不规则的六边形 plt.fill(angles,data,facecolor='g',alpha=0.25)#填充半透明颜色,即不规则的六边形颜色 plt.thetagrids(angles*180/np.pi,labels)#为雷达图设置标签,就是labels里的文字 plt.figtext(0.52,0.95,'em对的——成绩表',ha='center')#命名雷达图的名字 plt.grid(True) plt.savefig('作业成绩雷达图.JPG')#保存雷达图的图片 plt.show()
效果如下图所示
四、手绘图效果
from PIL import Image import numpy as np vec_el = np.pi/3.3# 光源的俯视角度,弧度值 vec_az = np.pi/9#光源的方位角度,弧度值 depth = 5#(0-100)值越大,整体画面灰度值较深,有近似浮雕的效果;值越小,背景区域接近白色 im = Image.open('Wade.png').convert('L') a = np.asarray(im).astype('float') grad = np.gradient(a)#取图像灰度的梯度值 grad_x,grad_y = grad#分别取横纵图像梯度值 grad_x = grad_x+depth/100. gred_y = grad_y+depth/100. dx = np.cos(vec_el)*np.cos(vec_az)#光源对x轴的影响 dy = np.cos(vec_el)*np.cos(vec_az)#光源对y轴的影响 dz = np.sin(vec_el) #光源对z轴的影响 A = np.sqrt(grad_x**2+grad_y**2+1.) uni_x = grad_x/A uni_y = grad_y/A uni_z = 1./A a2 = 255*(dx*uni_x+dy*uni_y+dz*uni_z)#光源归一化 a2 = a2.clip(0,255)#预防溢出0~255这个区间 im2 = Image.fromarray(a2.astype('uint8'))#重构图像 im2.save('Wade6.png')
效果图: