如何使用python绘制Friedman-Nemenyi检验的结果

发布于 2021-01-29 16:21:45

我针对12个数据集和11个分类器计算了Friedman-Nemenyi检验的结果,我想绘制结果,如下图所示
在此处输入图片说明

我计算了所有需求CD为单一数字(在图中显示为CD),分类列表(C4.5 + m + cf,C4.5 + m等)和均值(在x轴上)

提前谢谢了

2在此处输入链接说明

关注者
0
被浏览
52
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    为了重现上面的图,您可以将普通图的3个棘刺设置为不可见,然后将相应的元素添加到图中。

    在此处输入图片说明

    import matplotlib.pyplot as plt
    
    # input data
    cd = 1.2
    c = 3.2
    ccf = 2.8
    cmcf = 1.9
    cm = 2.05
    
    limits=(4,1)
    
    fig, ax = plt.subplots(figsize=(5,1.8))
    plt.subplots_adjust(left=0.2, right=0.8)
    
    # set up plot
    ax.set_xlim(limits)
    ax.set_ylim(0,1)
    ax.spines['top'].set_position(('axes', 0.6))
    #ax.xaxis.tick_top()
    ax.xaxis.set_ticks_position('top')
    ax.yaxis.set_visible(False)
    for pos in ["bottom", "left", "right"]:
        ax.spines[pos].set_visible(False)
    
    # CD bar
    ax.plot([limits[0],limits[0]-cd], [.9,.9], color="k")
    ax.plot([limits[0],limits[0]], [.9-0.03,.9+0.03], color="k")
    ax.plot([limits[0]-cd,limits[0]-cd], [.9-0.03,.9+0.03], color="k") 
    ax.text(limits[0]-cd/2., 0.92, "CD", ha="center", va="bottom")
    
    # annotations
    bbox_props = dict(boxstyle="square,pad=0.3", fc="w", ec="k", lw=0.72)
    arrowprops=dict(arrowstyle="-",connectionstyle="angle,angleA=0,angleB=90")
    kw = dict(xycoords='data',textcoords="axes fraction",
              arrowprops=arrowprops, bbox=bbox_props, va="center")
    ax.annotate("C4.5", xy=(c, 0.6), xytext=(0,0.25),ha="right",  **kw)
    ax.annotate("C4.5+cf", xy=(ccf, 0.6), xytext=(0,0),ha="right",  **kw)
    ax.annotate("C4.5+m+cf", xy=(cmcf, 0.6), xytext=(1.,0.25),ha="left",  **kw)
    ax.annotate("C4.5+m", xy=(cm, 0.6), xytext=(1.,0),ha="left",  **kw)
    
    #bars
    ax.plot([ccf,c],[0.55,0.55], color="k", lw=3)
    ax.plot([ccf,cmcf],[0.48,0.48], color="k", lw=3)
    
    plt.show()
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看