커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
4770
글번호 230811
지표
답변완료

문의 드립니다.

안녕하세요? 이제 막 배우기 시작한 초보입니다. 검색을 아무리 해봐도 찾을 수 없어 이렇게 질문 드립니다. 다름이 아니고 추세선 함수를 쓸때 최근 것 또는 최근 몇개에만 연장(TL_SetExtRight)를 적용하려면 어떻게 해야 하는지요? 전부다 연장을 하려니 화면이 너무 복잡해지고 그렇다고 연장을 하지 않으니 효용성이 떨어지네요. 바쁘시겠지만 예시를 포함한 답변 부탁드립니다. 감사합니다.
프로필 이미지
duke
2015-09-06
110
글번호 90095
지표
답변완료

지표 문의 드립니다.

해외선물(오일, 골드 등) 분봉 차트에서 당일 최고/최소 거래량의 현재가격을 표시하는 지표 부탁 드립니다,
프로필 이미지
예시
2015-09-06
114
글번호 90094
지표

매크로 님에 의해서 삭제되었습니다.

프로필 이미지
매크로
2015-09-05
0
글번호 90093
지표

매크로 님에 의해서 삭제되었습니다.

프로필 이미지
매크로
2015-09-05
10
글번호 90092
지표
답변완료

부탁 드립니다.

yt로 변환 부탁 드립니다. 미리 감사드립니다. d=simrido(20); up=avg(d,20)+2*stdev(d,20); dn=avg(d,20)-2*stdev(d,20); PB=(d-dn)/(up-dn); CUP=crossup(PB,0); CDN=crossdown(PB,0); valuewhen(1,CDN,H);
프로필 이미지
yes
2015-09-05
122
글번호 90091
지표
답변완료

스크립트 변환요청 11-1호

안녕하세요? 아래는 SK증권에서 사용했던 함수입니다. 예스랭귀지로 변환 요청드립니다. var : entry1(0); var : ho1(0),OL1(0),HL1(0); var : maho1(0),maOL1(0),maHL1(0); var : cnt(0), cnt1(0), cnt2(0), sumho1(0),sumOL1(0),sumHL1(0); var : EntryCnt1(0); Var : MP(0), MinValue(0); Array : Varray[4](0); MP = MarketPosition; //marketposition 변수에 담기 if date != date[1] Then entry1 = 0; if MP != 0 and MP != MP[1] Then entry1 = entry1 + 1; value1 = DayOpen(0); value2 = DayHigh(0); value3 = DayLow(0); ho1 = value2 - value1; OL1 = value1 - value3; HL1 = value2 - value3; sumho1 = 0; sumOL1 = 0; sumHL1 = 0; for cnt1 = 1 to 10 Begin sumho1 = sumho1 + (dayhigh(cnt1) - dayopen(cnt1)); sumOL1 = sumOL1 + (DayOpen(cnt1) - DayLow(cnt1)); sumHL1 = sumHL1 + (DayHigh(cnt1) - DayLow(cnt1)); End; maho1 = sumho1/10; maOL1 = sumOL1/10; maHL1 = sumHL1/10; Varray[1] = value1 + maho1; // value1 = DayOpen Varray[2] = value1 - maOL1; Varray[3] = value1 + maHL1; Varray[4] = value1 - maHL1; For Cnt = 1 To 4 Step 1 Begin MinValue = Varray[cnt]; cnt2 = cnt; While ( cnt2 > 1 ) && Varray[cnt2 - 1] > MinValue Begin Varray[cnt2] = Varray[cnt2 - 1]; cnt2 = cnt2 - 1; End; Varray[cnt2] = MinValue; End; V5 = Varray[4]; v6 = Varray[3]; v9 = Varray[2]; v10 = Varray[1]; //V5 = NthMaxList(1,V1,V2,V3,V4); //V6 = NthMaxList(2,V1,V2,V3,V4); //V9 = NthMaxList(3,V1,V2,V3,V4); //V10 = NthMaxList(4,V1,V2,V3,V4); V7 = (V5 + V10)/2; V8 = (V6 + V9)/2; if MP == 0 and entry1 == 0 Then Begin if V7 > V8 Then sell("s1",AtStop,V7 - 0.02); if V7 < V8 Then sell("s2",Atlimit,V8 - 0.02); End; if MP == -1 and IsEntryName("s1") == true Then Begin ExitShort("sp1",atlimit,V9 - 0.03); ExitShort("sl1",AtStop,V6); End; if MP == -1 and IsEntryName("s2") == true Then Begin ExitShort("sp2",atlimit,V9 - 0.03); ExitShort("sl2",AtStop,V6); End; var : TF(0); var : EXtime(0), Entime(false),mav1(0),mav2(0); var : HV(0),LV(0),HV1(0),LV1(0),HV2(0),LV2(0); var : sTimevalue(0); Array : HH[50](0),LL[50](0),CC[50](0); mav1 = ma(c,5); mav2 = ma(C,20); sTimevalue = sTime; TF = TimeToMin(sTimevalue)%30; if date != date[1] Then Begin Entime = true; if sTimevalue >= 090000 Then EXtime = 050000 Else EXtime = 060000; End; if date != date[1] or (TF < TF[1] and sTimevalue > sTimevalue[1]) or date != date[1] Then Begin HH[0] = H; LL[0] = L; for cnt = 1 to 49 Begin V0 = HH[cnt-1]; V1 = LL[cnt-1]; V2 = CC[cnt-1]; HH[cnt] = V0[1]; LL[cnt] = V1[1]; CC[cnt] = V2[1]; //HH[cnt] = HH[cnt-1][1]; //LL[cnt] = LL[cnt-1][1]; //CC[cnt] = CC[cnt-1][1]; End; End; if H > HH[0] Then HH[0] = H; if L < LL[0] Then LL[0] = L; CC[0] = C; if HH[25+2] > 0 Then Begin HV = HH[0]; LV = LL[0]; HV1 = HH[1]; LV1 = LL[1]; HV2 = HH[2]; LV2 = LL[2]; for cnt = 0 to 25 Begin if HH[cnt] > HV Then HV = HH[cnt]; if LL[cnt] < LV Then LV = LL[cnt]; if HH[cnt+1] > HV Then HV = HH[cnt+1]; if LL[cnt+1] < LV Then LV = LL[cnt+1]; if HH[cnt+2] > HV Then HV = HH[cnt+2]; if LL[cnt+2] < LV Then LV = LL[cnt+2]; End; var1 = (HV+LV)/2; var2 = (HV1+LV1)/2; var3 = (HV2+LV2)/2; if Entime == true then Begin if MP = 0 and CC[0] > var1 and CC[1] < var2 and CC[2] < var3 and C >= daylow(0)+0.5 Then buy("b",AtMarket); if MP = 1 and c <= highest(H,BarsSinceEntry)-0.5 and CrossDown(mav1,mav2) Then ExitLong("bx",AtMarket); End; End; if sTimevalue == EXtime or (sTimevalue > EXtime and sTimevalue[1] < EXtime) Then Begin Entime = false; ExitLong(); End; SetStopLoss(0.8,PercentStop); SetStopProfittarget(3,PercentStop); SetStopInactivity(3,23,PercentStop);
프로필 이미지
통큰베팅
2015-09-05
133
글번호 90089
시스템
답변완료

부탁드립니다

input : Period(5); var1 = ma(C,Period); if var1 > var1[1] Then value1 = var1; if var1 < var1[1] Then value2 = var1; plot1(value1); plot2(value2); 지표수식을씨스템수식으로부탁드립니다PLOT1이상승할때매수신호 반대로PLOT2에서떨어질때매도신호 PLOT1과 2가겹칠때는 신호생략 -첫매수신호가 발생되엇다면겹치는(PLOT1과2가)부분은 신호게속유지PLOT2모양이변하지않은한----매도는반대로 PLOT1모양이변하지않은한매도유지--부탁드립니다 신호는시가에나오도록해주세요
프로필 이미지
장군
2015-09-05
126
글번호 90088
시스템

장군 님에 의해서 삭제되었습니다.

프로필 이미지
장군
2015-09-05
4
글번호 90087
시스템

장군 님에 의해서 삭제되었습니다.

프로필 이미지
장군
2015-09-05
0
글번호 90086
시스템