随机漫步
随机漫步,顾名思义,每一步都是随机的,假设有一个点,下一步往哪里走,往上?往下?往左还是右?走多远?这些都没有明确的表示,完全是随机的,最后走到哪里,是由一系列随机决策决定的。这就是随机漫步。
那么使用python怎么样模拟随机漫步呢
首先我们需要创建一个类,这个类需要具备三个属性,1.随机漫步多少次?2,随机漫步每一个点的x坐标?3.y坐标?
如下我们创建一个随机漫步类,默认随机漫步5000次,设置起始坐标为(0,0)
class RandomWalk():
def __init__(self,num_points=5000):
self.num_points=num_points
self.x_values=[0]
self.y_values=[0]
那么,我们应该怎么计算每次随机漫步走到哪里了呢,现在起点有了,是(0,0),我们需要给他选择,让它自己随机选择是往左还是往右,往上还是往下,走一步还是两步还是三步四步?我们需要定义一个方法,来生成随机漫步所包含的点
def fill_walk(self):
#当横坐标小于随机漫步次数时
while len(self.x_values) < self.num_points:
#决定前进方向向左还是右?
x_direction=choice([1,-1])
#决定走多远
x_distance=shoice([0,1,2,3,4])
#决定走的距离
x_step=x_direction*x_distance
#y方向同理
y_direction=choice([1,-1])
y_distance=choice([0,1,2,3,4])
y_step=y_direction*y_distance
#不让他原地踏步
if x_step==0 and y_step==0:
continue
#下一个点的x值
next_x=self.x_values[-1]+x_step
#下一个点的y值
next_y=self.y_values[-1]+y_step
self.x_values.append(next_x)
self.y_values.append(next_y)
下面我们把这个随机漫步绘制出来
rw=RandomWalk()
rw.fill_walk()
plt.scatter(rw.x_values,rw.y_values,s=1)
plt.show()
此次如下图所示