在學習machine learing 和Deep learning的時候難免會有一些數據的操做,科學計算和一些矩陣的操做須要用到numpy,而若是想可視化的時候,好比效果展現和調參的時候就須要畫圖,因此咱們plot的的時候就須要用到一個很強大的包,叫matplotlib,今天對這兩個包展開說明,都時常常用到的一些簡單的操做!python
array = np.array([[1,2,3],[2,3,4]]) #列表生成矩陣
array.ndim # 幾維 2
array.shape #長寬 (2,3)
array.size #元素個數 6
np.array([1,2,3],dytpe = np.int) #int32 int64 float32
np.zeros((3,4)) #3行4列 全爲0
np.ones((3,4),dtype=int) #同理
np.empty((3,4)) #幾乎爲0 的矩陣
np.arange(10,20,2) #起始 結束 步長 相似於python中的range 10 12 14 16 18
np.arange(12).reshape(3,4) #生成矩陣3行4列
A.flat #將矩陣轉變爲一個向量 返回迭代器
A.flatten #將矩陣轉變爲一個向量 返回列表
np.linspace(1,10,20) #1到10分20段 生成20個數
np.random.random((2,4)) #隨機生成2行4列的矩陣
np.random.normal(0, 0.05, x_data.shape)
+ - *
** #平方
np.sin()
print(b<3) #b是矩陣 返回[true,false,...]
a*b #矩陣點乘 a,b分別爲矩陣
np.dot() 或 a.dout(b) #矩陣相乘
np.sum(arg1,arg2) #arg1是矩陣,arg2是行(0)或者列(1)
np.min(arg1,arg2)
np.max(arg1,arg2)
np.mean(A) 或A.mean() 或 np.average(A)
np.median(A) #中位數
np.cumsum(A) #求前n個元素的和 [[1,2,3],[4,5,6]] => [1,3,6,10 ...]
np.diff(A) #相鄰差
np.argmin() #最小值的索引
np.sort(A) #逐行排序
np.transport(A) 或 A.T #轉置
np.clip(A,5,9) #小於5的轉成5,大於9的轉成9,中間不變
A[1][2] 或 A[1,2]
A[:,1] 第一列說有數
A[1,1:2] 第一行第1 2列
A = np.array([1,1,1])
B= np.array([2,2,2])
np.vstack((A,B)) #上下合併 => [[1,1,1],[2,2,2]]
np.hstack((A,B)) #左右合併 => [1,1,1,2,2,2]]
np.concatenate((A,B,A,B),axis=1) #多個合併 第二個參數是維度
A[:,np.newaxis] #在縱向增長一個維度
np.split(A,片斷個數,axis=?) #等量分割
np.array_split(A,片斷個數,axis=? #不等量分割
np.vsplit(A,片斷個數) #縱向分割
np.hsplit(A,片斷個數) #橫向分割
python賦值(=)存在關聯性 numpy copy
copy() #沒有關聯的賦值 deep copy
#example
import numpy as np
import matplotlib.pyplot as plt
x=np.linspace(-3,3,50)
y1=2*x+1
y2=x**2
plt.figure(num=?,figsize=(8,5)) #下面的在一張圖裏
plt.plot(x,y1)
plt.plot(x,y2,color='red',linewidth=1.0,linestyle='- -')
plt.figure(num=?,figsize=(8,5))#下面的在一張圖裏
plt.plot(x,y2)
plt.show()
import matplotlib.pyplot as plt
import numpy as np
x = np.linspace(-3, 3, 50)
y1 = 2*x + 1
y2 = x**2
plt.figure()
plt.plot(x, y2)
# plot the second curve in this figure with certain parameters
plt.plot(x, y1, color='red', linewidth=1.0, linestyle='--')
# set x limits
plt.xlim((-1, 2))
plt.ylim((-2, 3))
plt.xlabel('I am x')
plt.ylabel('I am y')
# set new sticks
new_ticks = np.linspace(-1, 2, 5)
print(new_ticks)
plt.xticks(new_ticks)
# set tick labels
plt.yticks([-2, -1.8, -1, 1.22, 3],
[r'$really\ bad$', r'$bad$', r'$normal$', r'$good$', r'$really\ good$']) #機器可讀數學表示字體 很像LaTeX
plt.show()
修改座標軸的位置markdown
import matplotlib.pyplot as plt
import numpy as np
x = np.linspace(-3, 3, 50)
y1 = 2*x + 1
y2 = x**2
plt.figure()
plt.plot(x, y2)
# plot the second curve in this figure with certain parameters
plt.plot(x, y1, color='red', linewidth=1.0, linestyle='--')
# set x limits
plt.xlim((-1, 2))
plt.ylim((-2, 3))
# set new ticks
new_ticks = np.linspace(-1, 2, 5)
plt.xticks(new_ticks)
# set tick labels
plt.yticks([-2, -1.8, -1, 1.22, 3],
['$really\ bad$', '$bad$', '$normal$', '$good$', '$really\ good$'])
# to use '$ $' for math text and nice looking, e.g. '$\pi$'
# gca = 'get current axis'
ax = plt.gca()
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')
ax.xaxis.set_ticks_position('bottom')
# ACCEPTS: [ 'top' | 'bottom' | 'both' | 'default' | 'none' ]
ax.spines['bottom'].set_position(('data', 0))
# the 1st is in 'outward' | 'axes' | 'data'
# axes: percentage of y axis
# data: depend on y data
ax.yaxis.set_ticks_position('left')
# ACCEPTS: [ 'left' | 'right' | 'both' | 'default' | 'none' ]
ax.spines['left'].set_position(('data',0))
plt.show()
在example基礎上修改
plt.plot(x, y1, label=’linear line’) #增長了label
plt.plot(x, y2, color=’red’, linewidth=1.0, linestyle=’–’, label=’square line’) #增長了label
plt.legend(loc=’best’) #自動找一個比較合適的位置dom
import matplotlib.pyplot as plt
import numpy as np
n = 1024
X = np.random.normal(0,1,n)
Y = np.random.normal(0,1,n)
T = np.arctan2(Y,X) #for color value
plt.scatter(X,Y,s=75,c=T,alpha=0.5)
plt.xlim(-1.5,1.5)
plt.ylim(-1.5,1.5)
plt.xticks(())#讓座標消失
plt.yticks(())
plt.show()
均勻學習
#兩行兩列
plt.figure(figsize=(6, 4))
# plt.subplot(n_rows, n_cols, plot_num)
plt.subplot(2, 2, 1) #行 列 第幾個
plt.plot([0, 1], [0, 1])
plt.subplot(2,2,2)
plt.plot([0, 1], [0, 2])
plt.subplot(2,2,3)
plt.plot([0, 1], [0, 3])
plt.subplot(2,2,4)
plt.plot([0, 1], [0, 4])
plt.tight_layout()
不均勻字體
plt.figure(figsize=(6, 4))
# plt.subplot(n_rows, n_cols, plot_num)
plt.subplot(2, 1, 1) #兩行,一列,第一個
# figure splits into 2 rows, 1 col, plot to the 1st sub-fig
plt.plot([0, 1], [0, 1])
plt.subplot(2,3,4)#兩行 三列 第4個
# figure splits into 2 rows, 3 col, plot to the 4th sub-fig
plt.plot([0, 1], [0, 2])
plt.subplot(2,3,5)
# figure splits into 2 rows, 3 col, plot to the 5th sub-fig
plt.plot([0, 1], [0, 3])
plt.subplot(2,3,6)
# figure splits into 2 rows, 3 col, plot to the 6th sub-fig
plt.plot([0, 1], [0, 4])