Python学习第十二周作业——绘制函数图像

本文通过三个实例展示了如何使用Python进行函数图像绘制、利用最小二乘法进行参数估计以及绘制直方图并估计概率密度函数。涉及matplotlib、numpy及scipy等库的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Python可以绘制函数图像,但需要扩展包matplotlib支持。

第一题


绘制函数图像,添加标签和标题

import numpy as np
from matplotlib import pyplot as plt 
x = np.linspace(0,2,50)
y = np.sin(x-2) * np.sin(x-2) * np.exp(-x**2)
plt.figure(1)
plt.xlabel("x")
plt.ylabel("y")
plt.ylim(-0.1, 1)
plt.title(r"$f(x) = sin^2(x-2)e^{-x^2}$")
plt.annotate('max', xy=(0.22, 0.9), xytext=(0.22, 0.5),
            arrowprops=dict(facecolor='black'))
plt.plot(x,y)
plt.show()

第二题


给定y=b*x+z中各个量的值,根据x和y的值估计b的值,使用最小二乘法。

import numpy as np    
from matplotlib import pyplot as plt     
from scipy.optimize import leastsq  
X = np.random.normal(loc=5,scale=5,size=(20,10))  
b = np.random.normal(loc=0,scale=5,size=10)  
z = np.random.normal(size=20)  
y = np.dot(X,b) + z  
  
# 初始向量  
b_est = np.ones(10)  
  
# 误差计算  
def error(p,x,y):  
    return np.dot(x,p)-y  
  
# 最小二乘法函数调用  
b_est,cost=leastsq(error,b_est,args=(X,y))   
  
# 绘制图像  
plt.xlabel("base")  
plt.ylabel("value")  
plt.plot(b, 'rx', label="Coefficients")  
plt.plot(b_est, 'b', label="Estimated Coefficients")  
plt.legend(bbox_to_anchor=(1, 1), loc=0, borderaxespad=0)  
plt.axis([0,10,-10,10])  
plt.hlines(0,0,9 ,colors = "c", linestyles = "dashed")  
plt.show()  

第三题


绘制直方图并估计函数密度。

import numpy as np  
from matplotlib import pyplot as plt
from scipy import stats  
data = np.random.normal(scale=100, size=10000)
gauss = stats.gaussian_kde(data)
full_data = np.linspace(-500,500,10000)
est_data = gauss.evaluate(full_data)
plt.hist(data, 30, density=True)
plt.plot(full_data, est_data)
plt.show()


### 如何使用 Python 实现绘制由十个线段组成的图形 以下是两种方法分别基于 `matplotlib` 和 `turtle` 库来实现绘制由十个随机线段组成的图形。 #### 方法一:使用 Matplotlib 绘制十条线段 通过定义每条线段的起点和终点坐标,可以轻松利用 `matplotlib` 的 `plot` 函数完成此任务。以下是一个完整的代码示例: ```python import matplotlib.pyplot as plt import numpy as np # 初始化布 fig, ax = plt.subplots() # 定义十条线段的起点和终点 np.random.seed(42) # 固定随机种子以便结果可重复 segments = [] for _ in range(10): start_x, start_y = np.random.uniform(-10, 10, 2) end_x, end_y = np.random.uniform(-10, 10, 2) segments.append(((start_x, start_y), (end_x, end_y))) # 绘制线段 for segment in segments: x_values = [segment[0][0], segment[1][0]] y_values = [segment[0][1], segment[1][1]] ax.plot(x_values, y_values, 'b-', linewidth=2) # 设置坐标轴范围 ax.set_xlim([-15, 15]) ax.set_ylim([-15, 15]) # 添加网格 ax.grid(True) # 显示图像 plt.title("Ten Random Line Segments", fontsize=16) plt.xlabel("X-axis") plt.ylabel("Y-axis") plt.show() ``` 以上代码生成了一个包含十条随机分布线段的图形[^1]。 --- #### 方法二:使用 Turtle 绘制十条线段 `turtle` 是一个简单易用的绘图库,适合初学者学习基本几何形状的绘制。下面是如何使用它创建一条路径并连接十个点形成线段的例子: ```python import turtle import random # 配置屏幕大小 screen = turtle.Screen() screen.setup(width=800, height=600) # 创建笔对象 pen = turtle.Turtle() pen.speed(1) # 控制速度,数值越低越慢 pen.penup() # 提起笔以移动而不留下痕迹 # 定义十个随机位置作为端点 points = [(random.randint(-300, 300), random.randint(-200, 200)) for _ in range(10)] # 开始绘制第一条线之前先定位到第一个点 pen.goto(points[0]) pen.pendown() # 连接剩余九个点依次成线 for point in points[1:]: pen.goto(point) # 结束后隐藏海龟图标 pen.hideturtle() # 关闭窗口前等待点击事件 screen.exitonclick() ``` 这段程序会打开一个新的窗口,在其中展示了一组按顺序相连的十段线条[^4]。 --- ### 总结说明 无论是采用功能强大的科学计算可视化工具 `matplotlib`,还是趣味性强的教学型模块 `turtle`,都可以很好地满足题目需求——即构建一幅具有明确结构特征(此处指明为“十段独立或连续”的连线)的面效果。前者更适合处理复杂数据集以及追求高效批量化生产的场景;后者则因其直观性和互动特性而成为教育领域内的理想选择之一。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值