我正在尝试使用如下所示的文件中的数据制作直方图:
#Column 1 Column 2
#
0.0300 0.2126
1.0000e-4 0.0104
6.0000e-3 0.1299
1.0000e-4 8.0600e-3
1.0000e-4 0.0105
0.0190 0.2204
6.0000e-3 7.4900e-3
1.0000e-4 0.0952
6.0000e-3 7.4200e-3
1.0000e-4 0.0131
0.0190 0.3062
0.0190 0.2561
0.0300 0.9748
0.0300 0.9406
0.0300 0.0139
1.0000e-4 0.0281
0.0300 0.3625
1.0000e-4 0.0945
0.0300 0.5650
1.0000e-4 0.1045
6.0000e-3 0.2362
1.0000e-4 0.0180
1.0000e-4 0.1366
1.0000e-4 0.0195
0.0300 0.4652
0.0190 0.3505
0.0300 0.5146
0.0190 0.4319
6.0000e-3 0.2054
6.0000e-3 0.2377
0.0300 0.5281
1.0000e-4 0.1128
6.0000e-3 0.0623
如果我使用代码:
n=20 #number of intervals
max=0.03 #max value
min=0 #min value
width=(max-min)/n #interval width
hist(x,width)=width*floor(x/width)+width/2.0
plot 'data' u (hist(\$1,width)):(1.0) smooth freq w boxes lc rgb "blue" lt 1 lw 0.5 notitle
我得到了正确的直方图:
但如果我使用条件行:
plot 'data' u (hist((\$2<=0.5?\$1:1/0),width)):(1.0) smooth freq w boxes lc rgb "blue" lt 1 lw 0.5 notitle
我明白了:
您可以看到gnuplot
未正确添加行,而是将它们绘制为单独的列。
有什么方法可以解决这个问题吗?谢谢!
答案 0 :(得分:3)
我怀疑这是gnuplot如何处理“丢失”数据的症状。关于缺失数据,以下实际上略有不同:
plot 'data' u 1:2 w lines #connects lines across missing records
plot 'data' u 1:($2) w lines #doesn't connect lines when a missing record is encountered
我怀疑你看到这个设计决定的症状略有不同。
不幸的是,这使得典型的gnuplot数据过滤器在这里无用:-(。幸运的是,你的病情很容易进入awk
:
plot "< awk '{if ($2 <= 0.5) {print $0}}' test.dat " u (hist($1,width)):(1.0) smooth freq w boxes lc rgb "blue" lt 1 lw 0.5 notitle
现在gnuplot只能看到你想要它的数据(因为它没有看到任何NaN值,所以它不会创建任何新的计数器)。