TraceLab Component Library
 All Classes Namespaces Files Functions Variables Enumerations Enumerator Properties
GibbsLDALoopComponent.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 TraceLabSDK;
19 using TraceLabSDK.Types;
20 using RPlugin.Core;
21 using TraceLab.Components.Types.Tracers.InformationRetrieval;
22 using TraceLab.Components.DevelopmentKit.Tracers.InformationRetrieval;
23 
24 namespace TraceLab.Components.Library.Tracers.InformationRetrieval
25 {
26  [Component(Name = "(loop) Gibbs Latent Dirichlet Analysis",
27  Description = "Performs LDA on a set of artifacts. Imports configurations for use in a loop. Uses package 'topicmodels'",
28  Author = "SEMERU; Evan Moritz",
29  Version = "1.0.0.0")]
30  [IOSpec(IOSpecType.Input, "SourceArtifacts", typeof(TLArtifactsCollection))]
31  [IOSpec(IOSpecType.Input, "TargetArtifacts", typeof(TLArtifactsCollection))]
32  [IOSpec(IOSpecType.Input, "Config", typeof(GibbsLDAConfig))]
33  [IOSpec(IOSpecType.Output, "Similarities", typeof(TLSimilarityMatrix))]
34  [Tag("RPlugin.Tracers.InformationRetrieval")]
35  [Tag("Tracers.InformationRetrieval")]
36  public class GibbsLDALoopComponent : BaseComponent
37  {
38  public GibbsLDALoopComponent(ComponentLogger log) : base(log) { }
39 
40  public override void Compute()
41  {
42  TLArtifactsCollection source = (TLArtifactsCollection)Workspace.Load("SourceArtifacts");
43  TLArtifactsCollection target = (TLArtifactsCollection)Workspace.Load("TargetArtifacts");
44  GibbsLDAConfig config = (GibbsLDAConfig)Workspace.Load("Config");
45  REngine engine = new REngine(config.RScriptPath);
46  TLSimilarityMatrix sims = (TLSimilarityMatrix)engine.Execute(new GibbsLDAScript(source, target, config));
47  Workspace.Store("Similarities", sims);
48  }
49  }
50 }