基于python写了一个随机漫步的程序,最终效果图还挺好看的
import matplotlib.pyplot as plt
from random import choice
class RandomWalk:
'''一个生成随机漫步数据的类'''
def __init__(self,num_points=50000):
'''初始化随机漫步的属性'''
self.num_points=num_points
#所有随机漫步都开始于(0,0)
self.x_values=[0]
self.y_values=[0]
def fill_walk(self):
'''计算随机漫步包含的所有点'''
#不断漫步,直到列表达到指定的长度
while len(self.x_values)<self.num_points:
#决定前进方向及沿方向前行的距离
x_direction=choice([-1,1])
x_distance=choice([0,1,2,3,4])
x_step=x_distance*x_direction
y_direction = choice([-1, 1])
y_distance = choice([0, 1, 2, 3, 4])
y_step = y_distance * y_direction
#拒绝原地踏步
if x_step==0 or y_step==0:
continue
#计算下一个点的x值和y值
x=self.x_values[-1]+x_step
y=self.y_values[-1]+y_step
self.x_values.append(x)
self.y_values.append(y)
while True:
rw = RandomWalk()
rw.fill_walk()
# 将所有点画出来
plt.style.use('classic')
fig, ax = plt.subplots(figsize=(15,9))
point_numbers=range(rw.num_points)
ax.scatter(rw.x_values, rw.y_values,c=point_numbers,cmap=plt.cm.Blues,edgecolors='none', s=1)
#突出起点和终点
ax.scatter(0,0,c='green',edgecolors='none',s=100)
ax.scatter(rw.x_values[-1],rw.y_values[-1],c='red',edgecolors='none',s=100)
plt.savefig('随机漫步.png',bbox_inches='tight')
keep_running=input('make another walk?(y/n):')
if keep_running=='n':
break
最后效果图: