TraceLab Component Library
 All Classes Namespaces Files Functions Variables Enumerations Enumerator Properties
TriplePCAComponent.cs
Go to the documentation of this file.
1 // TraceLab Component Library
2 // Copyright © 2012-2013 SEMERU
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
16 
17 using RPlugin.Core;
18 using TraceLab.Components.DevelopmentKit.Metrics.Traceability;
19 using TraceLab.Components.Types;
20 using TraceLabSDK;
21 using TraceLabSDK.Types;
22 
23 namespace TraceLab.Components.Library.Metrics.Traceability
24 {
25  [Component(Name = "Principal Component Analysis (triple)",
26  Description = "Performs PCA on three TLSimilarityMatrix.",
27  Author = "SEMERU; Evan Moritz",
28  Version = "1.0.0.0",
29  ConfigurationType = typeof(RConfig))]
30  [IOSpec(IOSpecType.Input, "Matrix1", typeof(TLSimilarityMatrix))]
31  [IOSpec(IOSpecType.Input, "Matrix2", typeof(TLSimilarityMatrix))]
32  [IOSpec(IOSpecType.Input, "Matrix3", typeof(TLSimilarityMatrix))]
33  [IOSpec(IOSpecType.Output, "Matrix1Contribution", typeof(double))]
34  [IOSpec(IOSpecType.Output, "Matrix2Contribution", typeof(double))]
35  [IOSpec(IOSpecType.Output, "Matrix3Contribution", typeof(double))]
36  [Tag("RPlugin.Metrics.Traceability")]
37  [Tag("Metrics.Traceability")]
38  public class TriplePCAComponent : BaseComponent
39  {
40  private RConfig _config;
41 
42  public TriplePCAComponent(ComponentLogger log)
43  : base(log)
44  {
45  _config = new RConfig();
46  Configuration = _config;
47  }
48 
49  public override void Compute()
50  {
51  TLSimilarityMatrix matrix1 = (TLSimilarityMatrix)Workspace.Load("Matrix1");
52  TLSimilarityMatrix matrix2 = (TLSimilarityMatrix)Workspace.Load("Matrix2");
53  TLSimilarityMatrix matrix3 = (TLSimilarityMatrix)Workspace.Load("Matrix3");
54  REngine engine = new REngine(_config.RScriptPath);
55  double[] results = (double[])engine.Execute(new PCAScript(matrix1, matrix2, matrix3));
56  Workspace.Store("Matrix1Contribution", results[0]);
57  Workspace.Store("Matrix2Contribution", results[1]);
58  Workspace.Store("Matrix3Contribution", results[2]);
59  }
60  }
61 }