예스스탁
예스스탁 답변
2021-07-23 11:29:41
안녕하세요
예스스탁입니다.
MarketPosition은 현재봉의 포지션 상태를 알려주는 함수입니다.
현재봉이 무포지션이면 0, 매수포지션이면 1, 매도포지션이면 -1을 리턴합니다.
진입을 무포지션에서만 해야 하므로 MarketPosition == 0 조건을 매수진입식에 넣어주시면 됩니다.
IF MarketPosition == 0 and
(A1 or A2 or A3 or A4 or A5 or A6 or A7 or A8 or A9 or A10 or A11 or A12 or A13 or A14 or A15 or
A16 or A17 or A18 or A19 or A20 or A21 or A22 or A23 or A24 or A25 or A26 or A27 or A28 or
A29 or A30 or A31 or A32 or A33 or A34 or A35 or A36 or A37 or A38 or A39 or A40 or A41 or
A42 or A43 or A44 or A45 or A46 or A47 or A48 or A49 or A50 or A51 or A52 or A53 or A54 or
A55 or A56 or A57 or A58 or A59 or A60 or A61 or A62 or A63 or A64 or A65 or A66 or A67 or
A68 or A69 or A70 or A71 or A72 or A73 or A74 or A75 or A76 or A77 or A78 or A79 or A80 or
A81 or A82 or A83 or A84 or A85 or A86 or A87 or A88 or A89 or A90 or A91 or A92 or A93 or
A94 or A95 or A96 or A97 or A98 or A99 or A100 or A101 or A102 or A103 or A104 or A105 or A106) then
Buy("Z");
즐거운 하루되세요
> 말라 님이 쓴 글입니다.
> 제목 : 안녕하세요 질문드립니다.
> 안녕하세요
재질문 드려봅니다.
아까 질문 4개 드려봤는데요
3개는 잘 이해가 갑니다.
감사합니다
헌데 청산전 추가 진입을 안하고 싶다는 글에 대한 답변을 이렇게 받았습니다
--------------------------------------------------------------
진입식에 MarketPosition == 0 조건을 추가하시면 됩니다.
추가진입을 하는 경우에는 추가진입하는 로직을 만들고
차트에 적용할 때 시스템 트레이딩 설정창의 피라미딩탭에서 피라미딩을 설정을 해야만
추가진입을 합니다.
시스템은 기본설정이 추가진입을 하지 않습니다.
--------------------------------------------------------------
이렇게요
제가 생초보라서요....아래의 시스템식에 어떻게 대입해야하는건지...
이 식에 대입좀 부탁드립니다.
if MarketPosition == 1을 삭제하고 넣는건지...
if MarketPosition == 1을 삭제 안하고 추가해서 넣는건지...
넣는다면 어디에 넣는건지..... 하나도 몰라요 ㅜ.ㅜ
부탁드립니다.
var : A1(False),A2(False),A3(False),A4(False),A5(False),A6(False),A7(False),A8(False),A9(False),A10(False),A11(False),A12(False),A13(False),A14(False),A15(False),A16(False),
A17(False),A18(False),A19(False),A20(False),A21(False),A22(False),A23(False),A24(False),A25(False),A26(False),A27(False),A28(False),A29(False),A30(False),A31(False),
A32(False),A33(False),A34(False),A35(False),A36(False),A37(False),A38(False),A39(False),A40(False),A41(False),A42(False),A43(False),A44(False),A45(False),A46(False),
A47(False),A48(False),A49(False),A50(False),A51(False),A52(False),A53(False),A54(False),A55(False),A56(False),A57(False),A58(False),A59(False),A60(False),A61(False),
A62(False),A63(False),A64(False),A65(False),A66(False),A67(False),A68(False),A69(False),A70(False),A71(False),A72(False),A73(False),A74(False),A75(False),A76(False),
A77(False),A78(False),A79(False),A80(False),A81(False),A82(False),A83(False),A84(False),A85(False),A86(False),A87(False),A88(False),A89(False),A90(False),A91(False),
A92(False),A93(False),A94(False),A95(False),A96(False),A97(False),A98(False),A99(False),A100(False),A101(False),A102(False),A103(False),A104(False),A105(False),A106(False);
A1= 매수식(길어서생략)
A2= 상동
.
.
.
A106=상동
IF A1 or A2 or A3 or A4 or A5 or A6 or A7 or A8 or A9 or A10 or A11 or A12 or A13 or A14 or A15 or
A16 or A17 or A18 or A19 or A20 or A21 or A22 or A23 or A24 or A25 or A26 or A27 or A28 or
A29 or A30 or A31 or A32 or A33 or A34 or A35 or A36 or A37 or A38 or A39 or A40 or A41 or
A42 or A43 or A44 or A45 or A46 or A47 or A48 or A49 or A50 or A51 or A52 or A53 or A54 or
A55 or A56 or A57 or A58 or A59 or A60 or A61 or A62 or A63 or A64 or A65 or A66 or A67 or
A68 or A69 or A70 or A71 or A72 or A73 or A74 or A75 or A76 or A77 or A78 or A79 or A80 or
A81 or A82 or A83 or A84 or A85 or A86 or A87 or A88 or A89 or A90 or A91 or A92 or A93 or
A94 or A95 or A96 or A97 or A98 or A99 or A100 or A101 or A102 or A103 or A104 or A105 or A106 then
Buy("Z");
Var : ZPrice(0),Zhigh(0);
Var : Bidx1(0);
if MarketPosition == 1 Then
{
#Z진입 발생
#보유수량이 증가하고 최근 발생한 진입명이 Z이면
if CurrentContracts > CurrentContracts[1] and LatestEntryName(0) == "Z" Then
{
#진입가 저장
ZPrice = LatestEntryPrice(0);
#진입이후 최고가의 초기값으로 현재봉 고가저장
Zhigh = H;
}
#새로운 고가가 발생하면 변수의 값을 새로운 고가를 변경
if Zhigh > 0 and H > Zhigh Then
Zhigh = H;
if A1.3Price > 0 Then
{
#45% 수익이면 청산
ExitLong("C1",AtLimit,ZPrice*1.45,"Z");
#35% 이상 수익이후에 10% 하락하면 청산
if Zhigh >= ZPrice*1.35 Then
ExitLong("C2",AtStop,A1high*0.90,"Z");
#6% 손실시 청산
ExitLong("C3",AtStop,ZPrice*0.94,"Z");
}
if ZPrice > 0 Then
{
Bidx1 = Bidx1+1;
if Bidx1 == 1540 Then
ExitLong("bx1",OnClose,DEf,"Z");
}
}
Else
{
ZPrice = 0;
Zhigh = 0;
Bidx1 = 0;
}