예스스탁
예스스탁 답변
2023-12-07 13:02:51
안녕하세요
예스스탁입니다.
input : 비차익비중(10), 외인선물비중(30), 외인코스피비중(15);
Input : 개인옵션비중(15), 호가잔량비중(30), 미결가중치부여1(1);
Input : 원웨이점수(40);
Input : 당일분만표시1(1),횡보장표시폭(70);
var : 비차익_배점계수(0), 외인선물_배점계수(0), 외인코피_배점계수(0);
var : 개인옵션_배점계수(0), 호가잔량_배점계수(0);
var : 비차익(0), 외인선물(0), 외인코피(0), 개인옵션(0), 호가잔량(0);
var : 미결증감(0), 미결가중치(0) ;
비차익 = data9(C);
외인선물 = data10(C);
외인코피 = data11(C);
개인옵션 = data12(C);
호가잔량 = data1(bids)-data1(asks);
미결증감 = data1(dayoi)-data1(dayoi[1]);
#=================#
#===================#
비차익_배점계수 = 150000 / 비차익비중; // 억단위로 환산
외인선물_배점계수 = 4000 / 외인선물비중;
외인코피_배점계수 = 2500 / 외인코스피비중;
개인옵션_배점계수 = 40 / 개인옵션비중;
호가잔량_배점계수 = 8000 / 호가잔량비중;
//--미결은 전체 비중에 포함하지 않고 가중치만 부여
if 미결증감 > 0 and 미결가중치부여1 == 1 then
미결가중치 = 1 + ((미결증감 / 400) / 100); // 8000개일 경우 20%
else 미결가중치 = 1;
#===================#
//--------점수계산
var: 비차익점수(0), 외인선물점수(0), 외인코피점수(0);
var: 개인옵션점수(0), 호가잔량점수(0), 점수(0), 점수2(0);
//비차익점수 = 비차익 / 15000; //백만원 단위를 억으로 환산
//외인선물점수 = 외인선물 / 133.3;
//외인코피점수 = 외인코피 / 166.7;
//개인옵션점수 = -개인옵션 / 2.7;
//호가잔량점수 = 호가잔량 / 266.7;
비차익점수 = 비차익 / 비차익_배점계수;
외인선물점수 = 외인선물 / 외인선물_배점계수;
외인코피점수 = 외인코피 / 외인코피_배점계수;
개인옵션점수 = -개인옵션 / 개인옵션_배점계수;
호가잔량점수 = 호가잔량 / 호가잔량_배점계수;
점수 = ( 비차익점수 + 외인선물점수 + 외인코피점수 + 개인옵션점수 + 호가잔량점수 ) * 미결가중치 ;
#============================#
#==========================================#
Input : Length(13),UpLevel(70),DnLevel(30), NxtYn(0);
var : oUpBand6(0),oDnBand6(0),MidLevel(0),oMidLine6(0);
Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),MidLev(0);
var : idx(0,Data1);
#==========================================#
Var : CC6(0) ;
if IsNan(점수) == False Then
{
idx = idx+1;
CC6 = 점수;
#==========================================#
If idx == Length Then
Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1
Begin
UpAmt = CC6[Counter] - CC6[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else
IF idx > Length Then
Begin
UpAmt = CC6[0] - CC6[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
Value1 = 100 * UpAvg / (UpAvg + DownAvg);
Else
Value1 = 0;
If nxtYn == 1 Then // 다음 봉 여부가 1일 경우
{
If Value1 > UpLevel Then // 상단밴드
oUpBand6 = (((UpLevel - 100) / UpLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oUpBand6 = ((UpLevel / (100 - UpLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
If Value1 > DnLevel Then // 하단밴드
oDnBand6 = (((DnLevel - 100) / DnLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oDnBand6 = ((DnLevel / (100 - DnLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
MidLevel = (UpLevel + DnLevel) / 2; // 중간라인
If Value1 > MidLevel Then
oMidLine6 = (((MidLevel - 100) / MidLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oMidline6 = ((MidLevel / (100 - MidLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
}
Else
{
If Value1[1] > UpLevel Then
oUpBand6 = (((UpLevel - 100) / UpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oUpBand6 = ((UpLevel / (100 - UpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
If Value1[1] > DnLevel Then
oDnBand6 = (((DnLevel - 100) / DnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oDnBand6 = ((DnLevel / (100 - DnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
MidLevel = (UpLevel + DnLevel) / 2;
If Value1[1] > MidLevel Then
oMidLine6 = (((MidLevel - 100) / MidLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oMidline6 = ((MidLevel / (100 - MidLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
}
#=======
Plot5(oUpBand6);
Plot6(oDnBand6);
}
즐거운 하루되세요
> 성공예견 님이 쓴 글입니다.
> 제목 : 지표문의
> 11아래는 점수를 밴드로 구성 했는데요
지표가 표시가 안돼요
수정 좀 해주세요
nput : 비차익비중(10), 외인선물비중(30), 외인코스피비중(15);
Input : 개인옵션비중(15), 호가잔량비중(30), 미결가중치부여1(1);
Input : 원웨이점수(40);
Input : 당일분만표시1(1),횡보장표시폭(70);
var : 비차익_배점계수(0), 외인선물_배점계수(0), 외인코피_배점계수(0);
var : 개인옵션_배점계수(0), 호가잔량_배점계수(0);
var : 비차익(0), 외인선물(0), 외인코피(0), 개인옵션(0), 호가잔량(0);
var : 미결증감(0), 미결가중치(0) ;
비차익 = data9(C);
외인선물 = data10(C);
외인코피 = data11(C);
개인옵션 = data12(C);
호가잔량 = data1(bids)-data1(asks);
미결증감 = data1(dayoi)-data1(dayoi[1]);
#=================#
#===================#
비차익_배점계수 = 150000 / 비차익비중; // 억단위로 환산
외인선물_배점계수 = 4000 / 외인선물비중;
외인코피_배점계수 = 2500 / 외인코스피비중;
개인옵션_배점계수 = 40 / 개인옵션비중;
호가잔량_배점계수 = 8000 / 호가잔량비중;
//--미결은 전체 비중에 포함하지 않고 가중치만 부여
if 미결증감 > 0 and 미결가중치부여1 == 1 then
미결가중치 = 1 + ((미결증감 / 400) / 100); // 8000개일 경우 20%
else 미결가중치 = 1;
#===================#
//--------점수계산
var: 비차익점수(0), 외인선물점수(0), 외인코피점수(0);
var: 개인옵션점수(0), 호가잔량점수(0), 점수(0), 점수2(0);
//비차익점수 = 비차익 / 15000; //백만원 단위를 억으로 환산
//외인선물점수 = 외인선물 / 133.3;
//외인코피점수 = 외인코피 / 166.7;
//개인옵션점수 = -개인옵션 / 2.7;
//호가잔량점수 = 호가잔량 / 266.7;
비차익점수 = 비차익 / 비차익_배점계수;
외인선물점수 = 외인선물 / 외인선물_배점계수;
외인코피점수 = 외인코피 / 외인코피_배점계수;
개인옵션점수 = -개인옵션 / 개인옵션_배점계수;
호가잔량점수 = 호가잔량 / 호가잔량_배점계수;
점수 = ( 비차익점수 + 외인선물점수 + 외인코피점수 + 개인옵션점수 + 호가잔량점수 ) * 미결가중치 ;
#============================#
#==========================================#
Input : Length(13),UpLevel(70),DnLevel(30), NxtYn(0);
var : oUpBand6(0),oDnBand6(0),MidLevel(0),oMidLine6(0);
Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),MidLev(0);
#==========================================#
Var : CC6(0) ;
CC6 = 점수;
#==========================================#
If CurrentBar == 1 and Length > 0 Then
Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1
Begin
UpAmt = CC6[Counter] - CC6[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else
IF CurrentBar > 1 AND Length > 0 Then {
Begin
UpAmt = CC6[0] - CC6[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
Value1 = 100 * UpAvg / (UpAvg + DownAvg);
Else
Value1 = 0;
If nxtYn == 1 Then // 다음 봉 여부가 1일 경우
{
If Value1 > UpLevel Then // 상단밴드
oUpBand6 = (((UpLevel - 100) / UpLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oUpBand6 = ((UpLevel / (100 - UpLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
If Value1 > DnLevel Then // 하단밴드
oDnBand6 = (((DnLevel - 100) / DnLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oDnBand6 = ((DnLevel / (100 - DnLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
MidLevel = (UpLevel + DnLevel) / 2; // 중간라인
If Value1 > MidLevel Then
oMidLine6 = (((MidLevel - 100) / MidLevel * UpAvg) + DownAvg) * (Length - 1) + CC6;
Else
oMidline6 = ((MidLevel / (100 - MidLevel) * DownAvg) - UpAvg) * (Length - 1) + CC6;
}
Else
{
If Value1[1] > UpLevel Then
oUpBand6 = (((UpLevel - 100) / UpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oUpBand6 = ((UpLevel / (100 - UpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
If Value1[1] > DnLevel Then
oDnBand6 = (((DnLevel - 100) / DnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oDnBand6 = ((DnLevel / (100 - DnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
MidLevel = (UpLevel + DnLevel) / 2;
If Value1[1] > MidLevel Then
oMidLine6 = (((MidLevel - 100) / MidLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC6[1];
Else
oMidline6 = ((MidLevel / (100 - MidLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC6[1];
}
}
#=======
Plot5(oUpBand6);
Plot6(oDnBand6);
2.그럼 즐거운 하루되세요