Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
08/11/20 14:22:45 (4 years ago)
Author:
dpiringe
Message:

#3073

  • added regions in IntervalConstraint
  • modified IntervalConstraintsParser to detect regions
File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/3073_IA_constraint_splitting/HeuristicLab.Problems.DataAnalysis/3.4/Implementation/Interval/IntervalConstraintsParser.cs

    r17607 r17723  
    4545          var end              = trimmedLine.Length;
    4646          var targetConstraint = trimmedLine.Substring(start, end - start);
    47           var match = Regex.Match(targetConstraint,
    48                                   @"(['](.*)[']|(.*[^\s]))\s*(\bin\b)\s*([\[])\s*(\S*)\s*(\.{2})\s*(\S*)\s*([\]])");
     47
     48          var match =
     49          Regex.Match(targetConstraint,
     50                        @"(['](.*)[']|(.*[^\s]))" +
     51                        @"\s*(\bin\b)" +
     52                        @"\s*([\[])" +
     53                        @"\s*(\S*)" + // 6: interval lower bound
     54                        @"\s*(\.{2})" +
     55                        @"\s*(\S*)" + // 8: interval upper bound
     56                        @"\s*([\]])" +
     57                        @"(" +
     58                          @"\s*,\s*(\S*)\s*=\s*" + // 11: variable name
     59                          @"([(])\s*" +
     60                          @"(\S*)\s*" + // 13: region lower bound
     61                          @"(\.{2})\s*" +
     62                          @"(\S*)\s*" + // 15: region upper bound
     63                          @"([)])" +
     64                        @")*");
     65         
    4966          if (match.Success) {
    50             if (match.Groups.Count != 10) throw new ArgumentException("The target-constraint is not complete.", line);
     67            if (match.Groups.Count < 9) throw new ArgumentException("The target-constraint is not complete.", line);
    5168
    5269            var targetVariable = match.Groups[1].Value.Trim();
    53             if (match.Groups[1].Value.Trim().StartsWith("'") && match.Groups[1].Value.Trim().EndsWith("'"))
     70            if (targetVariable.StartsWith("'") && targetVariable.EndsWith("'"))
    5471              targetVariable = targetVariable.Substring(1, targetVariable.Length - 2);
    5572
     
    6885            var interval           = new Interval(lowerBound, upperBound);
    6986
    70             var constraint =
    71               new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, isEnabled);
    72 
    73             yield return constraint;
     87            if (match.Groups[10].Success)
     88            {
     89              IDictionary<string, Interval> pairs = new Dictionary<string, Interval>();
     90              // option variables found
     91              for(int idx = 0; idx < match.Groups[10].Captures.Count; ++idx)
     92              {
     93                var inputVar = match.Groups[11].Captures[idx].Value;
     94                var regionLb = ParseIntervalBounds(match.Groups[13].Captures[idx].Value);
     95                var regionUb = ParseIntervalBounds(match.Groups[15].Captures[idx].Value);
     96                pairs.Add(inputVar, new Interval(regionLb, regionUb));
     97              }
     98              yield return new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, pairs, isEnabled);
     99            }
     100            else
     101            {
     102              yield return new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, isEnabled);
     103            }
    74104          }
    75105          else {
     
    80110        }
    81111        else if (trimmedLine.StartsWith("d") || trimmedLine.StartsWith("\u2202")) {
    82           var match = Regex.Match(trimmedLine,
    83                                   @"([d∂])([²³]?)\s*(['](.*)[']|(.*[^\s]))\s*(\/)\s*([d∂])\s*(['](.*)[']|(.*[^\s²³]))\s*([²³]?)\s*\bin\b\s*([\[])\s*(\S*)\s*(\.{2})\s*(\S*)\s*([\]])");
     112          var match = Regex.Match(trimmedLine,
     113                                    @"([d∂])" +
     114                                    @"([²³]?)\s*" +
     115                                    @"(['](.*)[']|(.*[^\s]))\s*" +
     116                                    @"(\/)\s*" +
     117                                    @"([d∂])\s*" +
     118                                    @"(['](.*)[']|(.*[^\s²³]))\s*" +
     119                                    @"([²³]?)\s*\bin\b\s*" +
     120                                    @"([\[])\s*" +
     121                                    @"(\S*)\s*" +
     122                                    @"(\.{2})\s*" +
     123                                    @"(\S*)\s*" +
     124                                    @"([\]])" +
     125                                    @"(" +
     126                                      @"\s*,\s*(\S*)\s*=\s*" + // 18: variable name
     127                                      @"([(])\s*" +
     128                                      @"(\S*)\s*" + // 20: region lower bound
     129                                      @"(\.{2})\s*" +
     130                                      @"(\S*)\s*" + // 22: region upper bound
     131                                      @"([)])" +
     132                                    @")*");
    84133
    85134          if (match.Success) {
    86             if (match.Groups.Count != 17)
     135            if (match.Groups.Count < 24)
    87136              throw new ArgumentException("The given derivation-constraint is not complete.", line);
    88137
     
    121170            var interval           = new Interval(lowerBound, upperBound);
    122171
    123             var constraint =
    124               new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, isEnabled);
    125 
    126             yield return constraint;
     172            if(match.Groups[17].Success)
     173            {
     174              IDictionary<string, Interval> pairs = new Dictionary<string, Interval>();
     175              // option variables found
     176              for (int idx = 0; idx < match.Groups[17].Captures.Count; ++idx)
     177              {
     178                var inputVar = match.Groups[18].Captures[idx].Value;
     179                var regionLb = ParseIntervalBounds(match.Groups[20].Captures[idx].Value);
     180                var regionUb = ParseIntervalBounds(match.Groups[22].Captures[idx].Value);
     181                pairs.Add(inputVar, new Interval(regionLb, regionUb));
     182              }
     183              yield return new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, pairs, isEnabled);
     184            } else {
     185              yield return new IntervalConstraint(expression, variable, parsedTarget, numberOfDerivation, interval, isEnabled);
     186            }
    127187          }
    128188          else {
Note: See TracChangeset for help on using the changeset viewer.