답변완료
도움을 요청합니다.
안녕하세요..
아래 수식은 참조데이터 2와 3을 결합하여 나타내는 수식입니다.
참조데이터 4를 추가해주시기를 요청드립니다.
결과적으로 참조데이터2+3+4를 원하는 것입니다.
노고에 미리 감사드립니다.
==================
var : O2(0,data3),C2(0,Data3),H2(0,Data3),L2(0,Data3),cnt(0,Data3);
var : Sidx(0,Data3),Sidx1(0,Data3),Eidx(0,Data3),Eidx1(0,Data3),Pre1(0,Data3);
C2 = Data3(c)+data4(c);
if Data3(Bdate != Bdate[1]) Then
{
o2 = c2;
H2 = C2;
L2 = C2;
Sidx = data3(Index);
Sidx1 = Sidx[1];
Eidx1 = Eidx[1];
}
Eidx = data3(Index);
if data3(Bdate != Bdate[1] or (Bdate == bdate[1] and C2 > h2)) Then
h2 = C2;
if data3(Bdate != Bdate[1] or (Bdate == Bdate[1] and C2 < l2)) Then
l2 = C2;
if Sidx1 > 0 Then
{
pre1 = 0;
For cnt = data3(Index)-Eidx1 to data3(Index)-Sidx1
{
if data3(sDate[cnt] < sDate and sTime[cnt] <= sTime) Then
{
pre1 = C2[cnt];
cnt = data3(Index-Sidx1+1);
}
}
}
if CurrentDate == sDate Then
{
if Data1(sDate) == Data3(sDate) Then
{
Plot1(C2,"참조",IFf(C2 >0,RGB(0,0,0),RGB(0,0,0)));
Plot2(H2,"최고");
Plot3(L2,"최저");
Plot4(pre1,"전일");
PlotBaseLine1(0);
}
Else
{
NoPlot(1);
NoPlot(2);
NoPlot(3);
NoPlot(4);
}
}
if CurrentDate == sDate and Data1(sDate) == Data3(sDate) Then
{
Plot5(C2,"D2당일시가");
Plot6(h2,"D2당일고가");
Plot7(L2,"D2당일저가");
Plot8(L2+(H2-L2)*0.25,"25.0%");
Plot9(L2+(H2-L2)*0.75,"75.0%");
Plot10(L2+(H2-L2)*0.382,"38.2%");
Plot11(L2+(H2-L2)*0.618,"61.8%");
Plot12(L2+(H2-L2)*0.50,"50.0%");
}
if CurrentDate == sDate and Data1(sDate) == Data3(sDate) Then
Plot13(O2,"당일시가");
2023-11-16
751
글번호 174099
지표
답변완료
문의 드립니다.
periodK = input(50, title="%K Length", minval=1)
smoothK = input(10, title="%K Smoothing", minval=1)
src1 = input(close, title="Source")
length=input(2, "OTT Period", minval=1)
percent=input(0.5, "OTT Percent", type=input.float, step=0.1, minval=0)
showsupport = input(title="Show Support Line?", type=input.bool, defval=false)
showsignalsc = input(title="Show Stochastic/OTT Crossing Signals?", type=input.bool, defval=false)
Var_Func1(src1,length)=>
valpha1=2/(length+1)
vud11=src1>src1[1] ? src1-src1[1] : 0
vdd11=src1<src1[1] ? src1[1]-src1 : 0
vUD1=sum(vud11,9)
vDD1=sum(vdd11,9)
vCMO1=nz((vUD1-vDD1)/(vUD1+vDD1))
VAR1=0.0
VAR1:=nz(valpha1*abs(vCMO1)*src1)+(1-valpha1*abs(vCMO1))*nz(VAR1[1])
VAR1=Var_Func1(src1,length)
k = Var_Func1(stoch(close, high, low, periodK), smoothK)
src=k+1000
Var_Func(src,length)=>
valpha=2/(length+1)
vud1=src>src[1] ? src-src[1] : 0
vdd1=src<src[1] ? src[1]-src : 0
vUD=sum(vud1,9)
vDD=sum(vdd1,9)
vCMO=nz((vUD-vDD)/(vUD+vDD))
VAR=0.0
VAR:=nz(valpha*abs(vCMO)*src)+(1-valpha*abs(vCMO))*nz(VAR[1])
VAR=Var_Func(src,length)
h0 = hline(1080, "Upper Band", color=#606060)
h1 = hline(1020, "Lower Band", color=#606060)
fill(h0, h1, color=#9915FF, transp=80, title="Background")
plot(k+1000, title="%K", color=#0094FF)
MAvg=Var_Func(src, length)
fark=MAvg*percent*0.01
longStop = MAvg - fark
longStopPrev = nz(longStop[1], longStop)
longStop := MAvg > longStopPrev ? max(longStop, longStopPrev) : longStop
shortStop = MAvg + fark
shortStopPrev = nz(shortStop[1], shortStop)
shortStop := MAvg < shortStopPrev ? min(shortStop, shortStopPrev) : shortStop
dir = 1
dir := nz(dir[1], dir)
dir := dir == -1 and MAvg > shortStopPrev ? 1 : dir == 1 and MAvg < longStopPrev ? -1 : dir
MT = dir==1 ? longStop: shortStop
OTT=MAvg>MT ? MT*(200+percent)/200 : MT*(200-percent)/200
plot(showsupport ? MAvg : na, color=#0585E1, linewidth=2, title="Support Line")
OTTC = #B800D9
pALL=plot(nz(OTT[2]), color=OTTC, linewidth=2, title="OTT", transp=0)
alertcondition(cross(src, OTT[2]), title="Price Cross Alert", message="OTT - Price Crossing!")
alertcondition(crossover(src, OTT[2]), title="Price Crossover Alarm", message="PRICE OVER OTT - BUY SIGNAL!")
alertcondition(crossunder(src, OTT[2]), title="Price Crossunder Alarm", message="PRICE UNDER OTT - SELL SIGNAL!")
buySignalc = crossover(src, OTT[2])
plotshape(buySignalc and showsignalsc ? OTT*0.995 : na, title="Buy", text="Buy", location=location.absolute, style=shape.labelup, size=size.tiny, color=color.green, textcolor=color.white, transp=0)
sellSignallc = crossunder(src, OTT[2])
plotshape(sellSignallc and showsignalsc ? OTT*1.005 : na, title="Sell", text="Sell", location=location.absolute, style=shape.labeldown, size=size.tiny, color=color.red, textcolor=color.white, transp=0)
트레이딩뷰 지표인데 예스로 좀 변환해주세요.
선은 두선만 있습니다.
2023-11-15
1467
글번호 174093
지표
답변완료
종목검색식 작성 부탁드립니다
안녕하세요
아래 표기된 키움신호 수식을 예스트레이더 종목검색식으로 작성 부탁드립니다
아래 키움 지표수식과 같이 보스티안 지표와 보스티안 지표 시그널선을 그린 상태에서
키움 신호수식으로 보스티안지표가 0을 돌파하는 종목검색식과 보스티안지표가 보스티안시그널선을 돌파하는 종목검색식을 각각 작성 부탁드립니다
아래 키움지표수식 첨부하였습니다
감사합니다
키움지표 지표수식
​(수식1) 보스티안
sum(v*((Pow((C-L),2) - Pow((H-C),2))/(H-L)));
​(수식2) 보스티안 시그널선
a=sum(v*((Pow((C-L),2) - Pow((H-C),2))/(H-L)));
eavg(a,9)
​
--종목 검색 요청 부분 --
키움 신호수식
<보스티안 0선 돌파 신호수식>
a=sum(v*((Pow((C-L),2) - Pow((H-C),2))/(H-L)));
crossup(a,0)
​
<보스티안 시그널선돌파 신호수식>
a=sum(v*((Pow((C-L),2) - Pow((H-C),2))/(H-L)));
b=eavg(a,9);
crossup(a,b)
2023-11-15
896
글번호 174092
종목검색
답변완료
고생하십니다. 문의 드립니다......
> var : idx(0), ma1(0), ma2(0);
idx = Index;
ma1 = Ema(C, 5);
ma2 = Ema(C, 20);
// 1번
if 4 <= idx && idx < 9 Then {
if CountIF(C < ma1, idx - 3)[1] == idx - 4 && C[1] < ma1 && ma1 <= C
Then Find(1);
}
// 2번
if 19 <= idx && idx < 29 Then {
if CountIF(ma1 < ma2, idx - 18) == idx - 18 && CountIF(C < ma1, 5)[1] == 5 && C[1] < ma1 && ma1 <= C
Then Find(2);
}
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
새 수식 파일에 1번 수식만 입력해서 검색했을 때,
(2023-11-15 종가 기준)
종목명 검색결과값
컨텍 1
비아이매트릭스 1
로 1번 수식의 검색결과 종목인 컨텍, 비아이매트릭스가 검색되고
새 수식 파일에 2번 수식만 입력해서 검색했을 때,
(2023-11-15 종가 기준)
종목명 검색결과값
아이엠티 2
퓨릿 2
레뷰코퍼레이션 2
신성에스티 2
로 2번 수식의 검색결과 종목인 아이엠티, 퓨릿, 레뷰코퍼레이션, 신성에스티가 검색됩니다.
하지만 위의 수식 처럼 새 수식 파일에 1번과 2번 수식을 모두 적용 했을 때,
컨텍, 비아이매트릭스, 아이엠티, 퓨릿, 레뷰코퍼레이션, 신성에스티, 총 6종목의 검색결과를 기대했지만 기존의 2번 수식의 결과만 출력됐습니다.
이 문제를 해결하기 위해 수식을 몇번씩 고쳐보니 2번 수식의 'CountIF(C < ma1, 5)[1] == 5'를 지우니 1번 수식의 검색결과인 컨텍, 비아이매트릭스와 2번 수식의 결과 4종목, 총 6종목이 검색되더군요. 'CountIF(C < ma1, 5)[1] == 5'를 지우면 1번 수식의 검색결과가 나타나지만 2번 수식에 영향이 가는 상황입니다. 또한 'CountIF(C < ma1, 5)[1] == 5'를 'CountIF(C < ma1, 3)[1] == 3' 이와 같이 값을 5미만으로 수정해도 6종목이 검색되지만 왜 5이상은 안되는 걸까요? 2번 수식을 변경했는데 왜 1번 수식의 검색결과에 영향을 미치는 건가요? 문제점과 해결방법을 알려주세요.
2023-11-15
795
글번호 174091
검색