Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
12/15/21 11:50:57 (2 years ago)
Author:
gkronber
Message:

#3140: merged r18091:18131 from branch to trunk

Location:
trunk
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk

  • trunk/HeuristicLab.Problems.DataAnalysis.Symbolic

  • trunk/HeuristicLab.Problems.DataAnalysis.Symbolic/3.4/Importer/InfixExpressionParser.cs

    r17902 r18132  
    5757  /// </summary>
    5858  public sealed class InfixExpressionParser {
    59     private enum TokenType { Operator, Identifier, Number, LeftPar, RightPar, LeftBracket, RightBracket, Comma, Eq, End, NA };
     59    private enum TokenType { Operator, Identifier, Number, LeftPar, RightPar, LeftBracket, RightBracket, LeftAngleBracket, RightAngleBracket, Comma, Eq, End, NA };
    6060    private class Token {
    6161      internal double doubleVal;
     
    8282      knownSymbols = new BidirectionalLookup<string, ISymbol>(StringComparer.InvariantCulture, new SymbolComparer());
    8383
     84    private Number number = new Number();
    8485    private Constant constant = new Constant();
    8586    private Variable variable = new Variable();
     
    180181            && str[pos] != ']'
    181182            && str[pos] != '}'
    182             && str[pos] != ',') {
     183            && str[pos] != ','
     184            && str[pos] != '>') {
    183185            sb.Append(str[pos]);
    184186            pos++;
     
    265267          pos++;
    266268          yield return new Token { TokenType = TokenType.Comma, strVal = "," };
     269        } else if (str[pos] == '<') {
     270          pos++;
     271          yield return new Token {TokenType = TokenType.LeftAngleBracket, strVal = "<"};
     272        } else if (str[pos] == '>') {
     273          pos++;
     274          yield return new Token {TokenType = TokenType.RightAngleBracket, strVal = ">"};
    267275        } else {
    268276          throw new ArgumentException("Invalid character: " + str[pos]);
     
    326334          foreach (var negTerm in negTerms) sumNeg.AddSubtree(negTerm);
    327335
    328           var constNode = (ConstantTreeNode)constant.CreateTreeNode();
     336          var constNode = (NumberTreeNode)number.CreateTreeNode();
    329337          constNode.Value = -1.0;
    330338          var prod = GetSymbol("*").CreateTreeNode();
     
    524532          }
    525533        }
     534      } else if (next.TokenType == TokenType.LeftAngleBracket) {
     535        Token numberTok = null;
     536        var leftAngleBracket = tokens.Dequeue();
     537        if (leftAngleBracket.TokenType != TokenType.LeftAngleBracket)
     538          throw new ArgumentException("opening bracket < expected");
     539
     540        var idTok = tokens.Dequeue();
     541        if (idTok.TokenType != TokenType.Identifier || idTok.strVal.ToLower() != "num")
     542          throw new ArgumentException("string 'num' expected");
     543
     544        if (tokens.Peek().TokenType == TokenType.Eq) {
     545          var equalTok = tokens.Dequeue();
     546          if (tokens.Peek().TokenType != TokenType.Number)
     547            throw new ArgumentException("No value for number specified.");
     548
     549          numberTok = tokens.Dequeue();
     550        }
     551
     552        var rightAngleBracket = tokens.Dequeue();
     553        if (rightAngleBracket.TokenType != TokenType.RightAngleBracket)
     554          throw new ArgumentException("closing bracket > expected");
     555        var numNode = (NumberTreeNode)number.CreateTreeNode();
     556        if (numberTok != null) numNode.Value = numberTok.doubleVal;
     557        return numNode;
    526558      } else if (next.TokenType == TokenType.Number) {
    527559        var numTok = tokens.Dequeue();
    528         var constNode = (ConstantTreeNode)constant.CreateTreeNode();
     560        var constSy = new Constant {Value = numTok.doubleVal};
     561        return constSy.CreateTreeNode();
     562        /*var constNode = (ConstantTreeNode)constant.CreateTreeNode();
    529563        constNode.Value = numTok.doubleVal;
    530         return constNode;
     564        return constNode;*/
    531565      } else {
    532566        throw new ArgumentException(string.Format("unexpected token in expression {0}", next.strVal));
Note: See TracChangeset for help on using the changeset viewer.