public void CheckIteratorCompositionOfCompositions()
        {
            IExecute<int> identity = new SingleFunction<int>(x => x);
            IExecute<int> linearfunction = new SingleFunction<int>(x => x + 2);
            IExecute<int> quadraticfunction = new SingleFunction<int>(x => 2 * x * x);

            var comp1 = new Composition<int>(linearfunction, quadraticfunction);
            var comp2 = new Composition<int>(quadraticfunction, linearfunction);

            var compOfComps = new Composition<int>(comp1, comp2);

            var functionList = new[] { identity, linearfunction, quadraticfunction, compOfComps };

            var comp = new Composition<int>(functionList);

            var tab0 = new[] { 0, 2, 0, 2, 0, 0, 2 };
            var tab1 = new[] { 1, 3, 2, 3, 2, 2, 3 };
            var tab2 = new[] { 2, 4, 8, 4, 8, 8, 4 };
            var i = 0;

            Assert.AreEqual(7, comp.Count());

            foreach (var f in comp)
            {
                Assert.AreEqual(tab0[i], f.Execute(0));
                Assert.AreEqual(tab1[i], f.Execute(1));
                Assert.AreEqual(tab2[i], f.Execute(2));
                i++;
            }
        }
示例#2
0
        static void Main(string[] args)
        {
            IExecute<int> identity = new SingleFunction<int>(x => x);
            IExecute<int> linearfunction = new SingleFunction<int>(x => 3 * x - 2);
            IExecute<int> quadraticfunction = new SingleFunction<int>(x => 2 * x * x - 5);
            IExecute<int> cubicfunction = new SingleFunction<int>(x => x * x * x + x * x + x + 1);

            var functionList = new[] { identity, linearfunction, quadraticfunction, cubicfunction };

            var comp = new Composition<int>(functionList);

            Console.WriteLine(comp.Execute(5));
            Console.ReadKey();
        }
        private List <SingleFunction> RemoveHeaderAndDivideFunction()
        {
            List <SingleFunction> singleFunction = new List <SingleFunction>();
            StringBuilder         DotFileSb      = new StringBuilder();
            string       line;
            int          iterator   = 0;
            int          lineNumber = File.ReadAllLines(Directory.GetParent(workingDirectory).Parent.FullName + @"\Files\" + "code.dot").Length;
            StreamReader file       = new StreamReader(Directory.GetParent(workingDirectory).Parent.FullName + @"\Files\" + "code.dot");

            while ((line = file.ReadLine()) != null)
            {
                iterator++;

                if (iterator > 2 && iterator < lineNumber)
                {
                    DotFileSb.Append(line);
                    DotFileSb.Append(Environment.NewLine);
                }
            }
            string DOT_File_Stringified = DotFileSb.ToString();

            StringBuilder singleFunctionSb = new StringBuilder();
            int           breaker          = 0;

            foreach (char sign in DOT_File_Stringified)
            {
                singleFunctionSb.Append(sign);
                if (sign == '{')
                {
                    breaker++;
                }
                else if (sign == '}')
                {
                    breaker--;

                    if (breaker == 0)
                    {
                        SingleFunction sf = new SingleFunction();
                        sf.functionBody = singleFunctionSb.ToString();
                        sf.functionName = getBetween(singleFunctionSb.ToString());
                        singleFunction.Add(sf);
                        singleFunctionSb.Clear();
                    }
                }
            }
            //GetNodesFromEveryFunction(singleFunction);
            return(singleFunction);
        }
        public void AddingFunctionToComposition()
        {
            IExecute<int> identity = new SingleFunction<int>(x => x);

            var comp = new Composition<int>(identity);
            Assert.AreEqual(0, comp.Execute(0));
            Assert.AreEqual(2, comp.Execute(2));

            IExecute<int> linearFunction = new SingleFunction<int>(x => x + 2);

            comp.Add(linearFunction);
            Assert.AreEqual(2, comp.Execute(0));
            Assert.AreEqual(4, comp.Execute(2));

            IExecute<int> cubicfunction = new SingleFunction<int>(x => x * x * x);

            comp.Add(cubicfunction);
            Assert.AreEqual(8, comp.Execute(0));
            Assert.AreEqual(64, comp.Execute(2));
        }
        public void CheckIterator()
        {
            IExecute<int> identity = new SingleFunction<int>(x => x);
            IExecute<int> linearfunction = new SingleFunction<int>(x => 3 * x - 2);
            IExecute<int> quadraticfunction = new SingleFunction<int>(x => 2 * x * x - 5);
            IExecute<int> cubicfunction = new SingleFunction<int>(x => x * x * x + x * x + x + 1);

            var functionList = new[] { identity, linearfunction, quadraticfunction, cubicfunction };

            var comp = new Composition<int>(functionList);

            var tab0 = new[] { 0, -2, -5, 1 };
            var tab1 = new[] { 1, 1, -3, 4 };
            var tab2 = new[] { 2, 4, 3, 15 };
            var i = 0;

            foreach (var f in comp)
            {
                Assert.AreEqual(tab0[i], f.Execute(0));
                Assert.AreEqual(tab1[i], f.Execute(1));
                Assert.AreEqual(tab2[i], f.Execute(2));
                i++;
            }
        }
 public void ComposeOneFunction()
 {
     IExecute<int> linearfunction = new SingleFunction<int>(x => 2 * x + 10);
     var comp = new Composition<int>(linearfunction);
     Assert.AreEqual(10, comp.Execute(0));
     Assert.AreEqual(14, comp.Execute(2));
     Assert.AreEqual(20, comp.Execute(5));
 }
        public void CompositionOfCompositions()
        {
            IExecute<int> linearfunction = new SingleFunction<int>(x => x + 2);
            IExecute<int> quadraticfunction = new SingleFunction<int>(x => 2 * x * x);

            var comp1 = new Composition<int>(linearfunction, quadraticfunction);
            var comp2 = new Composition<int>(quadraticfunction, linearfunction);

            var compOfComps = new Composition<int>(comp1, comp2);

            Assert.AreEqual(130, compOfComps.Execute(0));
            Assert.AreEqual(650, compOfComps.Execute(1));
            Assert.AreEqual(2050, compOfComps.Execute(2));
        }
        public void ComposeTwoFunctions()
        {
            IExecute<int> linearfunction = new SingleFunction<int>(x => 2 * x + 5);
            IExecute<int> quadraticfunction = new SingleFunction<int>(x => x * x);

            var comp = new Composition<int>(linearfunction, quadraticfunction);
            Assert.AreEqual(25, comp.Execute(0));
            Assert.AreEqual(81, comp.Execute(2));
            Assert.AreEqual(225, comp.Execute(5));

            comp = new Composition<int>(quadraticfunction, linearfunction);
            Assert.AreEqual(5, comp.Execute(0));
            Assert.AreEqual(13, comp.Execute(2));
            Assert.AreEqual(55, comp.Execute(5));

            comp = new Composition<int>(linearfunction, linearfunction);
            Assert.AreEqual(15, comp.Execute(0));
            Assert.AreEqual(23, comp.Execute(2));
            Assert.AreEqual(35, comp.Execute(5));

            comp = new Composition<int>(quadraticfunction, quadraticfunction);
            Assert.AreEqual(0, comp.Execute(0));
            Assert.AreEqual(16, comp.Execute(2));
            Assert.AreEqual(625, comp.Execute(5));
        }
        public void ComposeThreeFunctions()
        {
            IExecute<int> identity = new SingleFunction<int>(x => x);
            IExecute<int> linearFunction = new SingleFunction<int>(x => x + 2);
            IExecute<int> cubicfunction = new SingleFunction<int>(x => x * x * x - 1);

            var functionList = new[] { identity, linearFunction, cubicfunction };

            var comp = new Composition<int>(functionList);
            Assert.AreEqual(7, comp.Execute(0));
            Assert.AreEqual(63, comp.Execute(2));
            Assert.AreEqual(26, comp.Execute(1));
        }
        private List <NodeCovered> checkIfAllNodesAreCovered(List <List <int> > linearlyIndependentPath, SingleFunction singleFunction)
        {
            List <NodeCovered> CoveredNode = new List <NodeCovered>();


            foreach (var single in singleFunction.nodes)
            {
                CoveredNode.Add(new NodeCovered(single.node, false));
            }

            foreach (var node in CoveredNode)
            {
                foreach (var path in linearlyIndependentPath)
                {
                    foreach (var linearNode in path)
                    {
                        if (linearNode == node.node)
                        {
                            node.isCovered = true;
                        }
                        else
                        {
                            //CoveredNode.Add(linearNode);
                        }
                    }
                }
            }
            return(CoveredNode.Where(node => node.isCovered = false).ToList());
        }