2

実際の財務データのローソク足を扱っています。過去の財務データには十分にあるデータにギャップがない限り、うまく機能します。

私は「set boxwidth 1 relative」を持っていましたが、うまくいきました。ほとんどの場合、ろうそく足の適切な「幅」が得られます。しかし、2 点間にデータがない場合、ローソク足は太くなります。つまり、そのギャップを埋めるために右に伸びます。ビジュアルがひどい、右への伸びが本当に悪い。

set boxwidth x absolute で遊んでみましたが、表示方法がわかりません。私はそれを絞り込みましたがset boxwidth 37500 absolute、設定されたボックス幅1の相対よりもさらに悪い問題がありますが、その数が機能する理由がわかりません。

最初の画像は を使用した様子set boxwidth 37500 absoluteです。日付は 01/31/13、02/01/13、02/03/13、02/04/13、02/05/13 です。02/02/13 はありません:

ここに画像の説明を入力

絶対値は 02/01 と 02/02 の間の適切なギャップを示していますが、説明できない理由で 02/03 と 02/04 が重複しています。

2 番目のイメージでは、set boxwidth 1 相対を使用しています。これは、ほとんど私が望む方法です。ローソク足は隣接しており、ほとんどが右です。しかし、02/02/13 のギャップは右に太ります。02/09/13 にもギャップがあり、太くなっているか、どちらかの側の 2 つが伸びてギャップを埋めている可能性があります。

ここに画像の説明を入力

すべてのローソク足が同じ幅で隣接し、データのギャップが空になるように設定するにはどうすればよいですか?

私はこれを狂ったようにグーグルで検索しましたが、誰もそれについて話しません。私が見つけたローソク足のいくつかの例は、「日付」ではなく整数を使用しており、まったく価値がありません。ローソク足チャートには、マニュアルに従って日付が必要です。

Windows 7 で Gnuplot 4.6 パッチレベル 0 を実行しています。

ありがとうございました

PS: ここにデータを追加する必要がありました。

basic.csv:

2013-01-15 00:00:00,93.879000,93.949000,92.874000,93.078000
2013-01-16 00:00:00,93.079000,93.672000,92.458000,92.800000
2013-01-17 00:00:00,92.799000,95.011000,92.629000,94.616000
2013-01-18 00:00:00,94.617000,94.872000,94.157000,94.662000
2013-01-20 17:00:00,94.649000,94.820000,93.965000,94.155000
2013-01-21 00:00:00,94.159000,94.938000,93.726000,94.009000
2013-01-22 00:00:00,94.011000,94.284000,93.147000,93.231000
2013-01-23 00:00:00,93.229000,94.024000,92.793000,93.649000
2013-01-24 00:00:00,93.650000,94.715000,93.559000,94.489000
2013-01-25 00:00:00,94.490000,95.083000,94.472000,94.749000
2013-01-27 17:00:00,94.819000,95.007000,94.652000,94.834000
2013-01-28 00:00:00,94.835000,94.968000,94.082000,94.809000
2013-01-29 00:00:00,94.803000,95.330000,94.370000,95.248000
2013-01-30 00:00:00,95.245000,95.450000,94.255000,94.365000
2013-01-31 00:00:00,94.372000,95.799000,94.328000,95.714000
2013-02-01 00:00:00,95.715000,96.718000,95.457000,96.597000
2013-02-03 17:00:00,96.716000,96.777000,96.370000,96.572000
2013-02-04 00:00:00,96.574000,97.064000,95.968000,96.044000
2013-02-05 00:00:00,96.043000,97.426000,95.945000,97.131000
2013-02-06 00:00:00,97.133000,97.284000,96.092000,96.395000
2013-02-07 00:00:00,96.396000,97.023000,95.813000,96.145000
2013-02-08 00:00:00,96.146000,96.182000,95.124000,95.625000
2013-02-10 17:00:00,95.623000,95.744000,95.210000,95.339000
2013-02-11 00:00:00,95.336000,96.877000,95.168000,96.537000
2013-02-12 00:00:00,96.536000,96.719000,95.776000,96.214000
2013-02-13 00:00:00,96.216000,96.890000,96.114000,96.775000
2013-02-14 00:00:00,96.771000,96.964000,95.609000,95.621000
2013-02-15 00:00:00,95.622000,96.676000,95.521000,96.351000

absolute.plt:

reset

set border linecolor rgbcolor "yellow"
set key textcolor rgbcolor "white"

set obj 1 rectangle behind from screen 0,0 to screen 1,1
set obj 1 fillstyle solid 1.0 fillcolor rgbcolor "black"

set xdata time
set timefmt"%Y-%m-%d %H:%M:%S"
set xrange ["2013-01-15 00:00:00":"2013-02-15 23:59:59"]

set yrange [*:*]
set datafile separator ","

set palette defined (-1 'red', 1 'green')
set cbrange [-1:1]
unset colorbox

set style fill solid noborder
set boxwidth 37500 absolute

set title "AUDJPY" textcolor rgbcolor "white"
plot 'basic.csv' using 1:2:4:3:5:($5 < $2 ? -1 : 1) with candlesticks palette

relative.plt:

reset

set border linecolor rgbcolor "yellow"
set key textcolor rgbcolor "white"

set obj 1 rectangle behind from screen 0,0 to screen 1,1
set obj 1 fillstyle solid 1.0 fillcolor rgbcolor "black"

set xdata time
set timefmt"%Y-%m-%d %H:%M:%S"
set xrange ["2013-01-15 00:00:00":"2013-02-15 23:59:59"]

set yrange [*:*]
set datafile separator ","

set palette defined (-1 'red', 1 'green')
set cbrange [-1:1]
unset colorbox

set style fill solid noborder
set boxwidth 1 relative

set title "AUDJPY" textcolor rgbcolor "white"
plot 'basic.csv' using 1:2:4:3:5:($5 < $2 ? -1 : 1) with candlesticks palette
4

1 に答える 1

5

を使用する場合set boxwidth absolute、幅は x 軸の単位で指定されます。日付の場合は秒です。したがって、幅37500は 10 時間です。

また、6 列目に明示的な幅を使用し、-2 に切り替えて、特定の列の自動ボックス幅を取得することもできます。ただし、データ ファイルを手動で操作する必要があります。

別のポイント: 一部のデータ ポイントに時間を含めることは必須ですか? これは、いくつかの隣接するポイントの距離を狭めるものです。時間は無視できます。これにより、最短で 1 日のポイント距離が得られます。時間を削除するstrptimeには、usingステートメントで次を使用します。

reset

set border linecolor rgbcolor "yellow"
set key textcolor rgbcolor "white"

set obj 1 rectangle behind from screen 0,0 to screen 1,1
set obj 1 fillstyle solid 1.0 fillcolor rgbcolor "black"

set xdata time
set timefmt"%Y-%m-%d %H:%M:%S"
set xrange ["2013-01-15 00:00:00":"2013-02-15 23:59:59"]

set yrange [*:*]
set datafile separator ","

set palette defined (-1 'red', 1 'green')
set cbrange [-1:1]
unset colorbox

set style fill solid noborder
set boxwidth 60000 absolute

set title "AUDJPY" textcolor rgbcolor "white"
plot 'basic.csv' using (strptime('%Y-%m-%d', strcol(1))):2:4:3:5:($5 < $2 ? -1 : 1) with candlesticks palette

4.6.0 での結果:

ここに画像の説明を入力

于 2014-06-07T13:05:11.110 に答える