WonderTones

MacD_MT

12
beta version of multiple macd indicator
오픈 소스 스크립트

이 스크립트의 오써는 참된 트레이딩뷰의 스피릿으로 이 스크립트를 오픈소스로 퍼블리쉬하여 트레이더들로 하여금 이해 및 검증할 수 있도록 하였습니다. 오써를 응원합니다! 스크립트를 무료로 쓸 수 있지만, 다른 퍼블리케이션에서 이 코드를 재사용하는 것은 하우스룰을 따릅니다. 님은 즐겨찾기로 이 스크립트를 차트에서 쓸 수 있습니다.

면책사항

이 정보와 게시물은 TradingView에서 제공하거나 보증하는 금융, 투자, 거래 또는 기타 유형의 조언이나 권고 사항을 의미하거나 구성하지 않습니다. 자세한 내용은 이용 약관을 참고하세요.

차트에 이 스크립트를 사용하시겠습니까?
study(title="MacD_MT", shorttitle="MacD_MT")

//@version=2
find_max_bool(s1, s2, s3) =>
    bmax = false
    if (s2 - s3) > 0.01 and (s2 - s1) > 0.01
        bmax := true
    bmax

//@version=2
find_diver(ser, length) =>
    sign = ser[1] / abs(ser[1])

    abs_ser = ser * sign
    max1 = false
    max2 = false
    diver_found = false
    max2_pos = 0
    
    max1 := find_max_bool(abs_ser[0], abs_ser[1], abs_ser[2])
    if max1 == true
        for i = 1 to length - 1
            max2 := find_max_bool(abs_ser[i+2], abs_ser[i+3], abs_ser[i+4])
            if max2 == true
                if (abs_ser[i+3] - abs_ser[1]) > 0.1
                    diver_found := true
                    max2_pos := i+3
                    break
                // else case
                max2 := false
        
    allpositive = true
    if diver_found == true
        for j = 2 to max2_pos
            if abs_ser[j] < 0
                allpositive := false
                break

    res = diver_found == true and allpositive == true
    res

//@version=2
var_macd(tframe) =>
    source = close

    fastLength = input(12, minval=1)
    slowLength=input(26,minval=1)
    signalLength=input(9,minval=1)

    fastMA = sma(source, fastLength)
    slowMA = sma(source, slowLength)

    macd = fastMA - slowMA
    signal = sma(macd, signalLength)
    hist = macd - signal

    outMacD = security(tickerid, tframe, macd)
    outSignal = security(tickerid, tframe, signal)
    outHist = security(tickerid, tframe, hist)

    [outMacD, outSignal, outHist]


[m30, s30, h30] = var_macd("30")
//plot(s60, color=red, title="SIGNAL")
plot(m30, color=#0060ff, title="MACD")
is_diver30 = find_diver(m30, 30)
plot(is_diver30, color=green)
plotshape(is_diver30, color=lime, style=shape.arrowup, text="Diver!")

[m240, s240, h240] = var_macd("240")
//plot(s240, color=red, title="SIGNAL")
plot(m240, color=#0020ff, title="MACD")
is_diver240 = find_diver(m240, 200)
plot(is_diver240, color=green)