Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
02/17/11 03:01:24 (14 years ago)
Author:
swagner
Message:

Worked on OKB (#1174)

Location:
branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query
Files:
12 added
26 deleted
17 edited

Legend:

Unmodified
Added
Removed
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/DataTransfer/Algorithm.cs

    r5482 r5502  
    3030    public string Description { get; set; }
    3131    [DataMember]
    32     public Platform Platform { get; set; }
     32    public string Platform { get; set; }
    3333    [DataMember]
    34     public AlgorithmClass AlgorithmClass { get; set; }
     34    public string AlgorithmClass { get; set; }
    3535    [DataMember]
    3636    public DataType DataType { get; set; }
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/DataTransfer/BinaryValue.cs

    r5482 r5502  
    2626  public class BinaryValue : Value {
    2727    [DataMember]
    28     public long BinaryDataId { get; set; }
     28    public byte[] Value { get; set; }
    2929  }
    3030}
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/DataTransfer/Problem.cs

    r5482 r5502  
    3030    public string Description { get; set; }
    3131    [DataMember]
    32     public Platform Platform { get; set; }
     32    public string Platform { get; set; }
    3333    [DataMember]
    34     public ProblemClass ProblemClass { get; set; }
     34    public string ProblemClass { get; set; }
    3535    [DataMember]
    3636    public DataType DataType { get; set; }
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/AlgorithmClassNameFilter.cs

    r5482 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Algorithm.AlgorithmClass.Name == Value;
     36            return x => x.Algorithm.AlgorithmClass.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Algorithm.AlgorithmClass.Name != Value;
     38            return x => x.Algorithm.AlgorithmClass.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Algorithm.AlgorithmClass.Name.Contains(Value);
     40            return x => x.Algorithm.AlgorithmClass.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Algorithm.AlgorithmClass.Name.Contains(Value);
     42            return x => !x.Algorithm.AlgorithmClass.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Algorithm.AlgorithmClass.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Algorithm.AlgorithmClass.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public AlgorithmClassNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public AlgorithmClassNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/AlgorithmNameFilter.cs

    r5482 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Algorithm.Name == Value;
     36            return x => x.Algorithm.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Algorithm.Name != Value;
     38            return x => x.Algorithm.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Algorithm.Name.Contains(Value);
     40            return x => x.Algorithm.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Algorithm.Name.Contains(Value);
     42            return x => !x.Algorithm.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Algorithm.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Algorithm.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public AlgorithmNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public AlgorithmNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/AlgorithmPlatformNameFilter.cs

    r5482 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Algorithm.Platform.Name == Value;
     36            return x => x.Algorithm.Platform.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Algorithm.Platform.Name != Value;
     38            return x => x.Algorithm.Platform.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Algorithm.Platform.Name.Contains(Value);
     40            return x => x.Algorithm.Platform.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Algorithm.Platform.Name.Contains(Value);
     42            return x => !x.Algorithm.Platform.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Algorithm.Platform.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Algorithm.Platform.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public AlgorithmPlatformNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public AlgorithmPlatformNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/AndFilter.cs

    r5482 r5502  
    2222using System;
    2323using System.Collections.Generic;
     24using System.Linq;
    2425using System.Linq.Expressions;
    2526using HeuristicLab.Services.OKB.DataAccess;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/OrFilter.cs

    r5482 r5502  
    2222using System;
    2323using System.Collections.Generic;
     24using System.Linq;
    2425using System.Linq.Expressions;
    2526using HeuristicLab.Services.OKB.DataAccess;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/ProblemClassNameFilter.cs

    r5482 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Problem.ProblemClass.Name == Value;
     36            return x => x.Problem.ProblemClass.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Problem.ProblemClass.Name != Value;
     38            return x => x.Problem.ProblemClass.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Problem.ProblemClass.Name.Contains(Value);
     40            return x => x.Problem.ProblemClass.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Problem.ProblemClass.Name.Contains(Value);
     42            return x => !x.Problem.ProblemClass.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Problem.ProblemClass.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Problem.ProblemClass.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public ProblemClassNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public ProblemClassNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/ProblemNameFilter.cs

    r5482 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Problem.Name == Value;
     36            return x => x.Problem.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Problem.Name != Value;
     38            return x => x.Problem.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Problem.Name.Contains(Value);
     40            return x => x.Problem.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Problem.Name.Contains(Value);
     42            return x => !x.Problem.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Problem.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Problem.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public ProblemNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public ProblemNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/ProblemPlatformNameFilter.cs

    r5378 r5502  
    2121
    2222using System;
     23using System.Data.Linq.SqlClient;
    2324using System.Linq.Expressions;
    2425using HeuristicLab.Services.OKB.DataAccess;
    2526
    26 namespace HeuristicLab.Services.OKB {
     27namespace HeuristicLab.Services.OKB.Query.Filters {
    2728  public class ProblemPlatformNameFilter : IFilter {
    2829    public DataTransfer.StringComparison Comparison { get; set; }
     
    3334        switch (Comparison) {
    3435          case DataTransfer.StringComparison.Equal:
    35             return x => x.Experiment.Problem.Platform.Name == Value;
     36            return x => x.Problem.Platform.Name == Value;
    3637          case DataTransfer.StringComparison.NotEqual:
    37             return x => x.Experiment.Problem.Platform.Name != Value;
     38            return x => x.Problem.Platform.Name != Value;
    3839          case DataTransfer.StringComparison.Contains:
    39             return x => x.Experiment.Problem.Platform.Name.Contains(Value);
     40            return x => x.Problem.Platform.Name.Contains(Value);
    4041          case DataTransfer.StringComparison.NotContains:
    41             return x => !x.Experiment.Problem.Platform.Name.Contains(Value);
     42            return x => !x.Problem.Platform.Name.Contains(Value);
     43          case DataTransfer.StringComparison.Like:
     44            return x => SqlMethods.Like(x.Problem.Platform.Name, Value);
     45          case DataTransfer.StringComparison.NotLike:
     46            return x => !SqlMethods.Like(x.Problem.Platform.Name, Value);
    4247          default:
    4348            return x => true;
     
    5055      Value = value;
    5156    }
    52     public ProblemPlatformNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     57    public ProblemPlatformNameFilter(DataTransfer.StringComparisonFilter filter) {
    5358      Comparison = filter.Comparison;
    5459      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/RunClientNameFilter.cs

    r5378 r5502  
    2424using HeuristicLab.Services.OKB.DataAccess;
    2525
    26 namespace HeuristicLab.Services.OKB {
     26namespace HeuristicLab.Services.OKB.Query.Filters {
    2727  public class RunClientNameFilter : IFilter {
    2828    public DataTransfer.StringComparison Comparison { get; set; }
     
    4040          case DataTransfer.StringComparison.NotContains:
    4141            throw new NotSupportedException();
     42          case DataTransfer.StringComparison.Like:
     43            throw new NotSupportedException();
     44          case DataTransfer.StringComparison.NotLike:
     45            throw new NotSupportedException();
    4246          default:
    4347            return x => true;
     
    5054      Value = value;
    5155    }
    52     public RunClientNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     56    public RunClientNameFilter(DataTransfer.StringComparisonFilter filter) {
    5357      Comparison = filter.Comparison;
    5458      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/RunCreatedDateFilter.cs

    r5295 r5502  
    2424using HeuristicLab.Services.OKB.DataAccess;
    2525
    26 namespace HeuristicLab.Services.OKB {
     26namespace HeuristicLab.Services.OKB.Query.Filters {
    2727  public class RunCreatedDateFilter : IFilter {
    2828    public DataTransfer.OrdinalComparison Comparison { get; set; }
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/RunRandomSeedFilter.cs

    r5295 r5502  
    2424using HeuristicLab.Services.OKB.DataAccess;
    2525
    26 namespace HeuristicLab.Services.OKB {
     26namespace HeuristicLab.Services.OKB.Query.Filters {
    2727  public class RunRandomSeedFilter : IFilter {
    2828    public DataTransfer.OrdinalComparison Comparison { get; set; }
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/Filters/RunUserNameFilter.cs

    r5378 r5502  
    2424using HeuristicLab.Services.OKB.DataAccess;
    2525
    26 namespace HeuristicLab.Services.OKB {
     26namespace HeuristicLab.Services.OKB.Query.Filters {
    2727  public class RunUserNameFilter : IFilter {
    2828    public DataTransfer.StringComparison Comparison { get; set; }
     
    4040          case DataTransfer.StringComparison.NotContains:
    4141            throw new NotSupportedException();
     42          case DataTransfer.StringComparison.Like:
     43            throw new NotSupportedException();
     44          case DataTransfer.StringComparison.NotLike:
     45            throw new NotSupportedException();
    4246          default:
    4347            return x => true;
     
    5054      Value = value;
    5155    }
    52     public RunUserNameFilter(DataTransfer.SetComparisonStringFilter filter) {
     56    public RunUserNameFilter(DataTransfer.StringComparisonFilter filter) {
    5357      Comparison = filter.Comparison;
    5458      Value = filter.Value;
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/IQueryService.cs

    r5482 r5502  
    4141
    4242    [OperationContract]
    43     IEnumerable<Run> GetRuns(IEnumerable<long> ids);
     43    IEnumerable<Run> GetRuns(IEnumerable<long> ids, bool includeBinaryValues);
    4444  }
    4545}
  • branches/OKB (trunk integration)/HeuristicLab.Services.OKB/3.3/Query/QueryService.cs

    r5482 r5502  
    2727using HeuristicLab.Services.OKB.DataAccess;
    2828using HeuristicLab.Services.OKB.Query.DataTransfer;
     29using HeuristicLab.Services.OKB.Query.Filters;
    2930
    3031namespace HeuristicLab.Services.OKB.Query {
     
    3738      List<Filter> filters = new List<Filter>();
    3839      using (OKBDataContext okb = new OKBDataContext()) {
    39         // run filters
     40        #region Run Filters
    4041        filters.Add(new OrdinalComparisonLongFilter(typeof(RunRandomSeedFilter).AssemblyQualifiedName, "Run Random Seed"));
    4142        filters.Add(new OrdinalComparisonDateTimeFilter(typeof(RunCreatedDateFilter).AssemblyQualifiedName, "Run Created Date"));
    42         filters.Add(new SetComparisonStringFilter(typeof(RunUserNameFilter).AssemblyQualifiedName, "Run User Name"));
    43         filters.Add(new SetComparisonStringFilter(typeof(RunClientNameFilter).AssemblyQualifiedName, "Run Client Name"));
    44 
    45         // result filters
    46         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ResultNameFilter).AssemblyQualifiedName, "Result Name", okb.Results.Select(x => x.Name).Distinct().ToArray()));
    47         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    48           filters.Add(new NameSetComparisonStringAvailableValuesFilter(typeof(ResultBlobValueDataTypeNameFilter).AssemblyQualifiedName, "Result " + name + " Value Data Type Name", name, okb.ResultBlobValues.Where(x => x.Result.Name == name).Select(x => x.DataType.Name).Distinct().ToArray()));
    49         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    50           filters.Add(new NameEqualityComparisonByteArrayFilter(typeof(ResultBlobValueValueFilter).AssemblyQualifiedName, "Result " + name + " Value", name));
    51         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "bit").Select(x => x.Name).Distinct())
    52           filters.Add(new NameEqualityComparisonBoolFilter(typeof(ResultBoolValueValueFilter).AssemblyQualifiedName, "Result " + name + " Value", name));
    53         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "float").Select(x => x.Name).Distinct())
    54           filters.Add(new NameOrdinalComparisonDoubleFilter(typeof(ResultFloatValueValueFilter).AssemblyQualifiedName, "Result " + name + " Value", name));
    55         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "bigint").Select(x => x.Name).Distinct())
    56           filters.Add(new NameOrdinalComparisonLongFilter(typeof(ResultIntValueValueFilter).AssemblyQualifiedName, "Result " + name + " Value", name));
    57         foreach (string name in okb.Results.Where(x => x.DataType.SqlName == "nvarchar").Select(x => x.Name).Distinct())
    58           filters.Add(new NameSetComparisonStringFilter(typeof(ResultStringValueValueFilter).AssemblyQualifiedName, "Result " + name + " Value", name));
    59 
    60         // algorithm parameter filters
    61         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(AlgorithmParameterNameFilter).AssemblyQualifiedName, "Algorithm Parameter Name", okb.AlgorithmParameters.Select(x => x.Name).Distinct().ToArray()));
    62         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    63           filters.Add(new NameSetComparisonStringAvailableValuesFilter(typeof(AlgorithmParameterBlobValueDataTypeNameFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value Data Type Name", name, okb.AlgorithmParameterBlobValues.Where(x => x.AlgorithmParameter.Name == name).Select(x => x.DataType.Name).Distinct().ToArray()));
    64         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    65           filters.Add(new NameEqualityComparisonByteArrayFilter(typeof(AlgorithmParameterBlobValueValueFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value", name));
    66         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "bit").Select(x => x.Name).Distinct())
    67           filters.Add(new NameEqualityComparisonBoolFilter(typeof(AlgorithmParameterBoolValueValueFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value", name));
    68         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "float").Select(x => x.Name).Distinct())
    69           filters.Add(new NameOrdinalComparisonDoubleFilter(typeof(AlgorithmParameterFloatValueValueFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value", name));
    70         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "bigint").Select(x => x.Name).Distinct())
    71           filters.Add(new NameOrdinalComparisonLongFilter(typeof(AlgorithmParameterIntValueValueFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value", name));
    72         foreach (string name in okb.AlgorithmParameters.Where(x => x.DataType.SqlName == "nvarchar").Select(x => x.Name).Distinct())
    73           filters.Add(new NameSetComparisonStringFilter(typeof(AlgorithmParameterStringValueValueFilter).AssemblyQualifiedName, "Algorithm Parameter " + name + " Value", name));
    74 
    75         // algorithm filters
    76         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(AlgorithmNameFilter).AssemblyQualifiedName, "Algorithm Name", okb.Algorithms.Select(x => x.Name).Distinct().ToArray()));
    77         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(AlgorithmClassNameFilter).AssemblyQualifiedName, "Algorithm Class Name", okb.AlgorithmClasses.Select(x => x.Name).Distinct().ToArray()));
    78         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(AlgorithmPlatformNameFilter).AssemblyQualifiedName, "Algorithm Platform Name", okb.Platforms.Select(x => x.Name).Distinct().ToArray()));
    79         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(AlgorithmDataDataTypeNameFilter).AssemblyQualifiedName, "Algorithm Data Type Name", okb.Algorithms.Select(x => x.AlgorithmData.DataType.Name).Distinct().ToArray()));
    80 
    81         // problem parameter filters
    82         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ProblemParameterNameFilter).AssemblyQualifiedName, "Problem Parameter Name", okb.ProblemParameters.Select(x => x.Name).Distinct().ToArray()));
    83         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    84           filters.Add(new NameSetComparisonStringAvailableValuesFilter(typeof(ProblemParameterBlobValueDataTypeNameFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value Data Type Name", name, okb.ProblemParameterBlobValues.Where(x => x.ProblemParameter.Name == name).Select(x => x.DataType.Name).Distinct().ToArray()));
    85         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "varbinary").Select(x => x.Name).Distinct())
    86           filters.Add(new NameEqualityComparisonByteArrayFilter(typeof(ProblemParameterBlobValueValueFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value", name));
    87         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "bit").Select(x => x.Name).Distinct())
    88           filters.Add(new NameEqualityComparisonBoolFilter(typeof(ProblemParameterBoolValueValueFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value", name));
    89         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "float").Select(x => x.Name).Distinct())
    90           filters.Add(new NameOrdinalComparisonDoubleFilter(typeof(ProblemParameterFloatValueValueFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value", name));
    91         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "bigint").Select(x => x.Name).Distinct())
    92           filters.Add(new NameOrdinalComparisonLongFilter(typeof(ProblemParameterIntValueValueFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value", name));
    93         foreach (string name in okb.ProblemParameters.Where(x => x.DataType.SqlName == "nvarchar").Select(x => x.Name).Distinct())
    94           filters.Add(new NameSetComparisonStringFilter(typeof(ProblemParameterStringValueValueFilter).AssemblyQualifiedName, "Problem Parameter " + name + " Value", name));
    95 
    96         // problem filters
    97         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ProblemNameFilter).AssemblyQualifiedName, "Problem Name", okb.Problems.Select(x => x.Name).Distinct().ToArray()));
    98         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ProblemClassNameFilter).AssemblyQualifiedName, "Problem Class Name", okb.ProblemClasses.Select(x => x.Name).Distinct().ToArray()));
    99         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ProblemPlatformNameFilter).AssemblyQualifiedName, "Problem Platform Name", okb.Platforms.Select(x => x.Name).Distinct().ToArray()));
    100         filters.Add(new SetComparisonStringAvailableValuesFilter(typeof(ProblemDataDataTypeNameFilter).AssemblyQualifiedName, "Problem Data Type Name", okb.Problems.Select(x => x.ProblemData.DataType.Name).Distinct().ToArray()));
    101 
    102         // and/or filters
     43        filters.Add(new StringComparisonFilter(typeof(RunUserNameFilter).AssemblyQualifiedName, "Run User Name"));
     44        filters.Add(new StringComparisonFilter(typeof(RunClientNameFilter).AssemblyQualifiedName, "Run Client Name"));
     45        #endregion
     46
     47        #region Parameter Filters
     48        filters.Add(new StringComparisonAvailableValuesFilter(
     49          typeof(ValueNameFilter).AssemblyQualifiedName,
     50          "Parameter Name",
     51          okb.ValueNames.Where(x => x.Category == ValueNameCategory.Parameter).Select(x => x.Name).Distinct().ToArray()
     52        ));
     53        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Binary)).Select(x => x.Name).Distinct())
     54          filters.Add(new NameStringComparisonAvailableValuesFilter(
     55            typeof(ValueDataTypeNameFilter).AssemblyQualifiedName,
     56            "Parameter " + name + " Value Data Type Name",
     57            name,
     58            okb.Values.Where(x => (x.ValueName.Name == name) && (x.ValueName.Category == ValueNameCategory.Parameter) && (x.ValueName.Type == ValueNameType.Binary)).Select(x => x.DataType.Name).Distinct().ToArray()
     59          ));
     60        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Bool)).Select(x => x.Name).Distinct())
     61          filters.Add(new NameEqualityComparisonBoolFilter(
     62            typeof(BoolValueFilter).AssemblyQualifiedName,
     63            "Parameter " + name + " Value",
     64            name
     65          ));
     66        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Int)).Select(x => x.Name).Distinct())
     67          filters.Add(new NameOrdinalComparisonIntFilter(
     68            typeof(IntValueFilter).AssemblyQualifiedName,
     69            "Parameter " + name + " Value",
     70            name
     71          ));
     72        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Long)).Select(x => x.Name).Distinct())
     73          filters.Add(new NameOrdinalComparisonLongFilter(
     74            typeof(LongValueFilter).AssemblyQualifiedName,
     75            "Parameter " + name + " Value",
     76            name
     77          ));
     78        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Float)).Select(x => x.Name).Distinct())
     79          filters.Add(new NameOrdinalComparisonFloatFilter(
     80            typeof(FloatValueFilter).AssemblyQualifiedName,
     81            "Parameter " + name + " Value",
     82            name
     83          ));
     84        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Double)).Select(x => x.Name).Distinct())
     85          filters.Add(new NameOrdinalComparisonDoubleFilter(
     86            typeof(DoubleValueFilter).AssemblyQualifiedName,
     87            "Parameter " + name + " Value",
     88            name
     89          ));
     90        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.String)).Select(x => x.Name).Distinct())
     91          filters.Add(new NameStringComparisonFilter(
     92            typeof(StringValueFilter).AssemblyQualifiedName,
     93            "Parameter " + name + " Value",
     94            name
     95          ));
     96        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Parameter) && (x.Type == ValueNameType.Binary)).Select(x => x.Name).Distinct())
     97          filters.Add(new NameEqualityComparisonByteArrayFilter(
     98            typeof(BinaryValueFilter).AssemblyQualifiedName,
     99            "Parameter " + name + " Value",
     100            name
     101          ));
     102        #endregion
     103
     104        #region Result Filters
     105        filters.Add(new StringComparisonAvailableValuesFilter(
     106          typeof(ValueNameFilter).AssemblyQualifiedName,
     107          "Result Name",
     108          okb.ValueNames.Where(x => x.Category == ValueNameCategory.Result).Select(x => x.Name).Distinct().ToArray()
     109        ));
     110        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Binary)).Select(x => x.Name).Distinct())
     111          filters.Add(new NameStringComparisonAvailableValuesFilter(
     112            typeof(ValueDataTypeNameFilter).AssemblyQualifiedName,
     113            "Result " + name + " Value Data Type Name",
     114            name,
     115            okb.Values.Where(x => (x.ValueName.Name == name) && (x.ValueName.Category == ValueNameCategory.Result) && (x.ValueName.Type == ValueNameType.Binary)).Select(x => x.DataType.Name).Distinct().ToArray()
     116          ));
     117        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Bool)).Select(x => x.Name).Distinct())
     118          filters.Add(new NameEqualityComparisonBoolFilter(
     119            typeof(BoolValueFilter).AssemblyQualifiedName,
     120            "Result " + name + " Value",
     121            name
     122          ));
     123        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Int)).Select(x => x.Name).Distinct())
     124          filters.Add(new NameOrdinalComparisonIntFilter(
     125            typeof(IntValueFilter).AssemblyQualifiedName,
     126            "Result " + name + " Value",
     127            name
     128          ));
     129        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Long)).Select(x => x.Name).Distinct())
     130          filters.Add(new NameOrdinalComparisonLongFilter(
     131            typeof(LongValueFilter).AssemblyQualifiedName,
     132            "Result " + name + " Value",
     133            name
     134          ));
     135        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Float)).Select(x => x.Name).Distinct())
     136          filters.Add(new NameOrdinalComparisonFloatFilter(
     137            typeof(FloatValueFilter).AssemblyQualifiedName,
     138            "Result " + name + " Value",
     139            name
     140          ));
     141        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Double)).Select(x => x.Name).Distinct())
     142          filters.Add(new NameOrdinalComparisonDoubleFilter(
     143            typeof(DoubleValueFilter).AssemblyQualifiedName,
     144            "Result " + name + " Value",
     145            name
     146          ));
     147        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.String)).Select(x => x.Name).Distinct())
     148          filters.Add(new NameStringComparisonFilter(
     149            typeof(StringValueFilter).AssemblyQualifiedName,
     150            "Result " + name + " Value",
     151            name
     152          ));
     153        foreach (string name in okb.ValueNames.Where(x => (x.Category == ValueNameCategory.Result) && (x.Type == ValueNameType.Binary)).Select(x => x.Name).Distinct())
     154          filters.Add(new NameEqualityComparisonByteArrayFilter(
     155            typeof(BinaryValueFilter).AssemblyQualifiedName,
     156            "Result " + name + " Value",
     157            name
     158          ));
     159        #endregion
     160
     161        #region Algorithm Filters
     162        filters.Add(new StringComparisonAvailableValuesFilter(
     163          typeof(AlgorithmNameFilter).AssemblyQualifiedName,
     164          "Algorithm Name",
     165          okb.Algorithms.Select(x => x.Name).Distinct().ToArray()
     166        ));
     167        filters.Add(new StringComparisonAvailableValuesFilter(
     168          typeof(AlgorithmClassNameFilter).AssemblyQualifiedName,
     169          "Algorithm Class Name",
     170          okb.AlgorithmClasses.Select(x => x.Name).Distinct().ToArray()
     171        ));
     172        filters.Add(new StringComparisonAvailableValuesFilter(
     173          typeof(AlgorithmPlatformNameFilter).AssemblyQualifiedName,
     174          "Algorithm Platform Name",
     175          okb.Platforms.Select(x => x.Name).Distinct().ToArray()
     176        ));
     177        filters.Add(new StringComparisonAvailableValuesFilter(
     178          typeof(AlgorithmDataTypeNameFilter).AssemblyQualifiedName,
     179          "Algorithm Data Type Name",
     180          okb.Algorithms.Select(x => x.DataType.Name).Distinct().ToArray()
     181        ));
     182        #endregion
     183
     184        #region Problem Filters
     185        filters.Add(new StringComparisonAvailableValuesFilter(
     186          typeof(ProblemNameFilter).AssemblyQualifiedName,
     187          "Problem Name",
     188          okb.Problems.Select(x => x.Name).Distinct().ToArray()
     189        ));
     190        filters.Add(new StringComparisonAvailableValuesFilter(
     191          typeof(ProblemClassNameFilter).AssemblyQualifiedName,
     192          "Problem Class Name",
     193          okb.ProblemClasses.Select(x => x.Name).Distinct().ToArray()
     194        ));
     195        filters.Add(new StringComparisonAvailableValuesFilter(
     196          typeof(ProblemPlatformNameFilter).AssemblyQualifiedName,
     197          "Problem Platform Name",
     198          okb.Platforms.Select(x => x.Name).Distinct().ToArray()
     199        ));
     200        filters.Add(new StringComparisonAvailableValuesFilter(
     201          typeof(ProblemDataTypeNameFilter).AssemblyQualifiedName,
     202          "Problem Data Type Name",
     203          okb.Problems.Select(x => x.DataType.Name).Distinct().ToArray()
     204        ));
     205        #endregion
     206
     207        #region Combined Filters
    103208        filters.Add(new CombinedFilter(typeof(AndFilter).AssemblyQualifiedName, "AND", BooleanOperation.And));
    104209        filters.Add(new CombinedFilter(typeof(OrFilter).AssemblyQualifiedName, "OR", BooleanOperation.Or));
     210        #endregion
    105211      }
    106212      return filters.OrderBy(x => x.Label);
     
    119225    }
    120226
    121     public IEnumerable<DataTransfer.Run> GetRuns(IEnumerable<long> ids) {
     227    public IEnumerable<DataTransfer.Run> GetRuns(IEnumerable<long> ids, bool includeBinaryValues) {
    122228      using (OKBDataContext okb = new OKBDataContext()) {
    123229        DataLoadOptions dlo = new DataLoadOptions();
    124         dlo.LoadWith<DataAccess.Run>(x => x.ResultBlobValues);
    125         dlo.LoadWith<DataAccess.Run>(x => x.ResultBoolValues);
    126         dlo.LoadWith<DataAccess.Run>(x => x.ResultFloatValues);
    127         dlo.LoadWith<DataAccess.Run>(x => x.ResultIntValues);
    128         dlo.LoadWith<DataAccess.Run>(x => x.ResultStringValues);
    129         dlo.LoadWith<DataAccess.Run>(x => x.Experiment);
    130         dlo.LoadWith<DataAccess.ResultBlobValue>(x => x.Result);
    131         dlo.LoadWith<DataAccess.ResultBlobValue>(x => x.DataType);
    132         dlo.LoadWith<DataAccess.ResultBoolValue>(x => x.Result);
    133         dlo.LoadWith<DataAccess.ResultFloatValue>(x => x.Result);
    134         dlo.LoadWith<DataAccess.ResultIntValue>(x => x.Result);
    135         dlo.LoadWith<DataAccess.ResultStringValue>(x => x.Result);
    136         dlo.LoadWith<DataAccess.Experiment>(x => x.AlgorithmParameterBlobValues);
    137         dlo.LoadWith<DataAccess.Experiment>(x => x.AlgorithmParameterBoolValues);
    138         dlo.LoadWith<DataAccess.Experiment>(x => x.AlgorithmParameterFloatValues);
    139         dlo.LoadWith<DataAccess.Experiment>(x => x.AlgorithmParameterIntValues);
    140         dlo.LoadWith<DataAccess.Experiment>(x => x.AlgorithmParameterStringValues);
    141         dlo.LoadWith<DataAccess.Experiment>(x => x.ProblemParameterBlobValues);
    142         dlo.LoadWith<DataAccess.Experiment>(x => x.ProblemParameterBoolValues);
    143         dlo.LoadWith<DataAccess.Experiment>(x => x.ProblemParameterFloatValues);
    144         dlo.LoadWith<DataAccess.Experiment>(x => x.ProblemParameterIntValues);
    145         dlo.LoadWith<DataAccess.Experiment>(x => x.ProblemParameterStringValues);
    146         //dlo.LoadWith<DataAccess.Experiment>(x => x.Algorithm);
    147         //dlo.LoadWith<DataAccess.Experiment>(x => x.Problem);
    148         dlo.LoadWith<DataAccess.AlgorithmParameterBlobValue>(x => x.AlgorithmParameter);
    149         dlo.LoadWith<DataAccess.AlgorithmParameterBlobValue>(x => x.DataType);
    150         dlo.LoadWith<DataAccess.AlgorithmParameterBoolValue>(x => x.AlgorithmParameter);
    151         dlo.LoadWith<DataAccess.AlgorithmParameterFloatValue>(x => x.AlgorithmParameter);
    152         dlo.LoadWith<DataAccess.AlgorithmParameterIntValue>(x => x.AlgorithmParameter);
    153         dlo.LoadWith<DataAccess.AlgorithmParameterStringValue>(x => x.AlgorithmParameter);
    154         dlo.LoadWith<DataAccess.ProblemParameterBlobValue>(x => x.ProblemParameter);
    155         dlo.LoadWith<DataAccess.ProblemParameterBlobValue>(x => x.DataType);
    156         dlo.LoadWith<DataAccess.ProblemParameterBoolValue>(x => x.ProblemParameter);
    157         dlo.LoadWith<DataAccess.ProblemParameterFloatValue>(x => x.ProblemParameter);
    158         dlo.LoadWith<DataAccess.ProblemParameterIntValue>(x => x.ProblemParameter);
    159         dlo.LoadWith<DataAccess.ProblemParameterStringValue>(x => x.ProblemParameter);
    160         //dlo.LoadWith<DataAccess.Algorithm>(x => x.AlgorithmParameters);
    161         //dlo.LoadWith<DataAccess.Algorithm>(x => x.Results);
    162         //dlo.LoadWith<DataAccess.Algorithm>(x => x.AlgorithmClass);
    163         //dlo.LoadWith<DataAccess.Algorithm>(x => x.Platform);
    164         //dlo.LoadWith<DataAccess.Problem>(x => x.ProblemParameters);
    165         //dlo.LoadWith<DataAccess.Problem>(x => x.ProblemClass);
     230        // TODO: specify LoadWiths
    166231        okb.LoadOptions = dlo;
    167232
    168         return okb.Runs.Where(x => ids.Contains(x.Id)).Select(x => ConvertToQueryResult(x)).ToArray();
     233        return okb.Runs.Where(x => ids.Contains(x.Id)).Select(x => Convert.ToDto(x, includeBinaryValues)).ToArray();
    169234      }
    170235    }
     
    174239      return runs.Where(f.Expression);
    175240    }
    176 
    177     private QueryResult ConvertToQueryResult(DataAccess.Run run) {
    178       List<QueryValue> algorithmParameters = new List<QueryValue>();
    179       List<QueryValue> problemParameters = new List<QueryValue>();
    180       List<QueryValue> results = new List<QueryValue>();
    181 
    182       foreach (DataAccess.AlgorithmParameterBlobValue value in run.Experiment.AlgorithmParameterBlobValues)
    183         algorithmParameters.Add(new QueryBlobValue { Name = value.AlgorithmParameter.Name, DataTypeName = value.DataType.Name + " (" + value.DataType.TypeName + ")", Value = value.Value.ToArray() });
    184       foreach (DataAccess.AlgorithmParameterBoolValue value in run.Experiment.AlgorithmParameterBoolValues)
    185         algorithmParameters.Add(new QueryBoolValue { Name = value.AlgorithmParameter.Name, Value = value.Value });
    186       foreach (DataAccess.AlgorithmParameterFloatValue value in run.Experiment.AlgorithmParameterFloatValues)
    187         algorithmParameters.Add(new QueryFloatValue { Name = value.AlgorithmParameter.Name, Value = value.Value });
    188       foreach (DataAccess.AlgorithmParameterIntValue value in run.Experiment.AlgorithmParameterIntValues)
    189         algorithmParameters.Add(new QueryIntValue { Name = value.AlgorithmParameter.Name, Value = value.Value });
    190       foreach (DataAccess.AlgorithmParameterStringValue value in run.Experiment.AlgorithmParameterStringValues)
    191         algorithmParameters.Add(new QueryStringValue { Name = value.AlgorithmParameter.Name, Value = value.Value });
    192 
    193       foreach (DataAccess.ProblemParameterBlobValue value in run.Experiment.ProblemParameterBlobValues)
    194         problemParameters.Add(new QueryBlobValue { Name = value.ProblemParameter.Name, DataTypeName = value.DataType.Name + " (" + value.DataType.TypeName + ")", Value = value.Value.ToArray() });
    195       foreach (DataAccess.ProblemParameterBoolValue value in run.Experiment.ProblemParameterBoolValues)
    196         problemParameters.Add(new QueryBoolValue { Name = value.ProblemParameter.Name, Value = value.Value });
    197       foreach (DataAccess.ProblemParameterFloatValue value in run.Experiment.ProblemParameterFloatValues)
    198         problemParameters.Add(new QueryFloatValue { Name = value.ProblemParameter.Name, Value = value.Value });
    199       foreach (DataAccess.ProblemParameterIntValue value in run.Experiment.ProblemParameterIntValues)
    200         problemParameters.Add(new QueryIntValue { Name = value.ProblemParameter.Name, Value = value.Value });
    201       foreach (DataAccess.ProblemParameterStringValue value in run.Experiment.ProblemParameterStringValues)
    202         problemParameters.Add(new QueryStringValue { Name = value.ProblemParameter.Name, Value = value.Value });
    203 
    204       foreach (DataAccess.ResultBlobValue value in run.ResultBlobValues)
    205         results.Add(new QueryBlobValue { Name = value.Result.Name, DataTypeName = value.DataType.Name + " (" + value.DataType.TypeName + ")", Value = value.Value.ToArray() });
    206       foreach (DataAccess.ResultBoolValue value in run.ResultBoolValues)
    207         results.Add(new QueryBoolValue { Name = value.Result.Name, Value = value.Value });
    208       foreach (DataAccess.ResultFloatValue value in run.ResultFloatValues)
    209         results.Add(new QueryFloatValue { Name = value.Result.Name, Value = value.Value });
    210       foreach (DataAccess.ResultIntValue value in run.ResultIntValues)
    211         results.Add(new QueryIntValue { Name = value.Result.Name, Value = value.Value });
    212       foreach (DataAccess.ResultStringValue value in run.ResultStringValues)
    213         results.Add(new QueryStringValue { Name = value.Result.Name, Value = value.Value });
    214 
    215       QueryResult result = new QueryResult();
    216       result.Id = run.Id;
    217       result.AlgorithmParameters = algorithmParameters;
    218       result.ProblemParameters = problemParameters;
    219       result.Results = results;
    220       return result;
    221     }
    222241  }
    223242}
Note: See TracChangeset for help on using the changeset viewer.