#region License Information
/* HeuristicLab
* Copyright (C) 2002-2008 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
*
* This file is part of HeuristicLab.
*
* HeuristicLab is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* HeuristicLab is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with HeuristicLab. If not, see .
*/
#endregion
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using HeuristicLab.Core;
using System.Xml;
using HeuristicLab.CEDMA.DB.Interfaces;
using HeuristicLab.Operators;
namespace HeuristicLab.CEDMA.Core {
public class Agent : IAgent {
public IDatabase Database { get; set; }
public long Id { get; set; }
public string Name { get; set; }
public ProcessStatus Status { get; set; }
public bool Terminated { get; set; }
private OperatorGraph operatorGraph;
public IOperatorGraph OperatorGraph {
get { return operatorGraph; }
}
public Agent()
: base() {
operatorGraph = new OperatorGraph();
}
public Agent(IDatabase database, long id)
: this() {
Database = database;
Id = id;
}
public void Save() {
Database.UpdateAgent(Id, Name);
Database.UpdateAgent(Id, Status);
Database.UpdateAgent(Id, PersistenceManager.SaveToGZip(OperatorGraph));
}
public void Start() {
Status = ProcessStatus.Waiting;
Save();
}
public ICollection SubAgents {
get {
List agents = new List();
foreach(AgentEntry entry in Database.GetSubAgents(Id)) {
Agent newAgent = new Agent(Database, entry.Id);
newAgent.Name = entry.Name;
newAgent.Status = entry.Status;
agents.Add(newAgent);
}
return agents;
}
}
public ICollection Results {
get {
List results = new List();
foreach(ResultEntry entry in Database.GetResults(Id)) {
Result result = new Result(Database, entry.Id);
result.Summary = entry.Summary;
result.Description = entry.Description;
results.Add(result);
}
return results;
}
}
public IView CreateView() {
if(OperatorGraph.Operators.Count == 0) {
byte[] rawData = Database.GetAgentRawData(Id);
IOperatorGraph opGraph = (IOperatorGraph)PersistenceManager.RestoreFromGZip(rawData);
foreach(IOperator op in opGraph.Operators) OperatorGraph.AddOperator(op);
OperatorGraph.InitialOperator = opGraph.InitialOperator;
OperatorLinkPatcher.LinkDatabase(OperatorGraph, Database);
}
return new AgentView(this);
}
}
}