當前位置: 首頁>>代碼示例>>C#>>正文


C# Single.Sum方法代碼示例

本文整理匯總了C#中System.Single.Sum方法的典型用法代碼示例。如果您正苦於以下問題:C# Single.Sum方法的具體用法?C# Single.Sum怎麽用?C# Single.Sum使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Single的用法示例。


在下文中一共展示了Single.Sum方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: CalculateBestAgainst_Naive

        void CalculateBestAgainst_Naive(Player Opponent)
        {
            // First decide strategy for children nodes.
            RecursiveBest(Opponent);

            // For each pocket we might have, calculate what we should do.
            PocketData UpdatedP = new PocketData();
            for (int p1 = 0; p1 < Pocket.N; p1++)
            {
                if (!MyCommunity.AvailablePocket[p1]) continue;

                // Update the opponent's pocket PDF using the new information,
                // (which is that we now know which pocket we have).
                UpdateOnExclusion(PocketP, UpdatedP, p1);

                // Calculate the EV assuming we proceed to a branch.
                // Loop through each possible opponent pocket and then each possible branch,
                // summing up the EV of each branch times the probability of arriving there.
                number TotalWeight = 0, BranchEV = 0;
                number[] BranchPDF = new number[Branches.Count];
                for (int p2 = 0; p2 < Pocket.N; p2++)
                {
                    if (!MyCommunity.AvailablePocket[p2]) continue;

                    // All branches not overlapping our pocket or the opponent's pocket are equally likely.
                    int BranchIndex = 0;
                    foreach (Node Branch in Branches)
                    {
                        BranchIndex++;
                        if (!Branch.MyCommunity.AvailablePocket[p1] || !Branch.MyCommunity.AvailablePocket[p2]) continue;

                        number Weight = Branch.Weight;
                        BranchEV += UpdatedP[p2] * Weight * Branch.EV[p1];
                        TotalWeight += UpdatedP[p2] * Weight;
                        BranchPDF[BranchIndex - 1] += UpdatedP[p2] * Weight;
                    }
                }
                Assert.ZeroOrOne(BranchPDF.Sum());
                Assert.ZeroOrOne(TotalWeight);
                Assert.That(BranchEV >= -DerivedSetup.MaxPot - Tools.eps && BranchEV <= DerivedSetup.MaxPot + Tools.eps);

                EV[p1] = BranchEV;
                Assert.IsNum(EV[p1]);
            }
        }
開發者ID:JordanFisher,項目名稱:Texas-Holdem-Nash-Solver,代碼行數:45,代碼來源:Junction.cs

示例2: CalculateBestAgainst_FlopSuitReduced

        void CalculateBestAgainst_FlopSuitReduced(Player Opponent)
        {
            System.Threading.Tasks.Parallel.ForEach(Branches, node => node.CalculateBestAgainst(Opponent));

            //foreach (Node node in Branches)
            //    node.CalculateBestAgainst(Opponent);

            // For each pocket we might have, calculate what we should do.
            PocketData UpdatedP = new PocketData();
            for (int p1 = 0; p1 < Pocket.N; p1++)
            {
                if (!MyCommunity.AvailablePocket[p1]) continue;

                // Update the opponent's pocket PDF using the new information,
                // (which is that we now know which pocket we have).
                UpdateOnExclusion(PocketP, UpdatedP, p1);

                // Calculate the EV assuming we proceed to a branch.
                // Loop through each possible opponent pocket and then each possible branch,
                // summing up the EV of each branch times the probability of arriving there.
                number TotalWeight = 0, BranchEV = 0;
                number[] BranchPDF = new number[Branches.Count];
                for (int p2 = 0; p2 < Pocket.N; p2++)
                {
                    if (!MyCommunity.AvailablePocket[p2]) continue;

                    // All branches not overlapping our pocket or the opponent's pocket are equally likely.
                    // However, because we have grouped some branches together we weight representative branches more heavily.
                    int b = 0;
                    foreach (Node Branch in Branches)
                    {
                        b++;
                        if (Branch.MyCommunity.NewCollision(p1) || Branch.MyCommunity.NewCollision(p2)) continue;

                        FlopRoot FlopBranch = (FlopRoot)Branch;
                        FlopRoot _Branch = FlopBranch.Representative;
                        int _p1 = FlopBranch.MyFlop.PocketMap[p1];

                        //Assert.AlmostEqual(Branch.EV[p1], _Branch.EV[_p1], .05);

                        number Weight = _Branch.Weight;
                        BranchEV += UpdatedP[p2] * Weight * _Branch.EV[_p1];
                        TotalWeight += UpdatedP[p2] * Weight;
                        BranchPDF[b - 1] += UpdatedP[p2] * Weight;
                    }
                }
                Assert.ZeroOrOne(BranchPDF.Sum());
                Assert.ZeroOrOne(TotalWeight);
                Assert.That(BranchEV >= -DerivedSetup.MaxPot - Tools.eps && BranchEV <= DerivedSetup.MaxPot + Tools.eps);

                EV[p1] = BranchEV;
                Assert.IsNum(EV[p1]);
            }
        }
開發者ID:JordanFisher,項目名稱:Texas-Holdem-Nash-Solver,代碼行數:54,代碼來源:Junction.cs


注:本文中的System.Single.Sum方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。