-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathbreadth_up_median.txt
212 lines (162 loc) · 6.12 KB
/
breadth_up_median.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
{ Search Tag: WA-Breadth - Custom }
{
This indicator plots the number of symbols, from a user-specified list, that are
trading above their moving average. The moving average length is a user input.
由于部分代码变动,在此处理Dow的变动
}
{ the code will make use of classes in these namespaces }
using tsdata.common ;
using tsdata.marketdata ;
using elsystem ;
using elsystem.collections ;
inputs:
string SymbolList( "DIS,DOW,VZ,MMM,PFE,NKE,WMT,MSFT,UNH,KO,CVX,V,IBM,PG,JPM,TRV,HD,GS,AAPL,JNJ,CAT,WBA,MCD,CSCO,INTC,MRK,XOM,UTX,BA,AXP")
[DisplayName = "SymbolList", Tooltip = "Enter a list of symbols, separated by commas."],
int MALength( 20 ) [DisplayName = "MALength", Tooltip =
"Moving Average Length. Enter the number of bars over which to calculate each symbol's moving average."] ;
variables:
intrabarpersist bool PSPsReady( false ),
int NumAbove( 0 ),
TokenList ListOfSymbols( NULL ),
Vector VectOfPSPs( NULL ),
PriceSeriesProvider PSP( NULL ) ;
Array: MyArray[30](0.0),Array_CurC[30](0.0),Array_YesC[30](0.0);
{ initialization method }
method void Init( Object sender, InitializedEventArgs args )
variables: int PSPCount, int Counter ;
begin
{ this indicator does not work with tick/volume bars or advanced bars }
if BarType = 0 or ( BarType > 4 and BarType <> 14 ) then
throw Exception.Create( Name + !( " cannot be used with tick bars, " +
"volume bars, or advanced bars." ) ) ;
VectOfPSPs = new Vector ;
ListOfSymbols = new TokenList ;
{ add the symbols specified in the input SymbolList to the TokenList }
ListOfSymbols.Add( SymbolList ) ;
{ create a PriceSeriesProvider (PSP) for each symbol in the TokenList and place
the PSP's into a Vector }
for Counter = 0 to ListOfSymbols.Count - 1
begin
PSP = new PriceSeriesProvider ;
PSP.Symbol = ListOfSymbols.Item[Counter] ;
//If DATE < 1190420 AND PSP.Symbol = "DOW" THEN BEGIN
//PSP.Symbol = "DWDP";
//END;
If DATE < 1180720 AND PSP.Symbol = "WBA" THEN BEGIN
PSP.Symbol = "GE";
END;
AlignPSP( PSP ) ;
PSP.Realtime = true ;
PSP.Load = true ;
PSPCount = PSP.Count ; { force the PSP to load }
VectOfPSPs.push_back( PSP ) ;
end ;
end ;
{ this method is used to align a PriceSeriesProvider to the data stream settings to
which the indicator is applied }
method void AlignPSP( PriceSeriesProvider PSPToAlign )
begin
{ currently, this indicator does not work when using Natural Hours for bar
building }
if AnalysisTechnique.DataStreams.DefaultStream.UsesNaturalHours then
throw Exception.Create( Name + !( " cannot be used with natural " +
"hours selected." ) ) ;
{ align the PSP bar interval and range; load additional data in case illiquid
symbols are used }
PSPToAlign.Interval = DataInterval.FromCurrentSymbolData( BarType, BarInterval ) ;
PSPToAlign.Range.FirstDate = DateTime.FromELDateAndTime( Date[MALength + 5],
Time[MALength + 5] ) - TimeSpan.Create( 4, 0, 0, 0 ) ;
{ align the PSP time zone, session, and natural hours }
PSPToAlign.TimeZone = ConvertTimeZone() ; { see commentary for the
ConvertTimeZone method }
PSPToAlign.SessionName =
AnalysisTechnique.DataStreams.DefaultStream.SessionName ;
end ;
{
the data stream TimeZone and the TimeZone used in DataProviders are from
different classes; this method is used to provide the cross-reference between the
two so that the DataProvider TimeZone can be set to the same TimeZone as the
data stream to which this indicator is applied
}
method tsdata.common.TimeZone ConvertTimeZone()
variables: elsystem.TimeZone ChartTimeZone ;
begin
ChartTimeZone = AnalysisTechnique.DataStreams.DefaultStream.TimeZone ;
switch ( ChartTimeZone )
begin
case elsystem.TimeZone.Exchange:
return tsdata.common.TimeZone.Exchange ;
case elsystem.TimeZone.Local:
return tsdata.common.TimeZone.Local ;
end ;
end ;
method bool AllPSPsReadyToCalculate()
variables: int Counter, bool AllCountsOK ;
begin
if VectOfPSPs.Count > 0 then { at least one PSP is in the Vector }
begin
AllCountsOK = true ;
{ loop through all PSP's to ensure enough bars are loaded for the
calculations }
for Counter = 0 to VectOfPSPs.Count - 1
begin
PSP = VectOfPSPs.Items[Counter] astype PriceSeriesProvider ;
if PSP.Close.Count <= MALength then
begin
AllCountsOK = false ;
break ;
end ;
end ;
end
else { Vector does not contain any PSP's }
begin
AllCountsOK = false ;
end ;
return AllCountsOK ;
end ;
{
calculate a moving average of each symbol and compare the symbol's current price
to the moving average; count the number of symbols that are trading above their
moving average
}
method int GetNumberAboveMA()
variables: int NumberAboveMA, int Counter ;
begin
NumberAboveMA = 0 ;
for Counter = 0 to VectOfPSPs.Count - 1
begin
PSP = VectOfPSPs.Items[Counter] astype PriceSeriesProvider ;
If PSP.Close[1] <> 0 then begin
If time = 0935 then begin
Array_CurC[Counter+1] = PSP.Close[0];
Array_YesC[Counter+1] = PSP.Close[1] ;
//Array_YesC[Counter+1] = PSP.CloseD[1] ; 由于结算价格不同于前一天的15分钟最后一根K线,所以我的指标有误差,需要找到一个方法获得前一天的收盘价
MyArray[Counter+1] = (Array_CurC[Counter+1] - Array_YesC[Counter+1])/Array_YesC[Counter+1] * 100 ;
end
Else begin
Array_CurC[Counter+1] = PSP.Close[0];
If Array_YesC[Counter+1] <> 0 then begin
MyArray[Counter+1] = (Array_CurC[Counter+1]- Array_YesC[Counter+1])/Array_YesC[Counter+1] * 100 ;
end;
//MyArray[Counter+1] = (PSP.Close[0] - PSP.Close[1+(Time - 0935)/5])/PSP.Close[1+(Time - 0935)/5] * 100 ;
end;
end;
if PSP.Close[0] > Average( PSP.Close, MALength ) then
NumberAboveMA += 1 ;
end ;
return NumberAboveMA ;
end ;
once ( AllPSPsReadyToCalculate() )
begin
PSPsReady = true ;
end ;
if PSPsReady then { ensure enough PSP bars are available for calculations }
begin
NumAbove = GetNumberAboveMA() ;
Value1 = MedianArray(MyArray,30);
Plot1( Value1, !( "change median" ) ) ;
Plot2( 0, !( "ZeroLine" ) ) ;
end ;
If time = 0935 then begin
SetPlotColor[1]( 1, Transparent ) ;
end;