如何使用GNOUPLOT绘制能量图 [英] How to plot energy diagram using gnuplot

查看:11
本文介绍了如何使用GNOUPLOT绘制能量图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有数据文件:

0 0 3 -0.17 6 -0.05
0 0 3 -0.23 6  0.90
0 0 3 -0.41 6  0.50
0 0 3 -0.50 6 -0.33
0 0 3 -0.20 6  0.80

我想绘制这样的图,它连接直线上的每个点。你能告诉我是怎么做到的吗?

推荐答案

以下建议使用with boxxyerrorwith vectorswith labels绘制样式。 零级别获取最后一个条目的颜色,因为所有内容都是在彼此的顶部绘制的。选择以下示例作为进一步调整的起点。

编码:

### energy diagram
reset session

$Data <<EOD
0 0 3 -0.17 6 -0.05   A_{one}
0 0 3 -0.23 6  0.90   B_{two}
0 0 3 -0.41 6  0.50   C_{three}
0 0 3 -0.50 6 -0.33   D_{four}
0 0 3 -0.20 6  0.80   E_{five}
EOD

set key noautotitle
set xrange [-1:8]

myWidth = 0.3

plot for [i=1:3] $Data u (column(2*i-1)):(column(i*2)):(myWidth):(0):0:xtic(i*2-1) w boxxy lw 3 lc var, 
     for [i=1:2] '' u (column(2*i-1)+myWidth):(column(i*2)): 
         (column(2*i+1)-column(2*i-1)-2*myWidth):(column(i*2+2)-column(i*2)):0 w vec nohead lw 1 dt 3 lc var, 
     '' u 5:6:7:0 w labels offset 6,0 tc var font ",16"
### end of code

结果:

添加:

来自您的评论:如果要关闭标高以使标签重叠,您可以添加单独的偏移量(此处在第8列)。 检查以下修改了数据的示例中的级别B和E是否非常接近。

编码:

### energy diagram with individual offset of labels
reset session

$Data <<EOD
0 0 3 -0.17 6 -0.05   A_{one}    0
0 0 3 -0.23 6  0.90   B_{two}    0.05
0 0 3 -0.41 6  0.50   C_{three}  0
0 0 3 -0.50 6 -0.33   D_{four}   0
0 0 3 -0.20 6  0.85   E_{five}  -0.05
EOD

set key noautotitle
set xrange [-1:8]
myWidth = 0.3

plot for [i=1:3] $Data u (column(2*i-1)):(column(i*2)):(myWidth):(0):0:xtic(i*2-1) w boxxy lw 3 lc var, 
     for [i=1:2] '' u (column(2*i-1)+myWidth):(column(i*2)): 
         (column(2*i+1)-column(2*i-1)-2*myWidth):(column(i*2+2)-column(i*2)):0 w vec nohead lw 1 dt 3 lc var, 
     '' u 5:($6+$8):7:0 w labels offset 6,0 tc var font ",16"
### end of code

结果:

这篇关于如何使用GNOUPLOT绘制能量图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆