python绘制1:1对角线(1:1 line)

本文基于python绘制1:1对角线并x、y数据之间的R方。

效果图:

在这里插入图片描述

蓝色线表示拟合线,黑色线表示1:1线。

详细代码:

import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
from pylab import mpl
from matplotlib.pyplot import MultipleLocator

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

fn = u'D://aaa.xlsx'
df = pd.read_excel(fn,'Sheet1',index_col=0)
a = df['a']

fn2 = u'E://ccc.csv'
df2 = pd.read_csv(fn2)
c = df2['c']

a.index = range(len(a))
b.index = range(len(a))
c.index = range(len(a))


fig, ax = plt.subplots(1, 1,figsize=(7,7),dpi=300)
## 绘制1:1对角线
ax.plot((0, 1), (0, 1), transform=ax.transAxes, ls='--',c='k', label="1:1 line")

ax.plot(c,a,'o',c='royalblue')

parameter = np.polyfit(c,a,1)
f = np.poly1d(parameter)
ax.plot(c,f(c),'b--',lw=3)

corr = np.corrcoef(c,a)[0,1]
bbox = dict(boxstyle="round", fc='1',alpha=0.5)
plt.text(0.05, 0.9, '$R^2=%.2f$' % (corr**2), 
         transform=ax.transAxes, size=25, bbox=bbox)

ax.set_xlabel('修改后',fontsize=30)
ax.set_ylabel('观测值',fontsize=30)
# 设置图片title
ax.tick_params(labelsize=27)

x_major_locator=MultipleLocator(10)
ax.xaxis.set_major_locator(x_major_locator)
y_major_locator=MultipleLocator(10)
ax.yaxis.set_major_locator(y_major_locator)
ax.set(xlim=(-22,25),ylim=(-22,25))

plt.show()
  • 11
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

撼沧

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

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

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

打赏作者

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

抵扣说明:

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

余额充值