- 사각형
- 특정 바 수의 K선 앞 고점, 하점 및 데모 프로그램을 찾는 방법
특정 바 수의 K선 앞 고점, 하점 및 데모 프로그램을 찾는 방법
저자:
발명가들의 수량화 - 작은 꿈, 날짜: 2017-10-28 15:16:43
태그:
연구
function FindLastHighestPoint(Records, NumOfBars){
var RecordsLen = Records.length
if(RecordsLen < 2){
return false
}
if(typeof(NumOfBars) == "undefined"){
NumOfBars = 0
}
var highPrice = TA.Highest(Records, NumOfBars, "High")
// find the bar
var bar = null
for(var i = 0; i < RecordsLen; i++){
if(Records[i].High == highPrice){
bar = {}
bar.record = Records[i]
bar.index = i
bar.range = NumOfBars
break
}
}
// compare current bar
if(bar && Records[RecordsLen - 1].High >= bar.record.High){
bar.record = Records[RecordsLen - 1]
bar.index = RecordsLen - 1
bar.range = NumOfBars
}
if(!bar || !Records[bar.index - 1]){
return false
}
return bar
}
function FindLastLowestPoint(Records, NumOfBars){
var RecordsLen = Records.length
if(RecordsLen < 2){
return false
}
if(typeof(NumOfBars) == "undefined"){
NumOfBars = 0
}
var lowPrice = TA.Lowest(Records, NumOfBars, "Low")
// find the bar
var bar = null
for(var i = 0; i < RecordsLen; i++){
if(Records[i].Low == lowPrice){
bar = {}
bar.record = Records[i]
bar.index = i
bar.range = NumOfBars
break
}
}
// compare current bar
if(bar && Records[RecordsLen - 1].Low <= bar.record.Low){
bar.record = Records[RecordsLen - 1]
bar.index = RecordsLen - 1
bar.range = NumOfBars
}
if(!bar || !Records[bar.index - 1]){
return false
}
return bar
}
function main(){
LogReset(1)
var chart_obj = Chart({})
chart_obj.reset()
while(true){
var records = exchange.GetRecords()
if(!records){
continue
}
var bar = FindLastHighestPoint(records)
var bar2 = FindLastLowestPoint(records)
$.PlotRecords(records)
if(bar){
$.PlotHLine(bar.record.High, "高点", "red")
}else{
Log("K线数据不足,最高点为初始K线bar!")
}
if(bar2){
$.PlotHLine(bar2.record.Low, "低点", "green")
}else{
Log("K线数据不足,最低点为初始K线bar!")
}
LogStatus(_D(), '\n', bar, '\n', bar2)
Sleep(1000)
}
}
관련
더 많은