커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

문의드립니다.

아래의 트레이딩뷰 수식을 변환 부탁드립니다. // This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/ // &#169; Duyck //@version=4 study("Blackflag FTS", overlay = true, resolution = "") //{ // # Author: Jose Azcarate //} // inputs // //{ trailType = input("modified", "Trailtype", options = ["modified", "unmodified"]) ATRPeriod = input(28, "ATR Period") ATRFactor = input(5, "ATR Factor") show_fib_entries = input(true, "Show Fib Entries?") norm_o = security(tickerid(syminfo.prefix,syminfo.ticker), timeframe.period, open) norm_h = security(tickerid(syminfo.prefix,syminfo.ticker), timeframe.period, high) norm_l = security(tickerid(syminfo.prefix,syminfo.ticker), timeframe.period, low) norm_c = security(tickerid(syminfo.prefix,syminfo.ticker), timeframe.period, close) //} //////// FUNCTIONS ////////////// //{ // Wilders ma // Wild_ma(_src, _malength) => _wild = 0.0 _wild := nz(_wild[1]) + (_src - nz(_wild[1])) / _malength /////////// TRUE RANGE CALCULATIONS ///////////////// HiLo = min(norm_h - norm_l, 1.5 * nz(sma((norm_h - norm_l), ATRPeriod))) HRef = norm_l<= norm_h[1] ? norm_h - norm_c[1] : (norm_h - norm_c[1]) - 0.5 * (norm_l- norm_h[1]) LRef = norm_h >= norm_l[1] ? norm_c[1] - norm_l: (norm_c[1] - norm_l) - 0.5 * (norm_l[1] - norm_h) trueRange = trailType == "modified" ? max(HiLo, HRef, LRef) : max(norm_h - norm_l, abs(norm_h - norm_c[1]), abs(norm_l - norm_c[1])) //} /////////// TRADE LOGIC //////////////////////// //{ loss = ATRFactor * Wild_ma(trueRange, ATRPeriod) Up = norm_c - loss Dn = norm_c + loss TrendUp = Up TrendDown = Dn Trend = 1 TrendUp := norm_c[1] > TrendUp[1] ? max(Up, TrendUp[1]) : Up TrendDown := norm_c[1] < TrendDown[1] ? min(Dn, TrendDown[1]) : Dn Trend := norm_c > TrendDown[1] ? 1 : norm_c < TrendUp[1]? -1 : nz(Trend[1],1) trail = Trend == 1? TrendUp : TrendDown ex = 0.0 ex := crossover(Trend, 0) ? norm_h : crossunder(Trend, 0) ? norm_l : Trend == 1 ? max(ex[1], norm_h) : Trend == -1 ? min(ex[1], norm_l) : ex[1] //} // //////// PLOT TP and SL ///////////// //{ plot(trail, "Trailingstop", style = plot.style_line, color = Trend == 1 ? color.green : Trend == -1 ? color.red : na) plot(ex, "Extremum", style = plot.style_circles, color = Trend == 1? color.lime : Trend == -1? color.fuchsia : na) //} ////// FIBONACCI LEVELS /////////// //{ state = Trend == 1 ? "long" : "short" fib1Level = 61.8 fib2Level = 75.4 fib3Level = 88.6 f1 = ex + (trail - ex) * fib1Level / 100 f2 = ex + (trail - ex) * fib2Level / 100 f3 = ex + (trail - ex) * fib3Level / 100 l100 = trail + 0 Fib1 = plot(f1, "Fib 1", style = plot.style_line, color = color.black) Fib2 = plot(f2, "Fib 2", style = plot.style_line, color = color.black) Fib3 = plot(f3, "Fib 3", style = plot.style_line, color = color.black) L100 = plot(l100, "l100", style = plot.style_line, color = color.black) fill(Fib1, Fib2, color = state == "long"? color.green : state == "short"? color.red : na) fill(Fib2, Fib3, color = state == "long"? color.new(color.green, 70) : state == "short"? color.new(color.red, 70) : na) fill(Fib3, L100, color = state == "long"? color.new(color.green, 60) : state == "short"? color.new(color.red, 60) : na) l1 = state[1] == "long" and crossunder(norm_c, f1[1]) l2 = state[1] == "long" and crossunder(norm_c, f2[1]) l3 = state[1] == "long" and crossunder(norm_c, f3[1]) s1 = state[1] == "short" and crossover(norm_c, f1[1]) s2 = state[1] == "short" and crossover(norm_c, f2[1]) s3 = state[1] == "short" and crossover(norm_c, f3[1]) atr = sma(trueRange, 14) /////////// FIB PLOTS /////////////////. plotshape(show_fib_entries and l1 ? low - atr : na, "LS1", style = shape.triangleup, location = location.belowbar, color = color.yellow, size = size.tiny) plotshape(show_fib_entries and l2 ? low - 1.5 * atr : na, "LS2", style = shape.triangleup, location = location.belowbar, color = color.yellow, size = size.tiny) plotshape(show_fib_entries and l3 ? low - 2 * atr : na, "LS3", style = shape.triangleup, location = location.belowbar, color = color.yellow, size = size.tiny) plotshape(show_fib_entries and s1 ? high + atr : na, "SS1", style = shape.triangledown, location = location.abovebar, color = color.purple, size = size.tiny) plotshape(show_fib_entries and s2 ? high + 1.5 * atr : na, "SS2", style = shape.triangledown, location = location.abovebar, color = color.purple, size = size.tiny) plotshape(show_fib_entries and s3 ? high + 2 * atr : na, "SS3", style = shape.triangledown, location = location.abovebar, color = color.purple, size = size.tiny) //} ====================== 항상 감사드립니다. 수고하세요!!!
프로필 이미지
해암
2025-10-02
129
글번호 194471
지표
답변완료

시스템

안녕하세요 아래식 매수매도전략 완성 부탁드립니다 //@version=5 strategy("YES Language 전략 - Squeeze + Momentum + ADX", overlay=false, default_qty_type=strategy.percent_of_equity, default_qty_value=10) // 사용자 설정 bbLength = input.int(20, title="BB 기간") bbMult = input.float(2.0, title="BB 표준편차 배수") kcLength = input.int(20, title="KC 기간") kcMult = input.float(1.5, title="KC 배수") useTR = input.bool(true, title="켈트너 채널에 TR 사용") adxLength = input.int(14, title="ADX 기간") adxThreshold = input.float(25, title="추세 기준 ADX 수치") // Bollinger Band src = close bbBasis = ta.sma(src, bbLength) bbDev = bbMult * ta.stdev(src, bbLength) bbUpper = bbBasis + bbDev bbLower = bbBasis - bbDev // Keltner Channel kcMA = ta.sma(src, kcLength) kcRange = useTR ? ta.tr : high - low kcRangeMA = ta.sma(kcRange, kcLength) kcUpper = kcMA + kcRangeMA * kcMult kcLower = kcMA - kcRangeMA * kcMult // 스퀴즈 감지 squeezeOn = bbLower > kcLower and bbUpper < kcUpper // 스퀴즈 발생 (변동성 축소) squeezeOff = bbLower < kcLower and bbUpper > kcUpper // 스퀴즈 해제 (변동성 확장) // Momentum 계산 mid = (ta.highest(high, kcLength) + ta.lowest(low, kcLength)) / 2 avgMid = (mid + ta.sma(close, kcLength)) / 2 momentum = ta.linreg(src - avgMid, kcLength, 0) momentumUp = momentum > momentum[1] // 모멘텀 증가 momentumDown = momentum < momentum[1] // 모멘텀 감소 // ADX 계산 adx = ta.adx(adxLength) isTrending = adx > adxThreshold // ADX가 임계치 이상: 추세 발생 중 // === 매수 조건 (YES Language Style) === // 1. 스퀴즈 해제 AND 2. 모멘텀 양수 AND 3. 모멘텀 증가 AND 4. 추세 발생 중 buyCondition = squeezeOff and momentum > 0 and momentumUp and isTrending // === 매도 조건 (YES Language Style) === // 1. 스퀴즈 해제 AND 2. 모멘텀 음수 AND 3. 모멘텀 감소 AND 4. 추세 발생 중 sellCondition = squeezeOff and momentum < 0 and momentumDown and isTrending // --- 포지션 진입 및 반전 (YES Language Style) --- // 매수 조건 충족 시: 롱 포지션 진입 (현재 숏 포지션이 있으면 청산 후 롱으로 반전) if (buyCondition) strategy.entry("YES 롱", strategy.long, comment="YES 롱 진입") // 매도 조건 충족 시: 숏 포지션 진입 (현재 롱 포지션이 있으면 청산 후 숏으로 반전) if (sellCondition) strategy.entry("YES 숏", strategy.short, comment="YES 숏 진입") // 전략 상태 메시지 (차트 표시) plotshape(buyCondition, location=location.belowbar, color=color.lime, style=shape.labelup, text="예스 매수", textcolor=color.black) plotshape(sellCondition, location=location.abovebar, color=color.red, style=shape.labeldown, text="예스 매도", textcolor=color.white) // 추가: 지표 시각화 (선택 사항) plot(momentum, title="Momentum", color=color.new(color.blue, 0)) hline(0, color=color.gray)
프로필 이미지
달마7
2025-10-02
107
글번호 194470
시스템
답변완료

문의드립니다

input : ndate(20211101); if sDate >= ndate Then { -------------- 날짜를 입력해야하는 식인데요 날짜를 어제(전일)로 고정하려면 어떻게 표현해야 하나요? 어제 이후... 감사합니다
프로필 이미지
러블리
2025-10-02
100
글번호 194469
지표
답변완료

수식 문의 드립니다.

안녕하십니까? 수식 부탁 드립니다 상단 = supertrend(period1, multiplier1); 하단 = supertrend(period2, multiplier2); 상단선의 고점/ 저점 변곡점 = CrossUp(A, B) or CrossDown(A, B); ------------------------------------------------- 수직선 A = supertrend(period1, multiplier1); B = supertrend(period2, multiplier2); 조건1 = CrossUp(A, B); 조건2 = CrossDown(A, B); if(조건1, A, 0) if(조건2, A, 0) period1 = 7 period2 = 15 multiplier1 = 1 multiplier2 = 2 항상 감사 합니다 명절 잘 보내 십시요
프로필 이미지
s1017051
2025-10-02
108
글번호 194468
지표

마녀58 님에 의해서 삭제되었습니다.

프로필 이미지
마녀58
2025-10-02
1
글번호 194467
지표
답변완료

추세선 수식에 박스와 변곡점의 가격과 퍼센트을 추가한 수식

아래 추세선 수식에 박스와 변곡점의 가격과 퍼센트을 추가한 수식 부탁드립니다 ============================================================================ var : T(0),HH(0),HD(0),HT(0),LL(0),LD(0),LT(0),TL(0); if Bdate != Bdate[1] Then { var1 = 0; var2 = 0; } var1 = var1+ma(upVol,5); var2 = var2+ma(downVol,5); Var3 = var1-Var2; var4 = var3-ema(var3,9); if CrossUp(0,Var4) Then var5 = C; Plot7(var5,"가격선"); if T <= 0 and CrossUp(c,var5) Then { T = 1; HH = H; HD = sDate; HT = sTime; if LL > 0 Then { TL = TL_New(LD,LT,LL,HD,HT,HH); TL_SetColor(TL,Red); } } if T >= 0 and CrossDown(c,var5) Then { T = -1; LL = L; LD = sDate; LT = sTime; if HH > 0 Then { TL = TL_New(HD,HT,HH,LD,LT,LL); TL_SetColor(TL,Blue); } } if T == 1 Then { if H > HH Then { HH = H; HD = sDate; HT = sTime; TL_SetEnd(TL,HD,HT,HH); } } if T == -1 Then { if L < LL Then { LL = L; LD = sDate; LT = sTime; TL_SetEnd(TL,LD,LT,LL); } }
프로필 이미지
팔보채
2025-10-02
126
글번호 194466
지표
답변완료

수식문의(신규종목)

input : 이평기간(200); var : LRLv(0), A(0); A=EmA(C,이평기간); LRLv = LRL(C,50); if CrossUp(LRLv, A) and LRLv>LRLv[1] and A>A[1] Then Find(1); 위 수식은 LRL(50)선이 200지수이평을 돌파(LRL과 200지수이평은 상승추세) 하는 검색인데, 검증에 맞는다 나오는데, 맞는지요? 상장된지 298일이내인 종목만을 검색대상으로 하고자 합니다. 이 부분을 수정해주세요.
프로필 이미지
ksks
2025-10-01
107
글번호 194465
종목검색
답변완료

진입제한

안녕하세요, 하루 진입횟수를 특정회수(5번등)으로 제한하는 수식 부탁드립니다. 감사합니다.
프로필 이미지
huhboo99
2025-10-01
75
글번호 194464
시스템
답변완료

전략실행과 시뮬레에션 진입의 차이?

전략실행챠트와 전략실행 성능보고서상의 진입과 시뮬레이션챠트와 시뮬레이션에서의 진입이 상이합니다. 청산은 봉이 완성되기 전에 청산이 될 수 있기 때문에 약간의 차이가 있을 수 있다고 생각되지만 진입은 봉이 완성되고나서 진입이 되기때문에 차이가 나지 않아야 될 것으로 생각이 됩니다. 시뮬레이션으로는 챠트와 성능보고서에 진입이 된 것으로 나오는데 전략실행상으로는 나타나지 않습니다. 이와관련 캡쳐를 첨부파일에 첨부하오니 원인을 파악하여 주시면 고맙겠습니다.
프로필 이미지
하날랑
2025-10-01
91
글번호 194463
시스템
답변완료

안녕하세요

주식 차트에서 분봉 거래대금을 (1억)으로 표현하여 구현할 수 있는 지표 문의드립니다. 감사합니다!
프로필 이미지
로즈버드
2025-10-01
114
글번호 194462
지표