《Python编程:从入门到实践》练习15-3、15-4、15-5

练习 15-3:分子运动 —— 修改rw_visual.py,将其中的ax.scatter()替换为ax.plot()。为模拟花粉在水滴表面的运动路径,向plt.plot()传递rw.x_values和rw.y_values,并指定实参linewidth。请使用5000个点而不是50000个点。

rw_visual.py

import matplotlib.pyplot as plt
from random_walk import RondomWalk

# 只要程序处于活动状态,就不断地模拟随机漫步
while True:
    # 创建一个RandomWalk实例
    rw = RondomWalk(50_000)
    rw.fill_walk()

    # 将所有的点都绘制出来
    plt.style.use('classic')
    fig, ax = plt.subplots(figsize=(8,5), dpi=128)
    point_numbers = range(rw.num_points)
    ax.scatter(rw.x_values, rw.y_values, c=point_numbers, cmap=plt.cm.hsv, 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='black', edgecolors='none', s=100)

    # 隐藏坐标轴
    ax.get_xaxis().set_visible(False)
    ax.get_yaxis().set_visible(False) # 将坐标轴地可见性设置为False
    plt.show()

    keeping = input("Make another walk? (y/n):")
    if keeping == 'n':
        break

修改后的rw_visual.py

# 分子运动:修改rw.visual.py,将其中的ax.scatter()替换为ax.plot()。
# 为模拟花粉在水滴表面的运动路径,向plt.plot()传递rw.x_values,并指定实参linewidth。使用5000个点。
import matplotlib.pyplot as plt
from random_walk import RondomWalk

# 只要程序处于活动状态,就不断地模拟随机漫步
while True:
    # 创建一个RandomWalk实例
    rw = RondomWalk()
    rw.fill_walk()

    # 将所有的点都绘制出来
    plt.style.use('classic')
    fig, ax = plt.subplots(figsize=(8, 5), dpi=128)
    point_numbers = range(rw.num_points)
    ax.plot(rw.x_values, rw.y_values, 'b')

    # 突出起点和终点
    ax.plot(0, 0, 'o-g', linewidth=10)
    ax.plot(rw.x_values[-1], rw.y_values[-1], 'o-r', linewidth=10)

    # 隐藏坐标轴
    ax.get_xaxis().set_visible(False)
    ax.get_yaxis().set_visible(False)  # 将坐标轴地可见性设置为False
    plt.show()

    keeping = input("Make another walk? (y/n):")
    if keeping == 'n':
        break

random_walk.py

from random import choice


class RondomWalk:
    """ 一个生成随机漫步数据的类 """

    def __init__(self, num_points=5000):
        """ 初始化随机漫步的属性 """
        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_direction * x_distance

            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值和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)

效果图:

 练习 15-4:改进的随机漫步 —— 在类RandomWalk中,x_step和y_step是根据相同的条件生成的:从列表[-1, 1]中随机选择方向,并从列表[0, 1, 2, 3, 4]中随机选择距离。请修改这些列表中的值,看看对随机漫步路径有何影响。尝试使用更长的距离选择列表(如1~8),或者将-1从x或y方向列表中删除。

# 练习 15-4
# 改进的随机漫步: 在类RandomWalk中,x_step和y_step是根据相同的条件生成的:从列表[-1, 1]中随机选择方向,
# 并从列表[0, 1, 2, 3, 4]中随机选择距离。请修改这些列表中的值,看看对随机漫步路径有何影响。
# 尝试使用更长的距离选择列表(如1~8),或者将-1从x或y方向列表中删除。
from random import choice


class RondomWalk:
    """ 一个生成随机漫步数据的类 """

    def __init__(self, num_points=5000):
        """ 初始化随机漫步的属性 """
        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_distance = choice(range(0, 9))
            x_step = x_direction * x_distance

            # y_direction = choice([1, -1])
            y_direction = 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值和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)

改进后的效果图:

 改进前的图:

 练习 15-5:重构 —— 方法fill_walk()很长。请新建一个名为get_step()的方法,用于确定每次漫步的距离和方向,并计算每一步。然后,在fill_walk()中调用get_step()两次:

x_step = self.get_step()

y_step = self.get_step()

通过这样的重构,可缩小方法fill_walk(),让它阅读和理解起来更容易。

# 练习15-5: 重构:将fill_walk拆分,新建一个名为get_step()的方法
from random import choice


class RondomWalk:
    """ 一个生成随机漫步数据的类 """

    def __init__(self, num_points=5000):
        """ 初始化随机漫步的属性 """
        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_step = self.get_step()
            y_step = self.get_step()

            # 拒绝原地踏步
            if x_step == 0 and 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)

    def get_step(self):
        """ 决定前进方向以及沿这个方向前进的距离 """
        direction = choice([1, -1])
        distance = choice([0, 1, 2, 3, 4])
        self.step = direction * distance

        return self.step

关于matplotlib.pyplot的一些基础操作,可以查看

Matplotlib学习 —— Pyplot_笨小古的博客-CSDN博客https://blog.csdn.net/weixin_51995147/article/details/125220863?spm=1001.2014.3001.5501

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笨小古

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值