当前位置: 首页 > news >正文

《数据分析与可视化》(清华)ch-6 作业 三、绘图题

1.根据如下绘制写出相应的代码。

1.绘制函数:y=sin(x),y=cos(x),x=np.linspace(-np.pi,np.pi,256,endpoint=Ture)
2.绘制填充区域:
紫色区域:(-2.5<x)&(x<0.5)
绿色区域:np.abs(x)<0.5,sin(x)>0.5
紫色的设置:color=‘purple’

答案:

修改后的代码:

import matplotlib.pyplot as plt
import numpy as npplt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = Falsex = np.linspace(-np.pi, np.pi, 256, endpoint=True)
sin, cos = np.sin(x), np.cos(x)plt.plot(x, sin, "b-", lw=2.5, label="正弦 Sin()")
plt.plot(x, cos, "r-", lw=2.5, label="余弦 Cos()")plt.xlim(x.min() * 1.5, x.max() * 1.5)
plt.ylim(cos.min() * 1.5, cos.max() * 1.5)plt.xticks([-np.pi, -np.pi / 2, 0, np.pi / 2, np.pi], [r'$-\pi$', r'$-\pi/2$', r'$0$', r'$\pi/2$', r'$\pi$'])
plt.yticks([-1, 0, 1])ax = plt.gca()
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')ax.xaxis.set_ticks_position('bottom')
ax.spines['bottom'].set_position(('data', 0))
ax.yaxis.set_ticks_position('left')
ax.spines['left'].set_position(('data', 0))plt.legend(loc="upper left", fontsize=12)t1 = -np.pi
t2 = 2 * np.pi / 3plt.scatter([t1,], [np.cos(t1),], 50, color='b')
plt.scatter([t2,], [np.sin(t2),], 50, color='r')plt.annotate(r'$\sin(\frac{2\pi}{3})=\frac{\sqrt{3}}{2}$',xy=(t2, np.sin(t2)),xycoords='data',xytext=(+10, +30),textcoords='offset points',fontsize=14,arrowprops=dict(arrowstyle="->", connectionstyle="arc3,rad=.2"))for label in ax.get_xticklabels() + ax.get_yticklabels():label.set_fontsize(18)plt.fill_between(x, np.abs(x) < 0.5, sin, sin > 0.5, color='g', alpha=0.8)
plt.fill_between(x, cos, where=(-2.5 < x) & (x < -0.5), color='purple')
plt.text(4.5,1,'Povchar',fontsize=15,alpha=0.3,color='gray',bbox=dict(fc="white",boxstyle='round',edgecolor='gray',alpha=0.3))
plt.grid()
plt.show()

运行结果:

声明:文章仅供学习使用。著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。  

相关文章:

  • 前端面试每日三题 - Day 26
  • 如何用爬虫获得按关键字搜索淘宝商品
  • 【能力比对】K8S数据平台VS数据平台
  • 第2章 神经网络的数学基础
  • 【高级IO】多路转接之select
  • SQLark可以支持PostgreSQL了,有哪些新功能?
  • AI应用爆发或将进入临界点
  • 【HarmonyOS 5】鸿蒙发展历程
  • uv简单使用
  • Vue 3 和 Vue 2 有哪些主要区别
  • 使用OpenCV 和 Dlib 实现年龄性别预测
  • OpenCV 图形API(78)图像与通道拼接函数-----调整图像大小的函数resize()
  • python仓库库存管理系统-药房药品库存管理系统
  • 颠覆监测体验!WM102无线温湿度记录仪开启智能物联新时代
  • .NET 通过回调函数执行 Shellcode启动进程
  • 基于nacos实现动态线程池设计与实践:告别固定配置,拥抱弹性调度
  • 即开即用,封装 Flask 项目为 exe 文件实操步骤
  • Os 库报错指南 路径处理常见陷阱
  • 在 Sheel 中运行 Spark:开启高效数据处理之旅
  • Python 中的数据结构介绍
  • 安徽六安原市长潘东旭,已任省市场监督管理局党组书记、局长
  • 全国首例在沪完成,这项近视治疗手术不到10秒
  • 印巴战火LIVE|巴基斯坦多地遭印度导弹袭击,巴总理称“有权作出适当回应”
  • 李云泽:再批复600亿元,进一步扩大保险资金长期投资试点范围
  • 起底新型保健品电话销售诈骗:从快递信息中筛选对象,忽悠其高价买药
  • 共生与伴生:关于人工智能时代艺术评论的对象与主体的思考