綜合前述的類、函數、matplotlib等,完成一個隨機移動的過程(註意要確定移動的次數,比如10萬次),每次行走都完全是隨機的,沒有明確的方向,結果是由一系列隨機決策確定的,最後顯示出每次移動的位置的圖表。 思考: 1)每次走動多少個像素,由隨機函數決定,每次移動方向也隨機確定。由隨機方向和隨機像 ...
綜合前述的類、函數、matplotlib等,完成一個隨機移動的過程(註意要確定移動的次數,比如10萬次),每次行走都完全是隨機的,沒有明確的方向,結果是由一系列隨機決策確定的,最後顯示出每次移動的位置的圖表。
思考:
1)每次走動多少個像素,由隨機函數決定,每次移動方向也隨機確定。由隨機方向和隨機像素共同移動位置大小和方向。
2)保證將每次移動的位置保存在列表中,供後面matplotlib調用,生成圖表。
故而,可以分成兩個文件,一個為rand_moving類,生成走動像素、方向,並記錄相關數據,保存在數列中,另一個為繪圖模塊randdraw_visual ,調用matplotlib和rand_moving類,生成一個實例,並調用計算出的數列組生成圖表。
一、rand_moving.py文件定義功能如下
1、初始化程式,設置一個參數,即移動的次數,初始化位置全部設置為0
2、隨機生成x,y的方向和移動像素,並相乘,得到相對移動距離,即為每次移動的距離和方向,即需要4個隨機函數來分別確定水平方向和垂直方向的 移動位置大小和方向,
3,計算出下一個位置,併進行保存到位置數列中,即每走完一步後,在屏幕中的絕對位置。
如下:
from random import choice #random是系統自帶的隨機函數模塊 class Rand_moving(): #定義一個Rand_moving類 def __init__(self,num_times=100000): # 初始化,設置預設參數為10萬,可以修改這個參數試試機器運行速度 self.num_times = num_times #移動次數 self.x_values=[0] # 設置兩個數列,用來保存每一步的位置,初始位置為(0, 0),數列元素個數會一直增加到num_times,用來記錄每一步的位置信息 self.y_values=[0] def fill_moving(self): #定義一個函數,用來計算移動方向和距離,並計算需要保存的位置信息 while len(self.x_values)<self.num_times:#迴圈不斷運行,直到漫步包含所需數量的點num_times
x_direction = choice([1,-1]) #x的移動方向,1向上,0不變,-1向下 x_distance = choice([0,1,2,3,4,5]) #x的每次移動的像素, x_step = x_direction*x_distance #移動方向乘以移動距離,以確定沿x移動的距離 y_direction = choice([1,-1]) #y的移動方向,1向上,0不變,-1向下 y_distance = choice([0,1,2,3,4,5]) #y的每次移動的像素, y_step = y_direction*y_distance #移動方向乘以移動距離,以確定沿y移動的距離 #原地不變 if x_step ==0 and y_step==0: # x_step和 y_step都為零,則意味著原地踏步 continue #計算下一個點的位置坐標x和y值,並分別保存到數列x_values和y_values中 next_x = self.x_values[-1] + x_step #self.x_values[-1]表示是數列最後一個值,初始為x_values=[0] next_y = self.y_values[-1] + y_step self.x_values.append(next_x ) #將每次計算的next_x存入到數列x_values中 self.y_values.append(next_y ) #將每次計算的next_y存入到數列y_values中
二、繪圖模塊 randdraw_visual.py
繪圖模塊randdraw_visual.py的功能如下:
1、調用matplotlib和rand_moving類;
2、rand_moving生成一個實例,並計算出的數列組生成圖表;
3、用matplotlib中的方法生成圖表
import matplotlib.pyplot as plt #導入matplotlib模塊 from rand_moving import * #也可以用 import random_moving 註意使用過程中的細微差別 ,小寫開頭的rand_moving是文件(或稱為模塊,一個模塊中可以有一個類,或多個類),大寫開頭Rand_moving是類。 rm = Rand_moving() # 利用導入的 Rand_moving 類,創建一個實例rm,這裡沒有給定參數,預設是10萬,可以修改為其他數據。 rm.fill_moving() # 調用類的方法fill_moving() ,並生成隨機數列,存入到x_values和y_values中, plt.scatter(rm.x_values, rm.y_values,s=15)#調用實例rm中位置數列x_values和y_values生成圖表 plt.show()
程式運行效果(註意,為了對比,程式中創建了3個實例,其中一個為預設值,另兩個為50萬和5萬,如果一直沒顯示,請耐心等會兒!)
上述三個實例處在同一圖中,呈現不同顏色,如果只有一個實例,如何修改顏色?
入門(1)中,語句 plt.scatter(x_values, y_values, c=y_values, cmap=plt.cm.Blues,edgecolor='none', s=40) 是修改漸變色的,可償試將randdraw_visual.py模塊中進行如下修改:
plt.scatter(rm.x_values, rm.y_values,c=y_values, cmap=plt.cm.Reds,edgecolor='none',s=15)
註: c的參數是字元串,可以直接使用顏色的英文進行賦值,比如:c='yellow',見後面修改起點、終點顏色。
指定一個紅色,一個藍色,實際運行效果(有重覆的地方,實例設置為藍色在後面,將紅色蓋住):
除些之外,還可以對特定的點進行設定,也就是在語句plt.scatter(rm.x_values, rm.y_values,c=y_values, cmap=plt.cm.Reds,edgecolor='none',s=15)之後,再多幾個相關語句,並給定相關點坐標。
import matplotlib.pyplot as plt from rand_moving import * #也可以用import random_moving註意使用過程中的差別 rm = Rand_moving() # 創建一個實例rm,這裡沒有給定參數,預設是10萬,可以修改為其他數據。 rm.fill_moving() # 調用類的方法fill_moving() ,並生成隨機數列,存入到x_values和y_values中 plt.scatter(rm.x_values,rm.y_values,c=rm.y_values,cmap=plt.cm.Reds,edgecolor='none',s=15) #調用實例rm中數列x_values和y_values生成圖表#調用實例rm中數列x_values和y_values生成圖表 new_rm = Rand_moving(500000) # 創建一個實例new_rm,是50萬次 new_rm.fill_moving() plt.scatter(new_rm.x_values,new_rm.y_values,c=new_rm.y_values, cmap=plt.cm.Blues,edgecolor='none',s=15) # 重繪起點,終點 #因為兩個實例的起點一樣,只需一個起點即可 plt.scatter(rm.x_values[0], rm.y_values[0],c='yellow',edgecolor='none',s=100) #設置起點,把s設置較大,以示區別 #兩個實例終點不同,分別重繪終點位置 plt.scatter(rm.x_values[-1], rm.y_values[-1],c='brown',edgecolor='none',s=100) #設置實例rm的終點,思考為什麼用[-1] plt.scatter(new_rm.x_values[-1], new_rm.y_values[-1],c='pink',edgecolor='none',s=100) #設置實例new_rm的終點 plt.show()
實際運行效果:
顯示圖表屏幕大小
圖表適合屏幕大小能有效地將數據中的規律呈現出來,如果要調整屏幕大小,可調整matplotlib輸出的尺寸
plt.figure(dpi=128,figsize=(12, 10))
函數 figure() 用於指定圖表的寬度、高度、解析度和背景色。
形參 figsize 指定一個元組
形參 dpi 向 figure() 傳遞該解析度
註意:plt.figure(dpi=128,figsize=(12, 10))語句要在其他plt開始語句的前面,才能調整顯示屏幕的大小。
import matplotlib.pyplot as plt from rand_moving import * #也可以用import random_moving註意使用過程中的差別 #調整屏幕大小 plt.figure(dpi=128,figsize=(12, 10)) #一開始就要定義顯示的大小,當然,可以試一下,放到plt.show()之前其他位置的運行效果。 rm = Rand_moving() # 創建一個實例rm,這裡沒有給定參數,預設是10萬,可以修改為其他數據。 rm.fill_moving() # 調用類的方法fill_moving() ,並生成隨機數列,存入到x_values和y_values中 plt.scatter(rm.x_values,rm.y_values,c=rm.y_values,cmap=plt.cm.Reds,edgecolor='none',s=15) #調用實例rm中數列x_values和y_values生成圖表#調用實例rm中數列x_values和y_values生成圖表 new_rm = Rand_moving(500000) # 創建一個實例new_rm,是50萬次 new_rm.fill_moving() plt.scatter(new_rm.x_values,new_rm.y_values,c=new_rm.y_values, cmap=plt.cm.Blues,edgecolor='none',s=15) plt.show()
當然,還可以試一下他函數功能。
是不是有點小小的成就感!
請思考:
1、上述程式是否能進行優化(比如功能相同的)
2、創建三個3個實例,用了3個語句,能否建一個函數,只輸入一個數n,就自動創建n個實例?同時,每個實例的num_times隨機,(n比較大時,num_times應該比較小)
3、當實現上述功能後,程式運行,只輸入一個參數(創建實例的個數),就會自動生成對應的num_times,並分別調用相關函數生成對應圖表。