python 2组list绘制拟合曲线、计算拟合方程 R^2

python 复制代码
import matplotlib.pyplot as plt
import numpy as np
# plt.rcParams['font.family'] = 'SimHei' # 指定使用中文字体,例如宋体(SimHei)

def Curve_Fitting(x, y, deg):
    parameter = np.polyfit(x, y, deg)    #拟合deg次多项式
    p = np.poly1d(parameter)             #拟合deg次多项式
    aa=''                               #方程拼接  ------------------------------------------------------
    for i in range(deg+1): 
        bb=round(parameter[i], 2)
        if bb>0:
            if i==0:
                bb=str(bb)
            else:
                bb='+'+str(bb)
        else:
            bb=str(bb)
        if deg==i:
            aa=aa+bb
        else:
            aa=aa+bb+'x^'+str(deg-i)    #方程拼接  ------------------------------------------------------
    # 利用相关系数矩阵计算R方
    r2 = round(np.corrcoef(y, p(x))[0,1]**2,2)
    plt.scatter(x, y, label="Comparison", color='b', marker='o')     #原始数据散点图
    plt.plot(x, p(x), color='r')  # 画拟合曲线
   # plt.text(-1,0,aa,fontdict={'size':'10','color':'b'})
    plt.legend([f"R^2: {r2}", f"Fitting Equation: {aa}"])   #拼接好的方程和R方放到图例
    # 添加标签和标题
    plt.xlabel("Old Normalized_TMB Values")
    plt.ylabel("New Normalized_TMB Values")
    plt.title("Comparison of Normalized_TMB")
    plt.savefig('./tmp.jpg')
    plt.show()
    print('曲线方程为:',aa)
    
    print('     r^2为:', r2)


def plot_scatter(old_list, new_list):
    # 示例数据:相同样本的两次运行结果
    # sample_names = ["Sample 1", "Sample 2", "Sample 3", "Sample 4"]
    run1_values = old_list  # 第一次运行的数据
    run2_values = new_list  # 第二次运行的数据
    # 创建散点图
    plt.scatter(run1_values, run2_values, label="Comparison", color='b', marker='o')
    # 添加标签和标题
    plt.xlabel("Old Normalized_TMB Values")
    plt.ylabel("New Normalized_TMB Values")
    plt.title("Comparison of Normalized_TMB")
    # 添加数据点的标签
    # for i, sample_name in enumerate(sample_names):
    #     plt.annotate(sample_name, (run1_values[i], run2_values[i]))
    # 添加一条线表示一对一的关系
    plt.plot([min(run1_values), max(run1_values)], [min(run1_values), max(run1_values)], linestyle='--', color='r', label="1:1 Line")
    # 显示图例
    plt.legend()
    plt.savefig('./tmp.jpg')
    # 显示散点图
    plt.show()





normalzed_tmb_compare_file = 'normalzed_tmb.txt'
old_FFPE_list, new_FFPE_list = [], []
old_CF_list, new_CF_list = [], []
with open(normalzed_tmb_compare_file) as f:
    next(f)
    for line in f:
        line_list = line.strip('\n').split('\t')
        # if float(line_list[0]) > 20:
        #     continue
        old, type_, new = line_list
        if type_ == 'FFPE':
            old_FFPE_list.append(float(line_list[0]))
            new_FFPE_list.append(float(line_list[-1]))
        if type_ == 'CF':
            old_CF_list.append(float(line_list[0]))
            new_CF_list.append(float(line_list[-1])) 
    # Curve_Fitting(old_FFPE_list, new_FFPE_list, 1)
    # Curve_Fitting(old_CF_list, new_CF_list, 1)
    Curve_Fitting(old_CF_list+old_FFPE_list, new_CF_list+new_FFPE_list, 1)
    # plot_scatter(old_list, new_list)
相关推荐
呱呱复呱呱31 分钟前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
曲幽5 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
荣码6 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱15 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵17 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio20 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户0332126663671 天前
使用 Python 从零创建 Word 文档
python
Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维