답변완료
[2014/0515] 예스스팟 기능추가
안녕하세요
예스스탁입니다.
예스스팟의 기능이 추가되어 알려드립니다.
1. 그리드 객체 추가
스크립트 객체화면에서 그리드 객체가 추가되었습니다.
그리드를 추가해 각 셀 혹은 행, 열에 값을 적거나 가져와서 수식에서 이용하실 수 있습니다.
2. 옵션객체 메써드 오버로딩 기능추가
수식을 좀더 간편하게 작성하실수 있도록 옵션객체의 함수 오버로딩 기능을 추가했습니다.
기존 옵션객체의 함수가 특정값을 불러올때
ATM단계로 지정하거나 종목코드로 지정해서 불러오는 함수 2개로 제공이 되고 있었습니다.
하나의 함수를 이용해 값을 불러와 사용할수 있게 변경이 되었습니다.
예)
GetAskAmount(nCallPut, nATMLevel, nAskLevel)
GetAskAmountByCode(sItemCode, nAskLevel)
--> GetAskAmount 함수 하나로 2가지 상황 모두 지정가능
GetAskAmount(nCallPut, nATMLevel, nAskLevel)
GetAskAmount(sItemCode, nAskLevel)
옵션객체의 리스트에는 기존 사용하시던 ByCode함수가 없지만
수식내에서는 ByCode함수도 그대로 사용하실 수 있습니다.
3. 옵션객체에 GetBasePrice, GetLimitDn, GetLimitUp 함수 추가
옵션객체에 함수가 추가되었습니다.
기준가를 리턴
GetBasePrice(nCallPut, nATMLevel)
GetBasePrice(sItemCode)
상한가를 리턴
GetLimitDn(nCallPut, nATMLevel)
GetLimitDn(sItemCode)
하한가를 리턴
GetLimitUp(nCallPut, nATMLevel)
GetLimitUp(sItemCode)
4. 외부입력변수를 전략 실행 중에 설정창에서 변경하면 변경된 값으로 실행이 되게 수정했습니다.
도움말에는 다음주에 설명이 추가될 예정입니다.감사합니다.
즐거운 하루되세요
2014-05-15
367
글번호 222977
답변완료
문의 드립니다.
항상 친절하시고 상세하신 답변 감사드립니다.
수식작성 Q&A 36191 글(아래에 복사해 넣었습니다)에 답해 주신 내용과 관련하여 문의드리고자 합니다.
1.
예스글로벌에서 가령 원유와 브라질상품(보베스파 등) 이렇게 두 품목을 거래할 경우,
원유는 일반해외선물용 계좌(00000-00-001)로,
브라질상품은 브라질상품용 계좌(00000-00-002)로 거래하도록 되어 있습니다.
두 품목을 동시에 거래하는 경우, Account1은 001계좌, Account2는 002계좌로 하고 싶은데, 그럴 경우 아래 식은 어떻게 수정되어야 하는지요?
(계좌가 복수이면 계좌 관련해서도 배열과 loop를 사용해야 할 것 같습니다만...)
2.
아래 식은 여러 품목을 매매하는 경우를 위한 것이라서 종목객체들을 구하기 위해 배열을 이용하여 loop를 돌리는 식입니다만,
만일 가장 간단하게,
"단 한 품목만 매매"할 때에는 아래 식을 어떻게 단순화해서 사용할 수 있을지 부탁드립니다.
감사합니다!
아래: 수식작성 Q&A 36191 글 답글 내용:
var Nth = 0;
var ItemCode = [];
var ItemObject = [];
var ItemHigh = [];
var Bnum;
function Main_OnStart()
{
Nth = 0;
Bnum = Account1.GetTheNumberOfBalances()
Main.MessageList("잔고종목수",Bnum);
if (Bnum > 0)
{
Account1.SetBalanceIndex(Nth);//잔고는 순번이 0부터 시작
//셋팅된 잔고의 수량이 0이상이면
if (Account1.Balance.count > 0)
{
//1번째 종목객체 생성요청
Main.ReqMarketData(Account1.Balance.code, 0,0);
//ItemCode의 [Nth]번째 방에 종목코드 저장
ItemCode[Nth] = Account1.Balance.code;
Main.MessageList("종목객체요청",Account1.Balance.code);
}
}
}
//요청한 종목객체 수신되면
function Main_OnRcvMarketData(MarketData)
{
Main.MessageList("종목객체수신",MarketData.code);
//수신받은 종목객체의 종목코드와 직전에 요청한 종목과 같은지 확인 후에
if (MarketData.code == ItemCode[Nth])
{
ItemObject[Nth] = MarketData;//ItemObject의 [Nth]방에 수신받은 객체를 저장
ItemHigh[Nth] = 0; //ItemHigh의 [Nth]방의 값을 0으로 셋팅 (이후 최고값 계산해 저장할 변수)
Main.MessageList(Nth,"번째","종목객체생성완료 : ",ItemObject[Nth].code);
//순번은 1 증가
Nth = Nth+1;
//종목객체 수신완료되면 다음 종목 종목객체 요청
if (Bnum > 0)
{
//계좌의 잔고리스트에서 다음 순번 잔고 셋팅
Account1.SetBalanceIndex(Nth);
//셋팅된 잔고의 수량이 0이상이면
if (Account1.Balance.count > 0)
{
//Nth번째 종목객체 생성요청
Main.ReqMarketData(Account1.Balance.code, 0,0);
//ItemCode의 [Nth]번째 방에 종목코드 저장
ItemCode[Nth] = Account1.Balance.code;
Main.MessageList("종목객체요청",Account1.Balance.code);
}
}
}
}
//종목객체 시세 업데이트
function Main_OnUp*dateMarket(sItemCode, lUp*dateID)//*삭제
{
if (Nth == Bnum-1)
{
//편입된 종목수 만킄만 수행
for (var i = 0; i <= Nth; i++)
{
if (ItemObject[i].code == sItemCode && lUp*dateID == 20001)//*삭제
{
Main.MessageList("-----------------------------------------------");
Main.MessageList(ItemObject[i].code,"업데이트");
//잔고셋팅
Account1.SetBalanceItem(ItemObject[i].code,0);
//종목편입 이후의 최고가 계산
if (ItemObject[i].current > ItemHigh[i])
{
ItemHigh[i] = ItemObject[i].current;
}
//매수잔고
if (Account1.Balance.position == 2)
{
//현재가가 평균단가 대비 +1이상 수익나면 청산
if (ItemObject[i].current >= Account1.Balance.avgUnitCost+1)
{
Account1.OrderSell(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("수익청산 : ",ItemObject[i].code,"종목객체삭제");
}
// 현재가가 평균단가 대비 1이상 손실나하면 청산
if (ItemObject[i].current <= Account1.Balance.avgUnitCost-1)
{
Account1.OrderSell(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("손절청산 : ",ItemObject[i].code,"종목객체삭제");
}
//현재가가 평균단가 0.7포인트 이상 수익후 +0.5 수익 하락하면 청산
if (ItemHigh[i] >= Account1.Balance.avgUnitCost*1.08 &&
ItemObject[i].current <= Account1.Balance.avgUnitCost*1.05)
{
Account1.OrderSell(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("TR청산 : ",ItemObject[i].code,"종목객체삭제");
}
}
//매도잔고
if (Account1.Balance.position == 1)
{
//현재가가 평균단가 대비1포인트이상 수익나면 청산
if (ItemObject[i].current <= Account1.Balance.avgUnitCost-1)
{
Account1.OrderBuy(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("수익청산 : ",ItemObject[i].code,"종목객체삭제");
}
// 현재가가 평균단가 대비 1이상 손실나면 청산
if (ItemObject[i].current >= Account1.Balance.avgUnitCost+1)
{
Account1.OrderBuy(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("손절청산 : ",ItemObject[i].code,"종목객체삭제");
}
//현재가가 평균단가 대비 0.7포인트 이상 수익 후 0.5까지 수익이 감소하면 청산
if (ItemHigh[i] <= Account1.Balance.avgUnitCost-0.7 &&
ItemObject[i].current <= Account1.Balance.avgUnitCost-0.5)
{
Account1.OrderBuy(Account1.Balance.code,Account1.Balance.count, 0,1);
//주문 후 해당 종목객체 삭제
Main.RemoveMarketData(ItemObject[i]);
Main.MessageList("TR청산 : ",ItemObject[i].code,"종목객체삭제");
}
}
}
}
}
}
2014-05-14
870
글번호 222971