代码拉取完成,页面将自动刷新
同步操作将从 mywildquant/ChanlunX 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#include <vector>
#include "Duan.h"
std::vector<float> Duan1(int nCount, std::vector<float> pIn, std::vector<float> pHigh, std::vector<float> pLow)
{
std::vector<float> pOut(nCount);
int nState = 0;
int nLastD = 0; // 前一个向下线段的底
int nLastG = 0; // 前一个向上线段的顶
float fTop0 = 0;
float fTop1 = 0;
float fTop2 = 0;
float fBot0 = 0;
float fBot1 = 0;
float fBot2 = 0;
for (int i = 0; i < nCount; i++)
{
if (pIn[i] == 1)
{
fTop1 = fTop2;
fTop2 = pHigh[i];
}
else if (pIn[i] == -1)
{
fBot1 = fBot2;
fBot2 = pLow[i];
}
if (nState == 0)
{
if (pIn[i] == 1)
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
fTop0 = 0;
fBot0 = 0;
}
else if (pIn[i] == -1)
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
fTop0 = 0;
fBot0 = 0;
}
}
else if (nState == 1) // 向上线段运行中
{
if (pIn[i] == 1) // 遇到高点
{
if (pHigh[i] > pHigh[nLastG]) // 比线段最高点还高,高点后移
{
pOut[nLastG] = 0;
nLastG = i;
pOut[nLastG] = 1;
fTop0 = 0;
fBot0 = 0;
}
}
else if (pIn[i] == -1) // 遇到低点
{
if (pLow[i] < pLow[nLastD]) // 低点比向上线段最低点还低了,当一段处理,也是终结。
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
fTop0 = 0;
fBot0 = 0;
}
else if (fTop1 > 0 && fTop2 > 0 && fBot1 > 0 && fBot2 > 0 && fTop2 < fTop1 && fBot2 < fBot1) // 向上线段终结
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
fTop0 = 0;
fBot0 = 0;
}
else
{
if (fBot0 == 0)
{
fBot0 = pLow[i];
}
else if (pLow[i] < fBot0) // 向上线段终结
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
fTop0 = 0;
fBot0 = 0;
}
}
}
}
else if (nState == -1) // 向下线段运行中
{
if (pIn[i] == -1) // 遇到低点
{
if (pLow[i] < pLow[nLastD]) // 比线段最低点还低,低点后移
{
pOut[nLastD] = 0;
nLastD = i;
pOut[nLastD] = -1;
fTop0 = 0;
fBot0 = 0;
}
}
else if (pIn[i] == 1) // 遇到高点
{
if (pHigh[i] > pHigh[nLastG]) // 高点比向下线段最高点还高了,当一段处理,也是终结。
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
fTop0 = 0;
fBot0 = 0;
}
else if (fTop1 > 0 && fTop2 > 0 && fBot1 > 0 && fBot2 > 0 && fTop2 > fTop1 && fBot2 > fBot1) // 向下线段终结
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
fTop0 = 0;
fBot0 = 0;
}
else
{
if (fTop0 == 0)
{
fTop0 = pHigh[i];
}
else if (pHigh[i] > fTop0) // 向下线段终结
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
fTop0 = 0;
fBot0 = 0;
}
}
}
}
}
return pOut;
}
std::vector<float> Duan2(int nCount, std::vector<float> pIn, std::vector<float> pHigh, std::vector<float> pLow)
{
std::vector<float> pOut(nCount);
int nState = 0;
int nLastD = 0; // 前一个向下线段的底
int nLastG = 0; // 前一个向上线段的顶
float fTop1 = 0;
float fTop2 = 0;
float fBot1 = 0;
float fBot2 = 0;
for (int i = 0; i < nCount; i++)
{
if (pIn[i] == 1)
{
fTop1 = fTop2;
fTop2 = pHigh[i];
}
else if (pIn[i] == -1)
{
fBot1 = fBot2;
fBot2 = pLow[i];
}
if (nState == 0)
{
if (pIn[i] == 1)
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
}
else if (pIn[i] == -1)
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
}
}
else if (nState == 1) // 向上线段运行中
{
if (pIn[i] == 1) // 遇到高点
{
if (pHigh[i] > pHigh[nLastG]) // 比线段最高点还高,高点后移
{
pOut[nLastG] = 0;
nLastG = i;
pOut[nLastG] = 1;
}
}
else if (pIn[i] == -1) // 遇到低点
{
if (pLow[i] < pLow[nLastD]) // 低点比向上线段最低点还低了,当一段处理,也是终结。
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
}
else if (fTop1 > 0 && fTop2 > 0 && fBot1 > 0 && fBot2 > 0 && fTop2 < fTop1 && fBot2 < fBot1) // 向上线段终结
{
nState = -1;
nLastD = i;
pOut[nLastD] = -1;
}
}
}
else if (nState == -1) // 向下线段运行中
{
if (pIn[i] == -1) // 遇到低点
{
if (pLow[i] < pLow[nLastD]) // 比线段最低点还低,低点后移
{
pOut[nLastD] = 0;
nLastD = i;
pOut[nLastD] = -1;
}
}
else if (pIn[i] == 1) // 遇到高点
{
if (pHigh[i] > pHigh[nLastG]) // 高点比向下线段最高点还高了,当一段处理,也是终结。
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
}
else if (fTop1 > 0 && fTop2 > 0 && fBot1 > 0 && fBot2 > 0 && fTop2 > fTop1 && fBot2 > fBot1) // 向下线段终结
{
nState = 1;
nLastG = i;
pOut[nLastG] = 1;
}
}
}
}
return pOut;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。