Beispiel #1
0
        /// <summary>
        /// Converts a ParseNode object into it correspondending AST node. Throws an exception when there is no conversion possible.
        /// </summary>
        /// <param name="parseNode">Parsenode to be converted</param>
        /// <returns>AST node</returns>
        private ASTNode ConvertPNtoASTNode(ParseNode parseNode)
        {
            ASTNode ret;

            switch (parseNode.GetEnum())
            {
            case ParseEnum.Number:
                ret = new Number(parseNode.GetValue());
                break;

            case ParseEnum.Operator:
                ret = new Operator(parseNode.GetValue());
                break;

            case ParseEnum.Variable:
                ret = new Variable(parseNode.GetValue());
                break;

            case ParseEnum.Equals:
                ret = new EqualSign(parseNode.GetValue());
                break;

            default:
                throw new Exception("Could not convert Parsenode");
            }

            return(ret);
        }
Beispiel #2
0
        protected Equation TranslateStringToEquation(string pattern, int desiredID)
        {
            Data.Sign sign = null;
            double    rightPart;

            string[] arr = pattern.Split(new string[] { "<=", ">=", "=" }, StringSplitOptions.RemoveEmptyEntries);
            double.TryParse(arr[1], out rightPart);
            string[] instances = pattern.Split(" ", StringSplitOptions.RemoveEmptyEntries);
            for (int i = 0; i < instances.Length; i++)
            {
                if (instances[i] == "<=")
                {
                    sign = new LessThanOrEqual();
                    break;
                }
                else if (instances[i] == ">=")
                {
                    sign = new MoreThanOrEqual();
                    break;
                }
                else if (instances[i] == "=")
                {
                    sign = new EqualSign();
                    break;
                }
            }
            if (sign == null)
            {
                throw new Exception("Знак неравенства не был найден");
            }
            return(new Equation(desiredID)
            {
                Coefficients = arr[0].Trim(),
                SelectedSign = sign,
                RightPart = rightPart
            });
        }
Beispiel #3
0
        /// <summary>
        /// Generates a abstract syntrax tree from the given ParseTree
        /// </summary>
        /// <param name="node">Start node</param>
        /// <returns>Abstract syntax tree </returns>
        public ASTNode GenerateAST(ParseNode node)
        {
            ASTNode root;

            // Skip start node
            if (node.GetEnum() == ParseEnum.Start)
            {
                node = node.GetChildren()[0];
            }

            List <ParseNode> bfQueue = GetBreadthFirstQueue(node).FindAll(x => x.GetEnum() == ParseEnum.Operator || x.GetEnum() == ParseEnum.Number ||
                                                                          x.GetEnum() == ParseEnum.Variable || x.GetEnum() == ParseEnum.Equals);

            // If there is only one interesting node no further processing needs to be done.
            if (bfQueue.Count == 1)
            {
                root = ConvertPNtoASTNode(bfQueue[0]);
            }
            else
            {
                // Handle special condition
                if (bfQueue.Count == 3 &&
                    (bfQueue.Find(x => x.GetEnum() == ParseEnum.Operator || x.GetEnum() == ParseEnum.Equals) != null))
                {
                    ParseNode op =
                        bfQueue.Find(x => x.GetEnum() == ParseEnum.Operator || x.GetEnum() == ParseEnum.Equals);
                    bfQueue.Remove(op);

                    if (op.GetEnum() == ParseEnum.Equals)
                    {
                        root = new EqualSign(op.GetValue());
                    }
                    else
                    {
                        root = new Operator(op.GetValue());
                    }

                    root.LeftChild  = ConvertPNtoASTNode(bfQueue[0]);
                    root.RightChild = ConvertPNtoASTNode(bfQueue[1]);
                }
                else
                {
                    // Normal routine
                    // Handles the left and right tree recursivly
                    ParseNode subTree = node.GetChildren().Find(x => ContainsNode(x, bfQueue[0]));

                    root = ConvertPNtoASTNode(bfQueue[0]);

                    if (node.GetChildren()[0].Equals(subTree))
                    {
                        subTree.GetChildren().Remove(bfQueue[0]);
                        root.LeftChild  = GenerateAST(subTree);
                        root.RightChild = GenerateAST(node.GetChildren()[1]);
                    }
                    else
                    {
                        subTree.GetChildren().Remove(bfQueue[0]);
                        root.RightChild = GenerateAST(subTree);
                        root.LeftChild  = GenerateAST(node.GetChildren()[0]);
                    }
                }
            }

            return(root);
        }