from matplotlib.lines import Line2D
import matplotlib.pyplot as plt
import numpy as np

plt.figure(figsize=(11,3), dpi=300)
# plt.subplots_adjust(left=0.04,bottom=0.18,right=0.99,top=0.96) # 设置子图间距
plt.subplots_adjust(left=0.1,bottom=0.25,right=0.99,top=0.96) # 设置子图间距
# 假设的数据
x = [1, 2, 3, 4, 5]  # x轴数据

# Reti18-------------------

# bbox_head.cls_convs.0.conv_in: 0.04663718119263649
# bbox_head.cls_convs.1.conv_in: 0.020631471648812294
# bbox_head.cls_convs.2.conv_in: 0.00886712595820427
# bbox_head.cls_convs.3.conv_in: 0.009042492136359215
# bbox_head.reg_convs.0.conv_in: 0.04663718119263649
# bbox_head.reg_convs.1.conv_in: 0.012869743630290031
# bbox_head.reg_convs.2.conv_in: 0.0021227560937404633
# bbox_head.reg_convs.3.conv_in: 0.0005618667346425354
# bbox_head.retina_cls_in: 0.018579009920358658
# bbox_head.retina_reg_in: 0.00036240892950445414
# (LLML) root@Long:/workspace/whole_world/data/long.huang/code/Quant/qfod# bash tools/starter_scripts/retinanet_18/ptq/WminmaxAemamse/dist_retinanet_18_coco_w4a4.sh


# bbox_head.cls_convs.0.conv_in: 0.03284594044089317
# bbox_head.cls_convs.1.conv_in: 0.011952904053032398
# bbox_head.cls_convs.2.conv_in: 0.002810601843520999
# bbox_head.cls_convs.3.conv_in: 0.001239598379470408
# bbox_head.reg_convs.0.conv_in: 0.03284594044089317
# bbox_head.reg_convs.1.conv_in: 0.009230363182723522
# bbox_head.reg_convs.2.conv_in: 0.0015209878329187632
# bbox_head.reg_convs.3.conv_in: 0.00034472154220566154
# bbox_head.retina_cls_in: 0.001693324069492519
# bbox_head.retina_reg_in: 0.00015039966092444956
# (LLML) root@Long:/workspace/whole_world/data/long.huang/code/Quant/qfod# bash tools/starter_scripts/retinanet_18/ptq/WminmaxAemamse/dist_retinanet_18_coco_ori-qfod_w4a4.sh

ori_cls = [0.0466, 0.0206, 0.0088, 0.0090, 0.0185]  # ori cls
ori_reg = [0.0466, 0.0128, 0.0021, 0.0005, 0.0003]  # ori reg

oar_cls = [0.0328, 0.0119, 0.0028, 0.0012, 0.0016]  # qfod cls
oar_reg = [0.0328, 0.0092, 0.0015, 0.0003, 0.0001] # qfod reg


# Reti50-------------------
# bbox_head.cls_convs.0.conv_in: 0.03191138058900833
# bbox_head.cls_convs.1.conv_in: 0.012981761246919632
# bbox_head.cls_convs.2.conv_in: 0.006949437782168388
# bbox_head.cls_convs.3.conv_in: 0.008954416029155254
# bbox_head.reg_convs.0.conv_in: 0.03191138058900833
# bbox_head.reg_convs.1.conv_in: 0.0077012027613818645
# bbox_head.reg_convs.2.conv_in: 0.0013646328588947654
# bbox_head.reg_convs.3.conv_in: 0.00038771095569245517
# bbox_head.retina_cls_in: 0.015640918165445328
# bbox_head.retina_reg_in: 0.00022359738068189472
# ori

# bbox_head.cls_convs.0.conv_in: 0.015987757593393326
# bbox_head.cls_convs.1.conv_in: 0.0054760887287557125
# bbox_head.cls_convs.2.conv_in: 0.0016652521444484591
# bbox_head.cls_convs.3.conv_in: 0.0009444911265745759
# bbox_head.reg_convs.0.conv_in: 0.015987757593393326
# bbox_head.reg_convs.1.conv_in: 0.004368944559246302
# bbox_head.reg_convs.2.conv_in: 0.0009216426406055689
# bbox_head.reg_convs.3.conv_in: 0.00026059147785417736
# bbox_head.retina_cls_in: 0.0014502726262435317
# bbox_head.retina_reg_in: 0.00013453038991428912
# (LLML) root@Long:/workspace/whole_world/data/long.huang/code/Quant/qfod# bash tools/starter_scripts/retinanet_50/ptq/WminmaxAemamse/dist_retinanet_50_coco_ori-qfod_w4a4.sh


ori_cls = [0.0319, 0.0129, 0.0069, 0.0089, 0.0156]  # ori cls
ori_reg = [0.0319, 0.0077, 0.0014, 0.0004, 0.0002]  # ori reg

oar_cls = [0.016, 0.0055, 0.0017, 0.001, 0.0015]  # qfod cls
oar_reg = [0.016, 0.0044, 0.0009, 0.0003, 0.0001] # qfod reg


# ATSS50-------------------
# bbox_head.cls_convs.0.conv_in: 0.010429007932543755
# bbox_head.cls_convs.1.conv_in: 0.014738352969288826
# bbox_head.cls_convs.2.conv_in: 0.014086193405091763
# bbox_head.cls_convs.3.conv_in: 0.012620160356163979
# bbox_head.reg_convs.0.conv_in: 0.010429007932543755
# bbox_head.reg_convs.1.conv_in: 0.01544996164739132
# bbox_head.reg_convs.2.conv_in: 0.011938123032450676
# bbox_head.reg_convs.3.conv_in: 0.014060654677450657
# bbox_head.atss_cls_in: 0.006033141165971756
# bbox_head.atss_reg_in: 0.011044262908399105
# bbox_head.atss_centerness_in: 0.011044262908399105
# (LLML) root@Long:/workspace/whole_world/data/long.huang/code/Quant/qfod# bash tools/starter_scripts/atss_50/ptq/WminmaxAemamse/dist_atss_50_coco_w4a4.sh

ori_cls = [0.0104, 0.0147, 0.0141, 0.0126, 0.0060]  # ori cls
ori_reg = [0.0104, 0.0154, 0.0119, 0.0141, 0.0110]  # ori reg

oar_cls = [0.0105, 0.018, 0.0170, 0.0148, 0.0062]  # qfod cls
oar_reg = [0.0105, 0.023, 0.0171, 0.0198, 0.0190] # qfod reg

# bbox_head.cls_convs.0.conv_in: 0.010466006584465504
# bbox_head.cls_convs.1.conv_in: 0.017970850691199303
# bbox_head.cls_convs.2.conv_in: 0.017000021412968636
# bbox_head.cls_convs.3.conv_in: 0.0147849814966321
# bbox_head.reg_convs.0.conv_in: 0.010466006584465504
# bbox_head.reg_convs.1.conv_in: 0.022960616275668144
# bbox_head.reg_convs.2.conv_in: 0.017115483060479164
# bbox_head.reg_convs.3.conv_in: 0.019762886688113213
# bbox_head.atss_cls_in: 0.006954263895750046
# bbox_head.atss_reg_in: 0.01902802661061287
# bbox_head.atss_centerness_in: 0.01902802661061287
# (LLML) root@Long:/workspace/whole_world/data/long.huang/code/Quant/qfod# bash tools/starter_scripts/atss_50/ptq/WminmaxAemamse/dist_atss_50_coco_ori-qfod_w4a4.sh





# 绘制四条折线
plt.plot(
    x, 
    ori_cls, 
    marker='^',
    markersize=10,
    color='#F27970',
    alpha=0.7
    )
plt.plot(
    x, 
    ori_reg, 
    marker='v',
    markersize=10,
    color='#F27970',
    alpha=0.7
    )
plt.plot(
    x, 
    oar_cls, 
    marker='^',
    markersize=10,
    color='#2878B5',
    alpha=0.7
    )
plt.plot(
    x, 
    oar_reg, 
    marker='v',
    markersize=10,
    color='#2878B5',
    alpha=0.7
    )

# 设置 X 轴刻度为整数
plt.xticks(np.arange(min(x), max(x) + 1, 1), fontsize=20)
# 显示图例
plt.xlim(-0.2 + 1, 5 + 0.2)
plt.ylabel('Quant Error', fontsize=20)
plt.xlabel('Layer Depth', fontsize=20)
plt.xticks(fontsize=20)  # 设置X轴刻度标签的字体大小为14
plt.yticks(fontsize=20)  # 设置Y轴刻度标签的字体大小为14
import numpy as np
# plt.gca().set_xticks(np.arange(1, base_cord + 1, 2))
legend_elements = [
    Line2D([0], [0], color='#F27970', lw=3, label='Baseline'),
    Line2D([0], [0], color='#2878B5', lw=3, label='OAR (Ours)'),
    Line2D([0], [0], marker='^', color='w', markerfacecolor='black', markersize=11, label='Cls Branch'),
    Line2D([0], [0], marker='v', color='w', markerfacecolor='black', markersize=11, label='Reg Branch')
]
plt.legend(handles=legend_elements, loc='upper right', fontsize=14, framealpha=0.45)

plt.grid(axis='y')
# 显示图形
plt.show()
plt.savefig('y_function_vis/tmp9.pdf')