커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

부탁드립니다

부탁드립니다
프로필 이미지
매치다2
2022-10-19
1056
글번호 163126
종목검색

매치다2 님에 의해서 삭제되었습니다.

프로필 이미지
매치다2
2022-10-19
0
글번호 163125
종목검색

매치다2 님에 의해서 삭제되었습니다.

프로필 이미지
매치다2
2022-10-19
0
글번호 163124
종목검색
답변완료

역사적변동성

안녕하세요! 스크린샷 화면은 옵션 시뮬레이터 화면인데, 혹시 밑줄 친 역사적 변동성을 구하는 수식이 어떻게 될까요? 항상 도움주셔서 감사합니다!
프로필 이미지
히익
2022-10-19
1240
글번호 163119
시스템
답변완료

파동의 저점과 고점 봉의 위치 재문의

안녕하십니까 ? 앞의 질문에 대한 재질문을 하고자 합니다. 파동의 최고점 최저점 봉의 위치를 타점으로 하는 데이터를 얻고자 하는 것인데 아래 로직에서 최저점 혹은 최고점은 실시간으로는 동적 메모리를 이용해서 고점과 저점의 변화에 따라서 지속적으로 갱신하는 것으로 보입니다. 하여간 아래 로직으로는 파동의 저점과 고점의 봉의 위치를 잡지 못하는것 같습니다. (그림파일 첨부 참조) 따라서 결정되는 봉의 color값도 함께 동적메모리를 이용해서 갱신해야 하지 않는지요 ?(개인적인 생각이지만...) yeslanguage 메모리 사용법을 몰라서 잘 안되는데 꼭 부탁드립니다. 안녕하세요 예스스탁입니다. Input:P(0),length(10); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0), Text1(0),처리구분(""),T(0),TL3(0),TL4(0),TL5(0),color(0); Array:고점[10,2](0),저점[10,2](0); //가격,위치 처리구분 = ""; If Highest(H,length) == H and lastHiVal <> H and Lowest(L,length) == L and lastLoVal <> L Then { If 저점[1,1] > L Then 처리구분 = "저점처리"; If 고점[1,1] < H Then 처리구분 = "고점처리"; } Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리"; Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리"; If 처리구분 == "고점처리" Then { lastHiVal = H; If 고점[1,2] < 저점[1,2] Then { For j = 10 DownTo 2 { 고점[j,1] = 고점[j-1,1]; 고점[j,2] = 고점[j-1,2]; } } If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then { 고점[1,1] = H; 고점[1,2] = Index; sBar = Index - 저점[1,2]; eBar = 0; TL_Delete(TL2); TL_Delete(TL3); TL_Delete(TL4); TL_Delete(TL5); If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL3 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382); TL4 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500); TL5 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618); Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],P)); Var1 = 고점[1,1]; Text_SetStyle(Text1, 2, 1); Text_SetColor(Text1,Blue); color = -1; } # End of If 고점[1,2] < 저점[1,2] or 고점[1,1] < H } # End of If 처리구분 == "고점처리"... If 처리구분 == "저점처리" Then { lastLoVal = L; If 저점[1,2] < 고점[1,2] then { For j = 10 DownTo 2 { 저점[j,1] = 저점[j-1,1]; 저점[j,2] = 저점[j-1,2]; } } If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then { 저점[1,1] = L; 저점[1,2] = Index; sBar = Index - 고점[1,2]; eBar = 0; TL_Delete(TL2); TL_Delete(TL3); TL_Delete(TL4); TL_Delete(TL5); If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); } # End of If TL_GetBeginDate(TL1) == TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL3 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382); TL4 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500); TL5 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618); Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],P)); Var2 = 저점[1,1]; Text_SetStyle(Text1, 2, 8); Text_SetColor(Text1,Red); color = 1; } # End of If 저점[1,2] < 고점[1,2] or 저점[1,1] > L } # End of If 처리구분 == "저점처리" TL_SetSize(TL1,0); TL_SetColor(TL1,GRAY); Plot1(color); 즐거운 하루되세요 > 구천룡 님이 쓴 글입니다. > 제목 : 파동의 저점과 고점 위치 > 안녕하십니까. 아래 프로그램으로 장중 파동의 고점과 저점의 봉의 데이터 값, 즉 첨부된 그름 파일에서 붉은 색 값인 경우 +1로 출력하고 푸른색의 값인 경우 -1로 리턴하는 함수를 작성하고자 합니다. 도움 좀 부탁드립니다. 사용 목적은 파동의 고점과 저점 봉의 데이터 출력하고자 합니다. (죄송스럽게도 제가 로직 이해가 부족해서 인지 정확히 숫자 찍히는 고점과 저점 지점을 잡을 수가 없네요) Input:P(0),length(10); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0), Text1(0),처리구분(""),T(0),TL3(0),TL4(0),TL5(0); Array:고점[10,2](0),저점[10,2](0); //가격,위치 처리구분 = ""; If Highest(H,length) == H and lastHiVal <> H and Lowest(L,length) == L and lastLoVal <> L Then { If 저점[1,1] > L Then 처리구분 = "저점처리"; If 고점[1,1] < H Then 처리구분 = "고점처리"; } Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리"; Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리"; If 처리구분 == "고점처리" Then { lastHiVal = H; If 고점[1,2] < 저점[1,2] Then { For j = 10 DownTo 2 { 고점[j,1] = 고점[j-1,1]; 고점[j,2] = 고점[j-1,2]; } } If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then { 고점[1,1] = H; 고점[1,2] = Index; sBar = Index - 저점[1,2]; eBar = 0; TL_Delete(TL2); TL_Delete(TL3); TL_Delete(TL4); TL_Delete(TL5); If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL3 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382); TL4 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500); TL5 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618); Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],P)); Var1 = 고점[1,1]; Text_SetStyle(Text1, 2, 1); Text_SetColor(Text1,Blue); } # End of If 고점[1,2] < 저점[1,2] or 고점[1,1] < H } # End of If 처리구분 == "고점처리"... If 처리구분 == "저점처리" Then { lastLoVal = L; If 저점[1,2] < 고점[1,2] then { For j = 10 DownTo 2 { 저점[j,1] = 저점[j-1,1]; 저점[j,2] = 저점[j-1,2]; } } If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then { 저점[1,1] = L; 저점[1,2] = Index; sBar = Index - 고점[1,2]; eBar = 0; TL_Delete(TL2); TL_Delete(TL3); TL_Delete(TL4); TL_Delete(TL5); If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); Text_Delete(Text1); } # End of If TL_GetBeginDate(TL1) == TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL3 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382); TL4 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500); TL5 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618); Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],P)); Var2 = 저점[1,1]; Text_SetStyle(Text1, 2, 8); Text_SetColor(Text1,Red); } # End of If 저점[1,2] < 고점[1,2] or 저점[1,1] > L } # End of If 처리구분 == "저점처리" TL_SetSize(TL1,0); TL_SetColor(TL1,GRAY);
프로필 이미지
구천룡
2022-10-19
1119
글번호 163117
지표
답변완료

79227 재댓글에 대한 답변부탁드립니다.(냉무)

냉무
프로필 이미지
임진사댁원장
2022-10-19
975
글번호 163112
지표
답변완료

종목검색이 분봉에서 적용이 안됩니다 도와주세요...

친절한 답변 감사합니다 수식을 확인해보니 일봉은 결과값중 대략 90%정로 맞습니다 그런데 실제 사용처는 1분봉 종목 검색으로 사용할려고 합니다 말씀하신것처럼 검색에 필요한 최소기간 체크하고 500봉 입력후 기준봉0 분 1 수정 까지 입력한다음 검색을 하니 분봉은 전혀 다른곳에서 결과가 나타납니다 예전 Q&A 찾아봐서 혹시나 하는 맘에 함수에서 5단위로 240~500까지 바꾸고 필요한 최소 기간도 함수랑 같은 봉수로 바꿔서 일일이 검색해봤는데 결과값이 안나옵니다 만약 답이 없다면 현재 종가가 B 박스선 아래 있을때 찾는다는 수식으로 바꿔보면 if CROSSUP(C,B) Then 을 if C<B Then 으로 바꿔주면 되는건가요? > 예스스탁 님이 쓴 글입니다. > 제목 : Re : 종목검색 수식 부탁드립니다 > 안녕하세요 예스스탁입니다. 1 이평을 계산하기 위해서 최소 240봉은 필요하고 avgif ,StdevIf 함수가 차트 전체봉을 대상으로 합니다. 종목검색은 최대 500봉입니다. 종목검색시 속성에서 500봉으로 지정하고 검색하셔야 합니다. input : 이평기간(240); var : A(0),value(0),sum(0),ii(0),avgif(0),cnt(0); var : SumSqrt(0),StdevIf(0),B(0); Array : diff[500](0); A= ma(C,이평기간); value = C-A; if IsNan(value) == False then { if value < 0 Then { ii = ii + 1; diff[ii] = value; sum = sum + value; avgif = sum/ii; } if ii >= 1 then { SumSqrt = 0; For cnt = 1 To ii { SumSqrt = SumSqrt + (diff[cnt] - avgif)^2; } StdevIf = SquareRoot(SumSqrt / ii); B = A + avgif - 2*StdevIf; if CROSSUP(C,B) Then Find(1); } } > 불개미미미 님이 쓴 글입니다. > 제목 : 종목검색 수식 부탁드립니다 > 안녕하세요 고생이 많으십니다 종목검색 수식은 너무 험난하네요 수식 좀 부탁 드리겠습니다 1.1분봉 A = MA(가격,이평기간,이평방법); // 종가,240,단순 b=A + AvgIf( c - A, -1, 0.0 ) -2*StdevIf( c - A, -1, 0.0 );
프로필 이미지
불개미미미
2022-10-19
990
글번호 163111
종목검색
답변완료

문의 드립니다.

아래 당일 중심선 지표를 기준으로 아래서 위로 돌파 시 매수 진입 아래로 돌파 시 매도 청산 완료 부탁드립니다. Plot1((DayHigh+DayLow)/2);
프로필 이미지
선물대장
2022-10-19
1326
글번호 163110
시스템

배득공 님에 의해서 삭제되었습니다.

프로필 이미지
배득공
2022-10-19
15
글번호 163103
지표
답변완료

포지션 진입후 경과 봉 수

안녕하세요 선물거래에서 포지션 매수 후, 최소가격 변화를 코드로 작성하고 싶어서 문의드립니다. 매수 또는 매도 진입 후, 3개의 캔들 경과시 -1~-4 포인트 손실중이고 스토캐스틱 12 5 5 의 StoD값이 반대방향이면 , 청산하는 식을 짜 넣고 싶어요. barssinceEntry(3) 이건, 포지션 진입의 카운트 세는건지? 잘 안되는거 같습니다
프로필 이미지
카카보오12
2022-10-19
1133
글번호 163102
시스템