示例#1
0
        public override bool Matched(ExpectData <TimeSerialData> data, out int MatchCnt)
        {
            ExpectList <TimeSerialData> el = new ExpectList <TimeSerialData>();

            el.Add(data);
            MatchCnt = 0;
            return(Matched(el, out MatchCnt, false));
        }
示例#2
0
        /// <summary>
        /// 机器学习-下期位移
        /// </summary>
        /// <param name="ReviewCnt">计算数据长度</param>
        /// <param name="TrainCnt">训练数据长度</param>
        /// <returns></returns>
        public override Dictionary <string, double> getAllShiftCnt(int ReviewCnt, int TrainCnt)
        {
            ExpectData <TimeSerialData> ed = orgData.LastData;
            string lastExpectId            = long.Parse(ed.Expect).ToString();

            if (orgData.Count < ReviewCnt + TrainCnt + 1)
            {
                return(null);
            }
            int[,] CurrTrainSet  = new int[10, TrainCnt];
            int[,] CurrReviewSet = new int[10, ReviewCnt];
            ////if (!LastReviewShiftDistr.ContainsKey(lastExpectId))
            ////{

            ////    //LastReviewShiftDistr
            ////}
            return(null);
        }
示例#3
0
        public override List <Dictionary <int, string> > getNoDispNums(int reviewCnt)
        {
            List <Dictionary <int, string> > ret = new List <Dictionary <int, string> >();
            int    lastId    = data.Count - 1;
            string RestModel = "1234567890";

            for (int i = 0; i < Math.Min(reviewCnt, data.Count); i++)
            {
                ExpectData currExpect             = data[lastId - i].CopyTo <ExpectData>();
                Dictionary <int, string> lastData = null;
                Dictionary <int, string> newData  = new Dictionary <int, string>();
                if (i > 0)
                {
                    lastData = ret[i - 1];
                }
                for (int j = 0; j < 10; j++)
                {
                    string carNo      = currExpect.ValueList[j];
                    int    carId      = int.Parse(carNo);
                    string LastString = RestModel;
                    if (lastData != null)
                    {
                        LastString = lastData[carId];//取得最后一次的字符串
                    }
                    string strNo = string.Format("{0}", (j + 1) % 10);
                    LastString = LastString.Replace(strNo, "");
                    newData.Add(carId, LastString);
                }
                ret.Add(newData);
            }
            List <Dictionary <int, string> > reSortRet = new List <Dictionary <int, string> >();

            for (int i = 0; i < 10; i++)
            {
                Dictionary <int, string> tmp = new Dictionary <int, string>();
                for (int j = 0; j < ret.Count; j++)
                {
                    tmp.Add(j, ret[j][i]);
                }
                reSortRet.Add(tmp);
            }

            return(reSortRet);
        }
示例#4
0
        protected virtual List <Dictionary <int, string> > getNoDispCars(int reviewCnt)
        {
            List <Dictionary <int, string> > ret = new List <Dictionary <int, string> >();
            int    lastId    = data.Count - 1;
            string RestModel = "1234567890";

            for (int i = 0; i < Math.Min(reviewCnt, data.Count); i++)
            {
                ExpectData currExpect             = data[lastId - i];//  data[lastId - i].CopyTo<ExpectData>();
                Dictionary <int, string> lastData = null;
                Dictionary <int, string> newData  = new Dictionary <int, string>();
                if (i > 0)
                {
                    lastData = ret[i - 1];
                }
                for (int j = 0; j < 10; j++)
                {
                    string LastString = RestModel;
                    if (lastData != null)
                    {
                        LastString = lastData[j];//取得最后一次的字符串
                    }
                    LastString = LastString.Replace(currExpect.ValueList[j], "");
                    newData.Add(j, LastString);
                }
                ret.Add(newData);
            }
            List <Dictionary <int, string> > reSortRet = new List <Dictionary <int, string> >();

            for (int i = 0; i < 10; i++)
            {
                Dictionary <int, string> tmp = new Dictionary <int, string>();
                for (int j = 0; j < ret.Count; j++)
                {
                    tmp.Add(j, ret[j][i]);
                }
                reSortRet.Add(tmp);
            }

            return(reSortRet);
        }
示例#5
0
        public new ExpectData this[int i]
        {
            get
            {
                ExpectData ret = new ExpectData();
                ret.OpenCode = base[i].OpenCode;
                ret.OpenTime = base[i].OpenTime;
                ret.Expect   = base[i].Expect;
                return(ret);

                return(base[i]  as ExpectData);

                return(base[i].CopyTo <ExpectData>());
            }
            set
            {
                if (value == null)
                {
                    return;
                }
                base[i] = value.CopyTo <ExpectData>();
            }
        }
示例#6
0
        bool Match(ExpectData <TimeSerialData> data, out int MatchCnt)
        {
            MatchCnt = 0;
            string[] strOrgArr = data.OpenCode.Split(',');
            string   strRes    = CombinGenerator.ResortNumString(data.OpenCode, ",");

            foreach (ChanceItem ci in this.SubItems)
            {
                CombinClass container = null;
                string[]    strCiArr  = null;
                if (ci.betChipCnt <= SelectNums)
                {
                    strCiArr = new string[ci.betChipCnt];
                    Array.Copy(strOrgArr, strCiArr, ci.betChipCnt);
                }
                switch (ci.betType)
                {
                case CombinBetType.Permut:
                {
                    if (string.Join(",", strCiArr) == ci.betCode)        //未排序的数组和投注串完全相等
                    {
                        if (this.PermutTypebaseodds.ContainsKey(ci.betChipCnt - 1))
                        {
                            MatchCnt += PermutTypebaseodds[ci.betChipCnt - 1];
                            //break;
                        }
                        else        //找不到,返回基本倍数
                        {
                            MatchCnt += 2;
                        }
                    }

                    break;
                }

                case CombinBetType.Combin:
                {
                    string[] strSArr = CombinGenerator.ResortNumString(strCiArr);                      // 获取前N位排序好的中奖号码
                    if (string.Join(",", strSArr) == CombinGenerator.ResortNumString(ci.betCode, ",")) //如果排序好的前N位中奖串等于重排后的投注串,命中
                    {
                        if (this.CombinTypeChipsBaseOdds.ContainsKey(ci.betChipCnt - 1))
                        {
                            MatchCnt += CombinTypeChipsBaseOdds[ci.betChipCnt - 1];
                            //break;
                        }
                        else        //找不到,返回基本倍数
                        {
                            MatchCnt += 2;
                        }
                    }
                    break;
                }

                case CombinBetType.All:
                default:
                {
                    int tn = ci.betChipCnt + 1;                              //一定要加1,是标志基础
                    if (ci.betChipCnt > SelectNums)                          //如果大于选择码
                    {
                        container = new CombinClass(ci.betCode, SelectNums); //找出N码选出数目的所有组合
                        if (container.Contains(strRes))                      //命中
                        {
                            if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                            {
                                MatchCnt += AllTypeChipsBaseOdds[tn];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }
                    }
                    else
                    {
                        container = new CombinClass(strRes, ci.betChipCnt);        //中奖结果的C(S,N)组合
                        if (container.Contains(ci.betCode))
                        {
                            if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                            {
                                MatchCnt += AllTypeChipsBaseOdds[tn];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }
                    }
                    break;
                }
                }
                if (ci.betChipCnt >= SelectNums && MatchCnt > 0)//只要有一个子长机会命中,就不再检查其他子机会
                {
                    break;
                }
            }
            if (MatchCnt > 0)
            {
                return(true);
            }
            return(false);
        }
示例#7
0
        public override bool Matched(ExpectList <TimeSerialData> el, out int MatchCnt, bool getRev)
        {
            //ExpectData data = el.LastData;
            if (ChanceCode == null)//停止
            {
                MatchCnt = 0;
                return(true);
            }
            string[] strArr = ChanceCode.Split('+');
            MatchCnt = 0;
            int begid = -1;   //默认为0,多期再去寻找起点

            if (el.Count > 1) //多期考虑
            {
                if (long.Parse(this.ExpectCode) < long.Parse(el.FirstData.Expect))
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会早于数据以前,无论是否中奖,立即关闭!");
                    return(true);
                }
                begid = el.IndexOf(this.ExpectCode);
                if (begid < 0)
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会不在数据中,无论是否中奖,立即关闭!");
                    return(true);
                }
            }
            //////ExpectData inputEd = el[begid];
            //////Log("计算服务", "获取到期号信息", string.Format("expect:{0};openCode:{1}",inputEd.Expect,inputEd.OpenCode));
            if (el.Count == 1)//只匹配一期
            {
                int ei = el.Count == 1?el.Count - 1:begid + 1;
                ExpectData <TimeSerialData> data = el[ei];
                return(Match(data, out MatchCnt));

                string[] strOrgArr = data.OpenCode.Split(',');
                string   strRes    = CombinGenerator.ResortNumString(data.OpenCode, ",");
                foreach (ChanceItem ci in this.SubItems)
                {
                    CombinClass container = null;
                    string[]    strCiArr  = null;
                    if (ci.betChipCnt <= SelectNums)
                    {
                        strCiArr = new string[ci.betChipCnt];
                        Array.Copy(strOrgArr, strCiArr, ci.betChipCnt);
                    }
                    switch (ci.betType)
                    {
                    case CombinBetType.Permut:
                    {
                        if (string.Join(",", strCiArr) == ci.betCode)       //未排序的数组和投注串完全相等
                        {
                            if (this.PermutTypebaseodds.ContainsKey(ci.betChipCnt - 1))
                            {
                                MatchCnt += PermutTypebaseodds[ci.betChipCnt - 1];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }

                        break;
                    }

                    case CombinBetType.Combin:
                    {
                        string[] strSArr = CombinGenerator.ResortNumString(strCiArr);                      // 获取前N位排序好的中奖号码
                        if (string.Join(",", strSArr) == CombinGenerator.ResortNumString(ci.betCode, ",")) //如果排序好的前N位中奖串等于重排后的投注串,命中
                        {
                            if (this.CombinTypeChipsBaseOdds.ContainsKey(ci.betChipCnt - 1))
                            {
                                MatchCnt += CombinTypeChipsBaseOdds[ci.betChipCnt - 1];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }
                        break;
                    }

                    case CombinBetType.All:
                    default:
                    {
                        int tn = ci.betChipCnt + 1;                              //一定要加1,是标志基础
                        if (ci.betChipCnt > SelectNums)                          //如果大于选择码
                        {
                            container = new CombinClass(ci.betCode, SelectNums); //找出N码选出数目的所有组合
                            if (container.Contains(strRes))                      //命中
                            {
                                if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                                {
                                    MatchCnt += AllTypeChipsBaseOdds[tn];
                                    //break;
                                }
                                else        //找不到,返回基本倍数
                                {
                                    MatchCnt += 2;
                                }
                            }
                        }
                        else
                        {
                            container = new CombinClass(strRes, ci.betChipCnt);        //中奖结果的C(S,N)组合
                            if (container.Contains(ci.betCode))
                            {
                                if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                                {
                                    MatchCnt += AllTypeChipsBaseOdds[tn];
                                    //break;
                                }
                                else        //找不到,返回基本倍数
                                {
                                    MatchCnt += 2;
                                }
                            }
                        }
                        break;
                    }
                    }
                    if (ci.betChipCnt >= SelectNums && MatchCnt > 0)//只要有一个子长机会命中,就不再检查其他子机会
                    {
                        break;
                    }
                }
            }
            else
            {
                for (int i = begid + 1; i < el.Count; i++)//中途任何一次匹配都干掉
                {
                    ExpectData <TimeSerialData> data = el[i];
                    bool suc = Match(data, out MatchCnt);
                    if (suc)
                    {
                        break;
                    }
                }
            }
            if (MatchCnt > 0)
            {
                return(true);
            }
            return(false);
        }
示例#8
0
 public ExpectData GetExpectData <T>(ExpectData <T> data) where T : TimeSerialData
 {
     return(ConvertionExtensions.Clone(data) as ExpectData);
 }
示例#9
0
        DataTable getCombMatchMetrix(int period, string strType, int N)
        {
            DataTable dt = new DataTable();

            if (orgData.Count < period)//数据长度必须要不小于期数
            {
                return(null);
            }
            List <string> combList = new List <string>();

            if (strType == "P")
            {
                return(null);
            }
            else//A,C
            {
                CombinClass allNcmb = CombinClass.CreateNumCombin(AllNums, N);//获得所有N个
                combList = allNcmb;
            }
            dt.Columns.Add("id", typeof(int));
            combList.ForEach(a => dt.Columns.Add(a, typeof(int)));
            ExpectList currList = new ExpectList();

            for (int i = orgData.Count - period; i < orgData.Count; i++)
            {
                ExpectData <TimeSerialData> ed = new ExpectData <TimeSerialData>();
                ed.OpenCode = orgData[i].OpenCode;
                ed.Expect   = orgData[i].Expect;

                currList.Add(ed);
            }

            for (int i = 0; i < currList.Count; i++)
            {
                DataRow dr = dt.NewRow();
                dr["id"] = i;
                string opencode = currList[i].OpenCode;
                opencode = CombinGenerator.ResortNumString(opencode, ",");
                CombinClass occ = null;
                if (N <= SelNums)
                {
                    occ = new CombinClass(opencode, N);
                    combList.ForEach(a => {
                        dr[a] = occ.Contains(a) ? 1 : 0;
                    });
                }
                else
                {
                    combList.ForEach(a =>
                    {
                        occ = new CombinClass(a, SelNums);
                        if (occ.Contains(opencode))
                        {
                            dr[a] = 1;
                        }
                        else
                        {
                            dr[a] = 0;
                        }
                    });
                }
                dt.Rows.Add(dr);
            }
            return(dt);
        }