《数据分析与可视化》(清华)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 np

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

x = 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 / 3

plt.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()

运行结果:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值