TraceLab Component Library
 All Classes Namespaces Files Functions Variables Enumerations Enumerator Properties
AffineTransformationLambdaComponent.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 System;
18 using System.Collections.Generic;
19 using System.Linq;
20 using System.Text;
21 using TraceLab.Components.DevelopmentKit.Postprocessors;
22 using TraceLabSDK;
23 using TraceLabSDK.Types;
24 
25 namespace TraceLab.Components.Library.Postprocessors
26 {
27  [Component(Name = "Affine Tranformation (lambda input)",
28  Description = "Performs an affine transformation combining two distributions.",
29  Author = "SEMERU; Evan Moritz",
30  Version = "1.0.0.0")]
31  [IOSpec(IOSpecType.Input, "LargeExpert", typeof(TLSimilarityMatrix))]
32  [IOSpec(IOSpecType.Input, "SmallExpert", typeof(TLSimilarityMatrix))]
33  [IOSpec(IOSpecType.Input, "Lambda", typeof(double))]
34  [IOSpec(IOSpecType.Output, "CombinedSimilarities", typeof(TLSimilarityMatrix))]
35  [Tag("Postprocessors")]
36  public class AffineTransformationLambdaComponent : BaseComponent
37  {
38  public AffineTransformationLambdaComponent(ComponentLogger log)
39  : base(log)
40  {
41 
42  }
43 
44  public override void Compute()
45  {
46  TLSimilarityMatrix large = (TLSimilarityMatrix)Workspace.Load("LargeExpert");
47  TLSimilarityMatrix small = (TLSimilarityMatrix)Workspace.Load("SmallExpert");
48  double lambda = (double)Workspace.Load("Lambda");
49  TLSimilarityMatrix combined = AffineTranformation.Transform(large, small, lambda);
50  Workspace.Store("CombinedSimilarities", combined);
51  }
52  }
53 }