-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMorrisDesignResultsAnalyzer.cs
More file actions
65 lines (50 loc) · 2.48 KB
/
MorrisDesignResultsAnalyzer.cs
File metadata and controls
65 lines (50 loc) · 2.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
using System;
using System.Collections.Generic;
using System.Linq;
using SensitivityAnalysis.MorrisDesign;
namespace sensitivity_analysis
{
public class MorrisDesignResultsAnalyzer : IResultsAnalyzer<MorrisDesignSensitivityAnalysisResult>
{
public MorrisDesignResultsAnalyzer()
{
}
public static IDictionary<string, double> MorrisParameterResults(MorrisDesignSensitivityAnalysisResult result, int paramIndex)
{
var paramDict = new Dictionary<string, double>();
// get SA value for current parameter
double value;
value = result.AbsoluteMeans.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("absolute_mean", value);
value = result.Means.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("mean", value);
value = result.NormalizedAbsoluteMeans.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("normalized_absolute_mean", value);
value = result.NormalizedMeans.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("normalized_mean", value);
value = result.AbsoluteStandardDeviations.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("absolute_standard_deviation", value);
value = result.StandardDeviations.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("standard_deviation", value);
value = result.NormalizedAbsoluteStandardDeviations.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("normalized_absolute_standard_deviation", value);
value = result.NormalizedStandardDeviations.FirstOrDefault(sv => (sv.ParameterId == paramIndex)).Value;
paramDict.Add("normalized_standard_deviation", value);
return paramDict;
}
// TODO: this can be refactored IResultsAnalyzer -> AbstractResultsAnalyzer, where MoeResults can be its method using abstract method *ParameterResults
#region IResultsAnalyser implementation
public IDictionary<string, System.Collections.Generic.IDictionary<string, double>> MoeResults(MorrisDesignSensitivityAnalysisResult moeResult, string[] paramIds)
{
IDictionary<string, IDictionary<string, double>> sobolMoeResults = new Dictionary<string, IDictionary<string, double>>();
// for each paramId create sub-dictionary
for (int i=0; i<paramIds.Length; ++i) {
var paramName = paramIds[i];
var paramDict = MorrisParameterResults(moeResult, i);
sobolMoeResults.Add(paramName, paramDict);
}
return sobolMoeResults;
}
#endregion
}
}