gpt4 book ai didi

gnuplot - 如何在 gnuplot 中设置统计功能的范围?

转载 作者:行者123 更新时间:2023-12-04 14:49:17 25 4
gpt4 key购买 nike

我有如下所示的时间序列数据,我想绘制所有数据,即特定范围的平均值,例如3、6 或 9 个月。

    Time           T      D      T/D
8/1/2021 1785.28 23.99 74.42
7/1/2021 1807.84 25.68 70.40
6/1/2021 1834.57 27 67.95
5/1/2021 1850.26 27.5 67.28
4/1/2021 1760.04 25.69 68.51
3/1/2021 1718.23 25.65 66.99
2/1/2021 1808.17 27.29 66.26
1/1/2021 1866.98 25.88 72.14
12/1/2020 1858.42 24.97 74.43
11/1/2020 1866.3 24.08 77.50
10/1/2020 1900.27 24.23 78.43
9/1/2020 1921.92 25.74 74.67
8/1/2020 1968.63 27 72.91

我正在使用 gnuplot 5.2,我尝试使用以下代码进行绘图,但似乎统计数据没有按预期工作。

  # plot data vs date 

reset session

FILE = "data_01.dat"

set timefmt "%m/%d/%Y"
stats ["8/1/2020":"1/1/2021"] FILE u 4 name "A"
stats ["8/1/2020":"8/1/2021"] FILE u 4 name "B"

set label 1 sprintf("6 months average= %.2f",A_mean) at graph 0.02, graph 0.95
set label 2 sprintf("12 months average= %.2f",B_mean) at graph 0.02, graph 0.90

set xdata time
set format x "%m/%y"
set xrange ["8/1/2020":"8/1/2021"]

plot FILE u 1:4 skip 1 w lp lc rgb 'blue' t 'data' ,\
A_mean lc rgb 'black' t '6 months avg',\
B_mean lc rgb 'red' t '12 months avg'

# end of code

我得到的输出是这样的: data_plot

我认为我在设置统计限制时犯了一个错误,这使得统计计算列中整个数据的平均值,而不是在特定范围内计算它。但我找不到如何修复它。起初我尝试使用这个

stats ["8/1/2020":"1/1/2021"] FILE u (timecolumn(1)):4 name "A"

但它没有给我任何输出并以:“undefined variable: A_mean”结尾。如何在 gnuplot 中正确设置统计功能的范围?

最佳答案

基本上,Eldrad 已经提到了所有要点......当我还在编码......

stats 不适用于时间数据,即 set xdata time。此外,如果您想限制第一个日期列,您还必须在 stats 中使用第 1 列。检查将给出合理结果的修改后的代码。

编辑:除了多次使用 strptime(myTimeFmt,"8/1/2020") 您还可以定义一个函数 myTime(s) = strptime(myTimeFmt,s) 缩短一切都有点,不要让它看起来那么“可怕”。

代码:

# plot data vs date and using stats 
reset session

$Data <<EOD
Time T D T/D
8/1/2021 1785.28 23.99 74.42
7/1/2021 1807.84 25.68 70.40
6/1/2021 1834.57 27 67.95
5/1/2021 1850.26 27.5 67.28
4/1/2021 1760.04 25.69 68.51
3/1/2021 1718.23 25.65 66.99
2/1/2021 1808.17 27.29 66.26
1/1/2021 1866.98 25.88 72.14
12/1/2020 1858.42 24.97 74.43
11/1/2020 1866.3 24.08 77.50
10/1/2020 1900.27 24.23 78.43
9/1/2020 1921.92 25.74 74.67
8/1/2020 1968.63 27 72.91
EOD

myTimeFmt = "%m/%d/%Y"
set timefmt myTimeFmt
myTime(s) = strptime(myTimeFmt,s)

stats [myTime("8/1/2020"):myTime("1/1/2021")] $Data u (timecolumn(1)):4 name "A" nooutput
stats [myTime("8/1/2020"):myTime("8/1/2021")] $Data u (timecolumn(1)):4 name "B" nooutput

set label 1 sprintf("6 months average= %.2f",A_mean_y) at graph 0.02, graph 0.95
set label 2 sprintf("12 months average= %.2f",B_mean_y) at graph 0.02, graph 0.90

set format x "%m/%y" time
set xrange [myTime("8/1/2020"):myTime("8/1/2021")]

plot $Data u (timecolumn(1)):4 skip 1 w lp lc rgb 'blue' t 'data' ,\
A_mean_y lc rgb 'black' t '6 months avg',\
B_mean_y lc rgb 'red' t '12 months avg'
### end of code

结果:

enter image description here

关于gnuplot - 如何在 gnuplot 中设置统计功能的范围?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69324219/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com