답변완료
체결확인을 하고싶습니다.
예를 들어 선물 신호기준 콜옵션 1.0에 가장 가까운 종목을 매수했을때. 가격이 올라 만약 2.5 가 되었을때 청산 신호가 뜬다면 예스스탁님이 올려주신 아래식을 적용한다면 매수는 a라는 종목에 나가고 청산은 b라는 종목에 나갈꺼 같습니다... 맞는지요..
그래서 아래처럼.OnNotifyFill 을 사용해서 체결유무를 확인하고 체결되었다면 checkbuycallcode 변수에 CallOrderCode 를 넣은후...청산 신호가 발생시 ...
Main.OrderSell(a1.number, CallOrderCode, 1, Option.GetAskByCode(checkbuycallcode, 2), 0);
이렇게 청산되게 했습니다... 근데 메시지 로그에 checkbuycallcode 값이 안나오네요
수정 및 설명부탁드립니다.
var CPrice = new Array(101);
var CCode = new Array(101);
var PPrice = new Array(101);
var PCode = new Array(101);
var MaxCall;
var MaxCallCode;
var MaxPut;
var MaxPutCode;
var checkbuycallcode;
function c1_OnRiseSignal(Signal)
{
//ATM 위 행사가 갯수
UNum = Option.uppersATM;
//ATM 위 행사가 갯수
LNum = Option.lowersATM;
//배열변수 준비(가격, 종목코드)
CallCode = new Array(UNum+LNum+1);
PutCode = new Array(UNum+LNum+1);
CallPrice = new Array(UNum+LNum+1);
PutPrice = new Array(UNum+LNum+1);
//3.0이하의 가격을 가지는 콜종목은 해당 값과 종목코드 저장
//3.0을 초과하는 콜종목은 가격과 종목코드를 모두 -1 처리
for (var i = -LNum; i <= UNum; i++)
{
if (Option.GetCurrent(0, i) <= money)
{
CallPrice[i+LNum] = Option.GetCurrent(0, i);
CallCode[i+LNum] = Option.GetATMCallRecent(i);
}
else
{
CallPrice[i+LNum] = -1;
CallCode[i+LNum] = -1;
}
Main.MessageLog(i+"콜종목코드:"+CallCode[i+LNum]+"/가격:"+CallPrice[i+LNum]);
}
//3.0이하의 가격을 가지는 풋종목은 해당 값과 종목코드 저장
//3.0을 초과하는 풋종목은 가격과 종목코드를 모두 -1 처리
for (var ii = -UNum; ii <= LNum; ii++)
{
if (Option.GetCurrent(1, ii) <= 1.0 )
{
PutPrice[ii+UNum] = Option.GetCurrent(1, ii);
PutCode[ii+UNum] = Option.GetATMPutRecent(ii);
}
else
{
PutPrice[ii+UNum] = -1;
PutCode[ii+UNum] = -1;
}
// Main.MessageLog(ii+"풋종목코드:"+PutCode[ii+UNum]+"/가격:"+PutPrice[ii+UNum]);
}
//각 배열에 저장된 값중 가장 큰 값을 찾음
var CC = -1;
var CallOrderCode = -1;
for (var iii = -LNum; iii <= UNum; iii++)
{
if (CallPrice[iii+LNum] > CC)
{
CC = CallPrice[iii+LNum];
CallOrderCode = CallCode[iii+LNum]
}
}
var PP = -1;
var PutOrderCode = -1;
for (var iiii = -UNum; iiii <= LNum; iiii++)
{
if (PutPrice[iiii+UNum] > PP)
{
PP = PutPrice[iiii+UNum];
PutOrderCode = PutCode[iiii+UNum];
}
}
Main.MessageLog("--------------------------------------------");
Main.MessageLog("콜주문종목코드:"+CallOrderCode+"/가격:"+CC);
// Main.MessageLog("풋주문종목코드:"+PutOrderCode+"/가격:"+PP);
if (Signal.signalKind == 1)// ----------->A 여기서부터 수정했습니다.
{
Main.OrderBuy(a1.number, CallOrderCode, 1, Option.GetAskByCode(CallOrderCode, 2), 0);
}
if (Signal.signalKind == 2)
{
Main.OrderSell(a1.number, CallOrderCode, 1, Option.GetBidByCode(CallOrderCode, 2), 0);
}
}
//그래서 A 에서 아래와 같이 수정했지만 메시지로그 에서는값이 나오지 않네요.
if (Signal.signalKind == 1)// -------> 이렇게요.
{
Main.OrderBuy(a1.number, CallOrderCode, 1, Option.GetAskByCode(CallOrderCode, 2), 0);
function Main_OnNotifyFill(NotifyFill)
{
if (NotifyFill == 2)
{
checkbuycallcode = CallOrderCode;
}
}
}
Main.MessageLog("call주문종목코드:"+checkbuycallcode);
if (Signal.signalKind == 2)
{
Main.OrderSell(a1.number, checkbuycallcode, 1, Option.GetAskByCode(checkbuycallcode, 2), 0);
2013-01-07
2529
글번호 221923
답변완료
[파워종목검색] 구버전과 신버전 결과가 다름
다음과 같은 동일한 검색식을 장종료후에 구버전과 신버전에서 실행했을때,
검색 결과값이 다르게 나오며 구버전 결과가 맞는 것으로 보입니다.
확인 부탁 드립니다.
Input : BB80Period(80), BB240Period(240), D(2);
Variable : BB80up(0), BB240up(0);
BB80up = BollBandUp(BB80Period,D);
BB240up = BollBandUp(BB240Period,D);
If (BB80up > BB240up) and
(CountIF(C > BB80up, 5) >= 4) and (C < BB80up*1.05 and C > BB80up*0.97 and C > BB240up) Then
{
Find(1);
}
2013-01-04
2332
글번호 221916
답변완료
스팟 주문오류입니다,.
예스트레이더 로는 시스템 매매가 가능한 상태입니다.
하지만 예스스팟으로 주문할시 증거금 부족으로 나옵니다..
왜그런가요.
.
<오류메시지>
[cd_ord_normal]부족액 위탁:16801980, 현금:16801980: sqlnum 20003
매수<0000-0000-00> 종목:KR4201H12703 수량:1 가격:0.00 주문유형 : 시장가
<적용 수식>
선물챠트 객체에서 신호를 받아와서 atm 옵션 가격중 1보다 작고 가장 근접한 옵션 을 매수 청산 하는 식을 시험 하려고 스팟 자동 매매로 돌려보니... 증거금 부족메시지가 나옵니다
현재 증거금은 2백 정도만 들어가 있는 상태로.. 미결제 계약을 항상 1개 를 남겨 두기에 .. 시스템 매매 거래 가능한 상태입니다.메시지를 분석해 보니.. 옵션 종목으로 매매가 이루어지는 것은 맞는거 같은데.. 증거금 부족 때문인지 아니면.... 다른 이유가 있는것이인지 알려주세요.
<수식내용>
var CPrice = new Array(101);
var CCode = new Array(101);
var PPrice = new Array(101);
var PCode = new Array(101);
var MaxCall;
var MaxCallCode;
var MaxPut;
var MaxPutCode;
function c1_OnRiseSignal(Signal)
{
//ATM 위 행사가 갯수
UNum = Option.uppersATM;
//ATM 위 행사가 갯수
LNum = Option.lowersATM;
//배열변수 준비(가격, 종목코드)
CallCode = new Array(UNum+LNum+1);
PutCode = new Array(UNum+LNum+1);
CallPrice = new Array(UNum+LNum+1);
PutPrice = new Array(UNum+LNum+1);
//3.0이하의 가격을 가지는 콜종목은 해당 값과 종목코드 저장
//3.0을 초과하는 콜종목은 가격과 종목코드를 모두 -1 처리
for (var i = -LNum; i <= UNum; i++)
{
if (Option.GetCurrent(0, i) <= 1.0)
{
CallPrice[i+LNum] = Option.GetCurrent(0, i);
CallCode[i+LNum] = Option.GetATMCallRecent(i);
}
else
{
CallPrice[i+LNum] = -1;
CallCode[i+LNum] = -1;
}
Main.MessageLog(i+"콜종목코드:"+CallCode[i+LNum]+"/가격:"+CallPrice[i+LNum]);
}
//3.0이하의 가격을 가지는 풋종목은 해당 값과 종목코드 저장
//3.0을 초과하는 풋종목은 가격과 종목코드를 모두 -1 처리
for (var ii = -UNum; ii <= LNum; ii++)
{
if (Option.GetCurrent(1, ii) <= 3.0 )
{
PutPrice[ii+UNum] = Option.GetCurrent(1, ii);
PutCode[ii+UNum] = Option.GetATMPutRecent(ii);
}
else
{
PutPrice[ii+UNum] = -1;
PutCode[ii+UNum] = -1;
}
Main.MessageLog(ii+"풋종목코드:"+PutCode[ii+UNum]+"/가격:"+PutPrice[ii+UNum]);
}
//각 배열에 저장된 값중 가장 큰 값을 찾음
var CC = -1;
var CallOrderCode = -1;
for (var iii = -LNum; iii <= UNum; iii++)
{
if (CallPrice[iii+LNum] > CC)
{
CC = CallPrice[iii+LNum];
CallOrderCode = CallCode[iii+LNum]
}
}
var PP = -1;
var PutOrderCode = -1;
for (var iiii = -UNum; iiii <= LNum; iiii++)
{
if (PutPrice[iiii+UNum] > PP)
{
PP = PutPrice[iiii+UNum];
PutOrderCode = PutCode[iiii+UNum];
}
}
Main.MessageLog("--------------------------------------------");
Main.MessageLog("콜주문종목코드:"+CallOrderCode+"/가격:"+CC);
Main.MessageLog("풋주문종목코드:"+PutOrderCode+"/가격:"+PP);
if (Signal.signalKind == 1)
{
Main.OrderBuy(a1.number, CallOrderCode, 1, 0, 1);
}
if (Signal.signalKind == 2)
{
Main.OrderSell(a1.number, CallOrderCode, 1, 0, 1);
}
}
2013-01-04
2582
글번호 221908
답변완료
다음 내용 확인 부탁드립니다.
안녕하세요~
YesSpot관련 다음 내용 확인 부탁드리겠습니다.
1) 동일계좌에 정정,취소주문 Spot시스템 A와 B가 적용되었을 때,
--> 정정, 취소가 A와 B 각각에 대하여 다른 orderNum이 생성되어
별개로 작동되는지요?
(A와 B 모두 id와 idNum의 변수명이 같은 상태임)
--> 이때 만약 장마감동시호가에서 미체결 잔량 전체에 대한 청산 Spot시스템을
적용하면, 이경우는 A와 B 시스템과 상관없이 해당계좌에 남아있는
미체결 잔량 전체에 대하여 청산이 이루어지는지요?
즉 Spot system이 몇개 적용되었건 해당계좌 전체 잔량에 대하여 청산되는지요?
2) OrderReplacePrice 또는 OrderCancel 함수를 사용하였을 때,
앞서 일부 체결이 있다면 미체결 수량에 대하여만 정정 또는 취소가 발생하는지요?
3) 2)와 관련하여 외부변수로 수량을 1계약으로 지정하였을 때,
정확성을 위하여 OrderReplacePrice 함수보다 OrderReplace 함수를 사용하는 것이
더 좋은지요?
이상입니다.
그럼 즐거운 주말되시기 바랍니다.
감사합니다 !!!
2013-01-04
2300
글번호 221906