奇狐社區論壇
在這個頁面顯示本主題全部的 2 個文章

奇狐社區論壇 (http://www.chiefox.com.tw/bbs/index.php)
- 問題交流 (http://www.chiefox.com.tw/bbs/forumdisplay.php?forumid=28)
-- SETLBOUND無法縮短橫向統計時間 (http://www.chiefox.com.tw/bbs/showthread.php?threadid=14245)


由 chwqk 在 2010-09-05 02:20 發表:

SETLBOUND無法縮短橫向統計時間

參閱
http://www.chiefox.com.tw/bbs/showt...=&threadid=2625

採N=10
CC:C;
IF DATACOUNT>=N AND N>0 THEN xx:=SETLBOUND(CC,DATACOUNT-N+1);
券買張:LONDATA(7);
IF DATACOUNT>=N AND N>0 THEN xx:=SETLBOUND(券買張,DATACOUNT-N+1);
TT: 券買張*CC
橫向統計 ESTDATA('TT')

測試結果
ESTDATA('TT')在10日之前為"0"
10日之內才是 券買張*CC
所以還是所有數據都運算


由 cgjj 在 2010-09-06 09:31 發表:

回覆: SETLBOUND無法縮短橫向統計時間

引用:
最初由 chwqk 發表
參閱
http://www.chiefox.com.tw/bbs/showt...=&threadid=2625

採N=10
CC:C;
IF DATACOUNT>=N AND N>0 THEN xx:=SETLBOUND(CC,DATACOUNT-N+1);
券買張:LONDATA(7);
IF DATACOUNT>=N AND N>0 THEN xx:=SETLBOUND(券買張,DATACOUNT-N+1);
TT: 券買張*CC
橫向統計 ESTDATA('TT')

測試結果
ESTDATA('TT')在10日之前為"0"
10日之內才是 券買張*CC
所以還是所有數據都運算



並非所有數據都算唷, 您檢驗起點就知了
看結果不只10日的原因, 是在於
每個商品的最後10日, 未必都是相同的10日
故會多出個幾日是正常的(有的股票沒天天交易)

以您這例來說, 能改善的非常有限(只有那麼一點點效益,很難查覺)
因為被影響的計算式只有一行 ( 券買張*CC )
若計算式很多時, 差異就會較大

橫向統計花在資料載入的時間也會不少
硬碟快慢, 也會造成差異大
若硬碟要真要追求快, 可改用SSD固態硬碟


全部時間均為台灣時間, 現在時間為09:17
在這個頁面顯示本主題全部的 2 個文章


Powered by: vBulletin Version 2.3.0 - Copyright©2000-, Jelsoft Enterprises Limited.

簡愛洋行 製作 Copyright 2003-. All Rights Reserved.