Exemple #1
0
        public override bool isMatch(string code, string currCode)
        {
            int    N        = code.Split(',').Length;
            string opencode = CombinGenerator.ResortNumString(currCode, ",");

            if (N <= SelNums)
            {
                CombinClass occ = new CombinClass(opencode, N);
                return(occ.Contains(code));
            }
            else
            {
                return(new CombinClass(code, SelNums).Contains(opencode));
            }
        }
 public MatchItem(string[] AllArr, string SelectString, int selectNum, int MissNum)
 {
     AllStr    = AllArr;
     LongItem  = SelectString;
     SelectCnt = selectNum;
     MissCnt   = MissNum;
     ShortItem = string.Join(",", CombinClass.getReconvertString(AllArr, SelectString.Split(',')));
     SubItems  = new Dictionary <int, CombinClass>();
     for (int i = 0; i < MissNum; i++)
     {
         CombinClass cc = new CombinClass(LongItem, selectNum - i);
         SubItems.Add(selectNum - i, cc);
         SubItemMatchCnt.Add(selectNum - i, 0);
     }
 }
        List <ChanceClass> getChances(CommCollection_KLXxY sc, CombinClass restComb, string[] AllArr, ExpectData ed)
        {
            List <ChanceClass> ret = new List <ChanceClass>();

            for (int i = 0; i < restComb.Count; i++)
            {
                ChanceClass_ForCombinXxY cc = new ChanceClass_ForCombinXxY();
                cc.AllNums               = 11;
                cc.SelectNums            = 5;
                cc.strAllTypeBaseOdds    = sc.strAllTypeOdds;
                cc.strCombinTypeBaseOdds = sc.strCombinTypeOdds;
                cc.strPermutTypeBaseOdds = sc.strPermutTypeOdds;

                string        a7   = restComb[i];
                string[]      Arr4 = CombinClass.getReconvertString(AllArr, a7.Split(','));
                List <string> al   = new List <string>();
                for (int j = 0; j < Arr4.Length - 1; j++)
                {
                    al.Add(string.Format("A2/{0},{1}", Arr4[j], Arr4[j + 1]));
                }
                //al.Add(string.Format("A2/{0}", string.Join(",",Arr4)));//支持2码多数
                cc.ChanceCode = string.Format("A7/{0}+{1}", a7, string.Join("+", al));


                cc.UnitCost   = 2;
                cc.ChipCount  = 4;
                cc.ChanceType = 2;
                cc.InputTimes = 1;
                //cc.AllowMaxHoldTimeCnt = this.AllowMaxHoldTimeCnt;
                cc.InputExpect = ed;
                cc.StragId     = this.GUID;
                //cc.MinWinRate = this.CommSetting.GetGlobalSetting().DefaultHoldAmtSerials.MaxRates[cc.ChipCount - 1];
                cc.IsTracer            = 0;
                cc.HoldTimeCnt         = 1;
                cc.Odds                = this.CommSetting.GetGlobalSetting().Odds;
                cc.ExpectCode          = ed.Expect;
                cc.CreateTime          = DateTime.Now;
                cc.UpdateTime          = DateTime.Now;
                cc.AllowMaxHoldTimeCnt = 1;
                cc.Closed              = false;
                ret.Add(cc);
            }
            return(ret);
        }
Exemple #4
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);
        }
Exemple #5
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);
        }
Exemple #6
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);
        }
        public override List <ChanceClass> getChances(BaseCollection bsc, ExpectData ed)
        {
            List <ChanceClass> ret = new List <ChanceClass>();

            try
            {
                CommCollection_KLXxY sc = bsc as CommCollection_KLXxY;
                if (sc == null)
                {
                    throw new Exception("数据收集类!");
                }
                //this.ChipCount;//12选5和11选5都是5
                //this.InputMaxTimes; //12选5选为8,1选5选为7
                //this.InputMinTimes;//12选5和11选5都是4
                string[] AllArr = CombinClass.CreateNumArr(sc.AllNums);
                //CombinClass allcmb = CombinClass.CireateNumCombin(sc,iAllNums, 3);//获得所有的3组合
                CombinClass allbigcmb = CombinClass.CreateNumCombin(sc.AllNums, this.InputMaxTimes);//获得所有的8/7个组合
                Dictionary <string, MatchItem> allItems = new Dictionary <string, MatchItem>();
                allbigcmb.ForEach(a =>
                {
                    MatchItem mi = new MatchItem(AllArr, a, this.ChipCount, this.InputMinTimes);
                    mi.LongItem  = a;
                    mi.ShortItem = string.Join(",", mi);
                    allItems.Add(a, mi);
                });

                /*
                 * 列出所有11/7或者12/8码的组合,列出这些组合在回览期内的下列数据
                 * 1,全部命中次数
                 * 2,错过1个的次数
                 * 3,错过2个的次数n
                 * 3,错过3个次数
                 * 4,错过4个的次数)
                 */

                int lastid = sc.orgData.Count - 1;
                for (int i = 0; i < this.ReviewExpectCnt; i++)
                {
                    int index = lastid - i;
                    if (index < 0)
                    {
                        break;
                    }
                    string opencode = sc.orgData[index].OpenCode;
                    opencode = CombinGenerator.ResortNumString(opencode, ",");
                    foreach (MatchItem mi in allItems.Values)
                    {
                        for (int c = 0; c < this.InputMinTimes; c++)
                        {
                            int         MatchCnt = this.ChipCount - c;
                            CombinClass occ      = new CombinClass(opencode, MatchCnt);
                            int         mcnt     = 0;
                            foreach (string si in occ)//如果开奖号中5-c命中,停止,计数器加1
                            {
                                if (mi.SubItems[MatchCnt].Contains(si))
                                {
                                    mcnt++;
                                }
                            }
                            mi.SubItemMatchCnt[MatchCnt] += mcnt;
                            if (mcnt > 0)
                            {
                                break;
                            }
                        }
                    }
                }
                DataTable dt = new DataTable();
                dt.Columns.Add("Id");
                for (int i = 0; i < this.InputMinTimes; i++)
                {
                    dt.Columns.Add(string.Format("MCnt_{0}", this.ChipCount - i), typeof(int));
                }
                foreach (MatchItem mi in allItems.Values)
                {
                    DataRow dr = dt.NewRow();
                    dr["Id"] = mi.LongItem;
                    for (int i = 0; i < this.InputMinTimes; i++)
                    {
                        dr[string.Format("MCnt_{0}", this.ChipCount - i)] = mi.SubItemMatchCnt[this.ChipCount - i];
                    }
                    dt.Rows.Add(dr);
                }
                double    cnt4avg = allItems.Values.Select(a => a.SubItemMatchCnt[4]).Average();
                double    cnt3avg = allItems.Values.Select(a => a.SubItemMatchCnt[3]).Average();
                double    cnt2avg = allItems.Values.Select(a => a.SubItemMatchCnt[2]).Average();
                double    cnt5avg = allItems.Values.Select(a => a.SubItemMatchCnt[5]).Average();
                double    cnt4std = ProbMath.CalculateStdDev(allItems.Values.Select(a => a.SubItemMatchCnt[4]));
                double    cnt3std = ProbMath.CalculateStdDev(allItems.Values.Select(a => a.SubItemMatchCnt[3]));
                double    cnt2std = ProbMath.CalculateStdDev(allItems.Values.Select(a => a.SubItemMatchCnt[2]));
                double    cnt5std = ProbMath.CalculateStdDev(allItems.Values.Select(a => a.SubItemMatchCnt[5]));
                DataTable sdt     = dt.Clone();
                DataView  dv      = new DataView(dt);
                double    stdcnt  = 2;
                //
                string sql = string.Format("MCnt_5<={0} and MCnt_4>{1} and MCnt_3<={2} and MCnt_2<={3}", Math.Max(cnt5avg - stdcnt * cnt5std, 0), cnt4avg + stdcnt * cnt4std, Math.Max(0, cnt3avg - 0 * cnt3std), Math.Max(0, cnt2avg - 0 * cnt2std));

                //string sql = string.Format("MCnt_5<={0} and MCnt_4>{1} and MCnt_3<={2}", Math.Max(cnt5avg - stdcnt * cnt5std, 0), cnt4avg + stdcnt * cnt4std, Math.Max(0, cnt3avg - 0 * cnt3std));
                dt.Select(sql).ToList().ForEach(a => sdt.Rows.Add(a.ItemArray));
                dv = new DataView(sdt);

                //4个匹配要求最低。
                CombinClass cc = new CombinClass();
                for (int i = 0; i < Math.Min(dv.Count, 100); i++)
                {
                    cc.Add(dv[i].Row[0].ToString());
                }
                ret = getChances(sc, cc, AllArr, ed);
            }
            catch (Exception ce)
            {
                Log(ce.Message, ce.StackTrace);
            }
            return(ret);
        }