-
Notifications
You must be signed in to change notification settings - Fork 25
/
FxjFunc.h
219 lines (186 loc) · 7.61 KB
/
FxjFunc.h
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
211
212
213
214
215
216
217
218
219
#ifndef __FXJFUNC_H_INCLUDE
#define __FXJFUNC_H_INCLUDE
/*
///////////////////////////////////////////////////////////////////////////
分析家扩展函数规范V3.10
1.本规范适用于分析家3.10标准版和专业版公式系统.
2.扩展函数用于实现系统函数不能实现的特殊算法.
3.扩展函数用windows 32位动态连接库实现,建议使用Microsoft Visual C++编程.
4.调用时在公式编辑器中写"动态库名称@函数名称"(参数表)即可,例如下面函数可以写为"FXJFUNC@MYCMALOSE"(5)
5.动态连接库名称和函数名称可以自己定义.
6.使用时可以将动态库拷贝到分析家目录下使用.
*/
#ifdef __cplusplus
extern "C"
{
#endif //__cplusplus
///////////////////////////////////////////////////////////////////////////
//分析周期
enum DATA_TYPE
{
TICK_DATA=2, //分笔成交
MIN1_DATA, //1分钟线
MIN5_DATA, //5分钟线
MIN15_DATA, //15分钟线
MIN30_DATA, //30分钟线
MIN60_DATA, //60分钟线
DAY_DATA, //日线
WEEK_DATA, //周线
MONTH_DATA, //月线
MULTI_DATA //多日线
};
///////////////////////////////////////////////////////////////////////////
//基本数据
typedef struct tagSTKDATA
{
time_t m_time; //时间,UCT
float m_fOpen; //开盘
float m_fHigh; //最高
float m_fLow; //最低
float m_fClose; //收盘
float m_fVolume; //成交量
float m_fAmount; //成交额
WORD m_wAdvance; //上涨家数(仅大盘有效)
WORD m_wDecline; //下跌家数(仅大盘有效)
} STKDATA;
////////////////////////////////////////////////////////////////////////////
//扩展数据,用于描述分笔成交数据的买卖盘
typedef union tagSTKDATAEx
{
struct
{
float m_fBuyPrice[3]; //买1--买3价
float m_fBuyVol[3]; //买1--买3量
float m_fSellPrice[3]; //卖1--卖3价
float m_fSellVol[3]; //卖1--卖3量
};
float m_fDataEx[12]; //保留
} STKDATAEx;
/////////////////////////////////////////////////////////////////////////////
/*财务数据顺序(m_pfFinData内容)
序号 内容
0 总股本(万股),
1 国家股,
2 发起人法人股,
3 法人股,
4 B股,
5 H股,
6 流通A股,
7 职工股,
8 A2转配股,
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 净资收益率
*/
/////////////////////////////////////////////////////////////////////////////
//函数数据结构
typedef struct tagCALCINFO
{
const DWORD m_dwSize; //结构大小
const DWORD m_dwVersion; //调用软件版本(V2.10 : 0x210)
const DWORD m_dwSerial; //调用软件序列号
const char* m_strStkLabel; //股票代码
const BOOL m_bIndex; //大盘
const int m_nNumData; //数据数量(pData,pDataEx,pResultBuf数据数量)
const STKDATA* m_pData; //常规数据,注意:当m_nNumData==0时可能为 NULL
const STKDATAEx* m_pDataEx; //扩展数据,分笔成交买卖盘,注意:可能为 NULL
const int m_nParam1Start; //参数1有效位置
const float* m_pfParam1; //调用参数1
const float* m_pfParam2; //调用参数2
const float* m_pfParam3; //调用参数3
const float* m_pfParam4; //调用参数3
float* m_pResultBuf; //结果缓冲区
const DATA_TYPE m_dataType; //数据类型
const float* m_pfFinData; //财务数据
} CALCINFO;
/*
注:
1.函数调用参数由m_pfParam1--m_pfParam4带入,若为NULL则表示该参数无效.
2.当一个参数无效时,则其后的所有参数均无效.
如:m_pfParam2为NULL,则m_pfParam3,m_pfParam4一定为NULL.
3.参数1可以是常数参数或序列数参数,其余参数只能为常数参数.
4.若m_nParam1Start<0, 则参数1为常数参数,参数等于*m_pfParam1;
5.若m_nParam1Start>=0,则参数1为序列数参数,m_pfParam1指向一个浮点型数组,
数组大小为m_nNumData,数据有效范围为m_nParam1Start--m_nNumData.
在时间上m_pData[x] 与 m_pfParam1[x]是一致的
*/
///////////////////////////////////////////////////////////////////////////////////
/* 函数输出
__declspec(dllexport) int xxxxxxxx(CALCINFO* pData); ---------- A
__declspec(dllexport) int xxxxxxxxVAR(CALCINDO* pData); ---------- B
1.函数名称需全部大写.
2.函数必须以上述A,B两种形式之一声明,请用实际函数名称替代xxxxxxxx;
对于C++程序还需包括在 extern "C" { } 括号中.
3.上述形式A用于声明不带参数或全部参数为常数的函数;
形式B用于声明参数1为序列数的函数;两种函数的区别在于后者以VAR结尾.
4.函数计算结果用pData->m_pResultBuf带回.
5.函数返回-1表示错误或全部数据无效,否则返回第一个有效值位置,即:
m_pResultBuf[返回值] -- m_pResultBuf[m_nNumData-1]间为有效值.
6.函数名称长度不能超过15字节,动态连接库文件名不能超过9字节(不包括扩展名),动态库名称不能叫SYSTEM,EXPLORER
7.编译时请请选择1字节对齐
*/
//示例函数,使用时用实际名称替换
__declspec(dllexport) int WINAPI MYMACLOSE(CALCINFO* pData);
__declspec(dllexport) int WINAPI MYMAVAR(CALCINFO* pData);
__declspec(dllexport) int WINAPI MYMACLOSE_CALC_PREV(CALCINFO* pData);
__declspec(dllexport) int WINAPI MYMAVAR_CALC_PREV(CALCINFO* pData);
// added by pp
// 自定义函数
// 大写为可单独调用的函数 小写为不可单独调用的函数
__declspec(dllexport) int WINAPI TT(CALCINFO* pData); // 测试用
__declspec(dllexport) int WINAPI VERSION(CALCINFO* pData); // 版本 如 1.013 1主版本号 01 小版本号 第三位小数 1 alpha(内测版) 2 beta(公测版) 3 standard标准版 4-5标准修正版 9 release最终版
__declspec(dllexport) int WINAPI DATE(CALCINFO* pData); // 发布日期 如20101231 1.013.20101231
__declspec(dllexport) int WINAPI JXZT(CALCINFO* pData); // 均线状态 @since 1.01
__declspec(dllexport) int WINAPI JXYL(CALCINFO* pData); // 均线压力 @since 1.01 返回1-8类均线
__declspec(dllexport) int WINAPI JXZC(CALCINFO* pData); // 均线支撑 @since 1.01
__declspec(dllexport) int WINAPI JXYL2(CALCINFO* pData); // 均线压力 @since 1.02 返回5 13 21 34 55 89 144 233
__declspec(dllexport) int WINAPI JXZC2(CALCINFO* pData); // 均线支撑 @since 1.02
__declspec(dllexport) int WINAPI kxian(CALCINFO* pData); // 初始化K线 分型 以及其他数据 @since 1.01 @update 1.02
__declspec(dllexport) int WINAPI kxg(CALCINFO* pData); // 缠K高点 @since 1.01
__declspec(dllexport) int WINAPI kxd(CALCINFO* pData); // 缠K低点 @since 1.01
__declspec(dllexport) int WINAPI kxfx(CALCINFO* pData); // K线方向 @since 1.01
__declspec(dllexport) int WINAPI bi(CALCINFO* pData); // 笔 @since 1.01 @update 1.02
__declspec(dllexport) int WINAPI bilast(CALCINFO* pData); // 距离上一笔结束的周期 @since 1.02
__declspec(dllexport) int WINAPI bigglast(CALCINFO* pData); // 距离上第1个笔高点的周期 @since 1.02
__declspec(dllexport) int WINAPI biddlast(CALCINFO* pData); // 距离上第1个笔低点的周期 @since 1.02
__declspec(dllexport) int WINAPI duan(CALCINFO* pData); // 段 @since 1.02
__declspec(dllexport) int WINAPI duanlast(CALCINFO* pData); // 距离上一段结束的周期 @since 1.02
__declspec(dllexport) int WINAPI duangglast(CALCINFO* pData); // 距离上第1个段高点的周期 @since 1.02
__declspec(dllexport) int WINAPI duanddlast(CALCINFO* pData); // 距离上第1个段低点的周期 @since 1.02
__declspec(dllexport) int WINAPI zs(CALCINFO* pData); // 走势中枢 @since 1.02
__declspec(dllexport) int WINAPI zszg(CALCINFO* pData); // 中枢ZG @since 1.02
__declspec(dllexport) int WINAPI zszd(CALCINFO* pData); // 中枢ZD @since 1.02
__declspec(dllexport) int WINAPI zsgg(CALCINFO* pData); // 中枢GG @since 1.02
__declspec(dllexport) int WINAPI zsdd(CALCINFO* pData); // 中枢DD @since 1.02
__declspec(dllexport) int WINAPI zszz(CALCINFO* pData); // 中枢中轴(震荡监视器) @since 1.02
__declspec(dllexport) int WINAPI zskslast(CALCINFO* pData); // 距离上一个中枢开始的周期 @since 1.02
__declspec(dllexport) int WINAPI zsjslast(CALCINFO* pData); // 距离上一个中枢结束的周期 @since 1.02
#ifdef __cplusplus
}
#endif //__cplusplus
#endif //__FXJFUNC_H_INCLUDE