基于python的随机漫步图

基于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

最后效果图:

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值