Free cookie consent management tool by TermsFeed Policy Generator

source: branches/thasling/DistributedGA/DistributedGA.Hive/P2PTask.cs @ 13808

Last change on this file since 13808 was 13557, checked in by thasling, 9 years ago

Implemented P2PTask-class
Changed communication protocoll http --> net.tcp
Logger is now Parameter of P2PTask

File size: 7.5 KB
Line 
1using System;
2using System.Linq;
3using System.Threading;
4using System.Threading.Tasks;
5using DistributedGA.Core;
6using DistributedGA.Core.Domain;
7using DistributedGA.Core.Implementation;
8using DistributedGA.Core.Interface;
9using HeuristicLab.Common;
10using HeuristicLab.Core;
11using HeuristicLab.Data;
12using HeuristicLab.Optimization;
13using HeuristicLab.Parameters;
14using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
15
16namespace DistributedGA.Hive {
17  [StorableClass]
18  [Creatable(Category = "Haslinger's Very Special XO", Priority = 1000)]
19  public class P2PTask : ParameterizedNamedItem, IOptimizer {
20
21
22    [Storable]
23    private DateTime startTime;
24    [Storable]
25    private RunCollection runCollection;
26
27    #region Constructors and Cloning
28    [StorableConstructor]
29    protected P2PTask(bool deserializing) { }
30    protected P2PTask(P2PTask original, Cloner cloner)
31      : base(original, cloner) {
32      startTime = original.startTime;
33      runCollection = cloner.Clone(original.runCollection);
34    }
35    public P2PTask() {
36      Name = "P2PTask";
37      Description = "P2PTask";
38      runCollection = new RunCollection();
39
40      Parameters.Add(new ValueParameter<StringValue>("LanIpPrefix", "", new StringValue("10.")));
41      Parameters.Add(new ValueParameter<StringValue>("ContactServerURL", "", new StringValue("net.tcp://10.42.1.150:9090/DistributedGA.ContactServer/ContactService")));
42      Parameters.Add(new ValueParameter<Log>("Log", "", new Log()));
43
44    }
45
46    [StorableHook(HookType.AfterDeserialization)]
47    protected virtual void AfterDeserialization() {
48    }
49
50    public override IDeepCloneable Clone(Cloner cloner) {
51      return new P2PTask(this, cloner);
52    }
53    #endregion
54
55    #region ITask Members
56    public ExecutionState ExecutionState { get; private set; }
57
58    public TimeSpan ExecutionTime { get; private set; }
59
60    public void Prepare() {
61      Prepare(true);
62    }
63    public void Prepare(bool clearRuns) {
64      // ignore
65      ExecutionState = HeuristicLab.Core.ExecutionState.Prepared;
66      OnExecutionStateChanged();
67      OnPrepared();
68    }
69
70    private CancellationTokenSource cts;
71    private ManualResetEvent stoppedEvent;
72
73    public void Start() {
74      Task.Factory.StartNew(() => {
75        cts = new CancellationTokenSource();
76        stoppedEvent = new ManualResetEvent(false);
77        startTime = DateTime.Now;
78
79        ExecutionState = HeuristicLab.Core.ExecutionState.Started;
80        OnExecutionStateChanged();
81        OnStarted();
82
83        var log = ((Log)(Parameters["Log"].ActualValue));
84
85
86        try {
87
88          log.LogMessage("Starting peer...");
89          IMessageHandler h = new PeerNetworkMessageHandler();
90          var lanIpPrefix = ((StringValue)(Parameters["LanIpPrefix"].ActualValue)).Value;
91          var contactServerUri = ((StringValue)(Parameters["ContactServerURL"].ActualValue)).Value;
92          h.Init(lanIpPrefix, contactServerUri);
93          PeerInfo pi = h.GetPeerInfo();
94          log.LogMessage(string.Format("Peer is hostet at IP: {0} and port: {1}", pi.IpAddress, pi.Port));
95          Thread.Sleep(1000 * 20);
96          log.LogMessage("Current peers within network:");
97          foreach (var item in h.GetCurrentNetwork()) {
98            log.LogMessage(string.Format("Peer at {0}:{1}", item.IpAddress, item.Port));
99          }
100          int i = 1;
101          while (i < 10 && !cts.Token.IsCancellationRequested) {
102            i++;
103            Thread.Sleep(1000 * 10);
104            var pop1 = CreatePopulation();
105            log.LogMessage("Publish population into network...");
106            h.PublishDataToNetwork(pop1);
107            log.LogMessage("Population published.");
108            log.LogMessage("Recieved populations:");
109            foreach (var item in h.GetDataFromNetwork()) {
110              log.LogMessage(string.Format("Population with Quality: {0:2} in Iteration {1}", item.Quality, item.IterationNumber));
111            }
112            ExecutionTime = DateTime.Now - startTime;
113            OnExecutionTimeChanged();
114          }
115        } catch (Exception ex) {
116          log.LogMessage(ex.Message);
117          log.LogMessage("press any key to continue...");
118        }
119
120        var run = new Run();
121        var results = new ResultCollection();
122
123        run.Results.Add("Execution Time", new TimeSpanValue(ExecutionTime));
124        run.Results.Add("Log", log);
125
126        runCollection.Add(run);
127
128        stoppedEvent.Set();
129        ExecutionState = HeuristicLab.Core.ExecutionState.Stopped;
130
131        OnExecutionStateChanged();
132        OnStopped();
133      });
134    }
135
136
137    public void Pause() {
138      if (cts != null) cts.Cancel();
139      stoppedEvent.WaitOne();
140
141      ExecutionState = HeuristicLab.Core.ExecutionState.Paused;
142      OnExecutionStateChanged();
143
144      OnPaused();
145    }
146
147    public void Stop() {
148      if (cts != null) cts.Cancel();
149      stoppedEvent.WaitOne();
150
151      ExecutionState = HeuristicLab.Core.ExecutionState.Stopped;
152      OnExecutionStateChanged();
153
154      OnStopped();
155    }
156
157    public event EventHandler Started;
158    protected virtual void OnStarted() {
159      EventHandler handler = Started;
160      if (handler != null) handler(this, EventArgs.Empty);
161    }
162
163    public event EventHandler Stopped;
164    protected virtual void OnStopped() {
165      EventHandler handler = Stopped;
166      if (handler != null) handler(this, EventArgs.Empty);
167    }
168
169    public event EventHandler Paused;
170    protected virtual void OnPaused() {
171      EventHandler handler = Paused;
172      if (handler != null) handler(this, EventArgs.Empty);
173    }
174
175    public event EventHandler Prepared;
176    protected virtual void OnPrepared() {
177      EventHandler handler = Prepared;
178      if (handler != null) handler(this, EventArgs.Empty);
179    }
180
181
182    public event EventHandler ComputeInParallelChanged;
183    protected virtual void OnComputeInParallelChanged() {
184      EventHandler handler = ComputeInParallelChanged;
185      if (handler != null) handler(this, EventArgs.Empty);
186    }
187    #endregion
188
189    #region Events
190    public event EventHandler ExecutionTimeChanged;
191    protected virtual void OnExecutionTimeChanged() {
192      EventHandler handler = ExecutionTimeChanged;
193      if (handler != null) handler(this, EventArgs.Empty);
194    }
195    public event EventHandler ExecutionStateChanged;
196    protected virtual void OnExecutionStateChanged() {
197      EventHandler handler = ExecutionStateChanged;
198      if (handler != null) handler(this, EventArgs.Empty);
199    }
200    #endregion
201
202    public override string ToString() {
203      return Name;
204    }
205
206
207
208    private static SolutionInfo[] CreatePopulation() {
209      SolutionInfo si1 = new SolutionInfo() {
210        IterationNumber = 1,
211        Quality = 3.5f,
212        Solution = new Solution() {
213        }
214      };
215      SolutionInfo si2 = new SolutionInfo() {
216        IterationNumber = 2,
217        Quality = 3.5f,
218        Solution = new Solution() {
219        }
220      };
221      SolutionInfo si3 = new SolutionInfo() {
222        IterationNumber = 3,
223        Quality = 3.5f,
224        Solution = new Solution() {
225        }
226      };
227      return new SolutionInfo[] { si1, si2, si3 };
228    }
229
230    public System.Collections.Generic.IEnumerable<IOptimizer> NestedOptimizers {
231      get { return Enumerable.Empty<IOptimizer>(); }
232    }
233
234    public RunCollection Runs {
235      get { return runCollection; }
236    }
237
238    public event EventHandler<EventArgs<Exception>> ExceptionOccurred;
239
240  }
241}
Note: See TracBrowser for help on using the repository browser.