第七部分、数组基本运算函数运算:加,减,乘,除,移位【参数数组为正序,返回数组也为正序,适合做中间变量计算用】
  
- UID
- 2
- 积分
- 2954160
- 威望
- 1427117 布
- 龙e币
- 1527043 刀
- 在线时间
- 13879 小时
- 注册时间
- 2009-12-3
- 最后登录
- 2025-5-13

|
第七部分、数组基本运算函数运算:加,减,乘,除,移位【参数数组为正序,返回数组也为正序,适合做中间变量计算用】
头文件声明变量:- //第七部分 数组基本运算函数(开始)加,减,乘,除,移位【参数数组为正序,返回数组也为正序】
- vector<double>SeriesSummation(vector<double> pc, int num); //数组前NUM项元素加总计算(返回数组前NUM项的和,返回的仍然是数组形式)
- vector<double>SeriesPlusN(vector<double> pc, double num); //数组每一项+N计算(返回所有项+N后的数组,如果N为负值,则为相减)
- vector<double>SeriestimesN(vector<double> pc, double num); //数组每一项乘N计算(返回所有项乘N后的数组)
- vector<double>SeriesDivideN(vector<double> pc, double num); //数组每一项除N计算(返回所有项除N后的数组)
- vector<double>SeriesPlus(vector<double> pc, vector<double> pc2); //pc[i]+pc2[i](返回两个数组相加后的新数组)
- vector<double>SeriesMinus(vector<double> pc, vector<double> pc2); //pc[i]-pc2[i](返回两个数组相减后的新数组)
- vector<double>SeriesTimes(vector<double> pc, vector<double> pc2); //pc[i]*pc2[i](返回两个数组相乘后的新数组)
- vector<double>SeriesDivide(vector<double> pc, vector<double> pc2);//pc[i]/pc2[i](返回两个数组相除后的新数组)
- vector<double>SeriesSelfMinus(vector<double> pc, int num); //数组与自己第前NUM项相减(应用场景:momentum计算类及涉及价格处于涨势或跌势,当前价格与第num个价格相减)
- vector<double>SeriesSelfDivide(vector<double> pc, int num); //数组与自己第前NUM项相除(应用场景:momentum计算类及涉及价格处于涨势或跌势,当前价格与第num个价格相除)
- vector<double>SeriesForwardref(vector<double> pc, int ref); //数组元素往右移ref位,为保证与原来的数组数目一致,要从最新size()-ref个。)
- vector<double>SeriesAbs(vector<double> pc); //数组元素进行绝对值计算
- vector<double>SeriesPowerN(vector<double> pc, int num); //数组元素进行幂函数计算
- vector<double>Seriessquareroot(vector<double> pc); //数组元素进行开平方计算
- vector<double>SeriesReciprocal(vector<double> pc); //数组元素取倒数计算
- vector<double>SeriesNDivide(int num, vector<double> pc); //数值除数组元素各元素计算
- vector<double>SeriesNegation(vector<double> pc); //数组元素取负计算
- vector<double>SeriesNMinus(int num, vector<double> pc); //数组元素分别被N减计算
- //数组基本运算函数(开始)加,减,乘,除,移位【参数数组为正序,返回数组也为正序】
复制代码 |
论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
|
|
|
|
|
|
  
- UID
- 2
- 积分
- 2954160
- 威望
- 1427117 布
- 龙e币
- 1527043 刀
- 在线时间
- 13879 小时
- 注册时间
- 2009-12-3
- 最后登录
- 2025-5-13

|
公式模块增加:- //第七部分 数组基本运算函数(开始)加,减,乘,除,移位【参数数组为正序,返回数组也为正序】
- //数组前NUM项元素加总计算【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesSummation(vector<double> pc, int num)
- {
- vector<double> sumvector;//声明一个存储和的容器变量
- double sum = 0;
- for (size_t i = 0; i < pc.size(); i++)
- {
- if (i == 0)
- {
- sumvector.push_back(pc[i]);;
- }
- else if (i < num) //如果数据数目小于周期要求的最低bar数量
- {
- sum = 0;
- for (size_t j = 0; j < i; j++)
- {
- sum = sum + pc[i - j];//前num个数值相加
- }
- sumvector.push_back(sum); //用简单平均代替并存入容器中
- }
- else //pc数目大于num周期后正常计算方法
- {
- sum = 0;//重置加总变量
- for (size_t j = 0; j < num; j++)
- {
- sum = sum + pc[i - j];//加总从pc[i]往左数num个pc的数值
- }
- sumvector.push_back(sum);
- }
- }
-
- return sumvector;
- }
- //数组所有项元素都乘N(N非0)【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriestimesN(vector<double> pc, double num)
- {
- vector<double>PcTimesN;
- for (size_t i = 0; i < pc.size(); i++)
- {
- PcTimesN.push_back(pc[i] * num);
- }
- return PcTimesN;
- }
- //数组所有项元素都除N(N非0)【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesDivideN(vector<double> pc, double num)
- {
- vector<double>PcDivideN;
- for (size_t i = 0; i < pc.size(); i++)
- {
- PcDivideN.push_back(pc[i] / num);
- }
- return PcDivideN;
- }
- //两个数组的相加函数【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesPlus(vector<double> pc, vector<double> pc2)
- {
- //if (pc.size() != pc2.size())return 0;//两个数组中的元素数量必须得相等,否则无法相加
- vector<double> sumvector;// 声明一个新的数组变量存储和的值
- for (size_t i = 0; i < pc.size(); i++)
- {
- sumvector.push_back(pc[i] + pc2[i]);
- }
- return sumvector;
- }
- //两个数组相减函数【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesMinus(vector<double> pc, vector<double> pc2)
- {
- //if (pc.size() != pc2.size())return 0;//两个数组中的元素数量必须得相等,否则无法相减
- vector<double> minusvector;// 声明一个新的数组变量存储差的值
- for (size_t i = 0; i < pc.size(); i++)
- {
- minusvector.push_back(pc[i] - pc2[i]);
- }
- return minusvector;
- }
- //两个数组内元素相乘【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesTimes(vector<double> pc, vector<double> pc2)
- {
- //if (pc.size() != pc2.size())return 0;//两个数组中的元素数量必须得相等,否则无法相乘
- vector<double> Timesvector;// 声明一个新的数组变量存储积的值
- for (size_t i = 0; i < pc.size(); i++)
- {
- Timesvector.push_back(pc[i] * pc2[i]);
- }
- return Timesvector;
- }
- //两个数组内元素相除【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesDivide(vector<double> pc, vector<double> pc2)
- {
- //if (pc.size() != pc2.size())return 0;//两个数组中的元素数量必须得相等,否则无法相除
- vector<double> Dividevector;// 声明一个新的数组变量存储积的值
- for (size_t i = 0; i < pc.size(); i++)
- {
- if (pc2[i] == 0)//如果被除数为0时处理方法
- {
- if (i == 0)//又是第一项
- {
- Dividevector.push_back(0);//用0代替
- }
- else //其它项
- {
- Dividevector.push_back(Dividevector[i-1]);//用上一个值代替
- }
- }
- else
- {
- Dividevector.push_back(pc[i] / pc2[i]);//正常处理
- }
- }
- return Dividevector;
- }
- //数组与自己第前NUM项相减(应用场景:momentom计算类及涉及价格处于涨势或跌势)【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesSelfMinus(vector<double> pc, int num)
- {
- vector<double>self;
- for (size_t i = 0; i < pc.size(); i++)
- {
- if (i < num)//数据不够时
- {
- self.push_back((int)0);// 用0代替
- }
- else//数据量足够时
- {
- self.push_back(pc[i] - pc[i - num]);
- }
- }
- return self;
- }
- //数组与自己第前NUM项相除(应用场景:momentom计算类及涉及价格处于涨势或跌势)与相减相比此处为比率形式【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesSelfDivide(vector<double> pc, int num)
- {
- vector<double>self;
- for (size_t i = 0; i < pc.size(); i++)
- {
- if (i < num)//数据不够时
- {
- self.push_back((int)0);// 用0代替
- }
- else//数据量足够时
- {
- if (pc[i - num] == 0)//如果[i - num]项数值为0时,即除数为0时处理方法
- {
- self.push_back(pc[i - num - 1]);// 用前一项代替
- }
- else //正常状态下
- {
- self.push_back(pc[i] / pc[i - num]);//正常两个数值相除
- }
- }
- }
- return self;
- }
- //Vctor数组元素往右挪N位【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesForwardref(vector<double> pc, int ref)
- {
- vector<double>newself;
- for (size_t i = 0; i < pc.size(); i++) //因为前ref项已经单独设置为0,为了保证后面使用过程中数组元素数量相同,最新的ref项我们删除不使用
- {
- if (i < ref)//当循环项为小于右移的项数时
- {
- newself.push_back((int)0);//前ref项都设置为0
- }
- else
- {
- newself.push_back(pc[i - ref]);//将pc第i项数据pc[i]存入newself[i+1]项中
- }
- }
- return newself;// 返回新的数组,因为前面加了ref项,后面减了ref项,所以新的数组与原来的数组数量是一致的
- }
- //Vctor数组元素取绝对值【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesAbs(vector<double> pc)
- {
- vector<double>absvevctor;
- for (size_t i = 0; i < pc.size(); i++)
- {
- absvevctor.push_back(abs(pc[i]));
- }
- return absvevctor;
- }
- //Vector幂次方数组计算【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesPowerN(vector<double> pc, int num)
- {
- vector<double>newvector;//声明新变量容器
- for (size_t i = 0; i < pc.size(); i++)
- {
- newvector.push_back(pow(pc[i], num));//pow(x,y)
- }
- return newvector;
- }
- //平方根计算【参数数组为正序,返回数组也为正序】
- vector<double> test::Seriessquareroot(vector<double> pc)
- {
- vector<double>vector1;//中间变量,临时存储数组
- for (size_t i = 0; i < pc.size(); i++)
- {
- vector1.push_back(sqrt(pc[i]));
- }
- return vector1;
- }
- vector<double> test::SeriesReciprocal(vector<double> pc)
- {
- vector<double>newvector;
- for (size_t i = 0; i < pc.size(); i++)
- {
- if (i == 0) //第一个元素代替为pc[0]
- {
- newvector.push_back(pc[i]);
- }
- else //中间元素处理方法
- {
- if (pc[i] == 0)newvector.push_back(newvector[i - 1]);//若是pc[i] = 0 则用前一值(newvector[i-1])代替
- if (pc[i] != 0)newvector.push_back(1 / pc[i]);//若是pc[i] != 0 则 用1除pc[i]值即可
- }
- }
- return newvector;
- }
- //数值除数组元素各元素计算【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesNDivide(int num, vector<double> pc)
- {
- vector<double>newvector;
- for (size_t i = 0; i < pc.size(); i++)
- {
- newvector.push_back(num / pc[i]);
- }
- return newvector;
- }
- //数组元素取负计算【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesNegation(vector<double> pc)
- {
- vector<double>newvector2;
- for (size_t i = 0; i < pc.size(); i++)
- {
- newvector2.push_back(-(pc[i]));
- }
- return newvector2;
- }
- //数组元素分别被N减计算【参数数组为正序,返回数组也为正序】
- vector<double> test::SeriesNMinus(int num, vector<double> pc)
- {
- vector<double>newvector;
- for (size_t i = 0; i < pc.size(); i++)
- {
- newvector.push_back(num - pc[i]);
- }
- return newvector;
- }
- //第七部分 数组基本运算函数(开始)加,减,乘,除,移位【参数数组为正序,返回数组也为正序】
复制代码 |
|
|
|
|
|
|