Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.Core/3.3/OperatorGraph.cs @ 3317

Last change on this file since 3317 was 3317, checked in by swagner, 14 years ago

Implemented ReadOnlyView property for items (#969).

File size: 9.6 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Collections.Generic;
24using System.Text;
25using System.Xml;
26using System.Linq;
27using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
28using HeuristicLab.Common;
29using HeuristicLab.Collections;
30
31namespace HeuristicLab.Core {
32  /// <summary>
33  /// Represents a graph of operators.
34  /// </summary>
35  [Item("Operator Graph", "Represents a graph of operators.")]
36  [Creatable("Algorithm Design")]
37  [StorableClass]
38  public class OperatorGraph : Item {
39    [Storable]
40    private OperatorSet operators;
41    /// <summary>
42    /// Gets all operators of the current instance.
43    /// </summary>
44    public OperatorSet Operators {
45      get { return operators; }
46    }
47
48    [Storable]
49    private IOperator initialOperator;
50    /// <summary>
51    /// Gets or sets the initial operator (the starting one).
52    /// </summary>
53    /// <remarks>Calls <see cref="OnInitialOperatorChanged"/> in the setter.</remarks>
54    public IOperator InitialOperator {
55      get { return initialOperator; }
56      set {
57        if (initialOperator != value) {
58          if (value != null) Operators.Add(value);
59          initialOperator = value;
60          OnInitialOperatorChanged();
61        }
62      }
63    }
64
65    [Storable]
66    private IDeepCloneable visualizationInfo;
67    /// <summary>
68    /// Gets or sets the visualizationInfo.
69    /// </summary>
70    /// /// <remarks>The VisualizationInfo can only be set once and fires afterwards and InvalidOperationException</remarks>
71    public IDeepCloneable VisualizationInfo {
72      get { return visualizationInfo; }
73      set {
74        if (visualizationInfo != null)
75          throw new InvalidOperationException("The value of the property VisualizationInfo is already set and cannot be set again.");
76        visualizationInfo = value;
77      }
78    }
79
80    /// <summary>
81    /// Initializes a new instance of <see cref="OperatorGraph"/>.
82    /// </summary>
83    public OperatorGraph() {
84      operators = new OperatorSet();
85      initialOperator = null;
86      visualizationInfo = null;
87      Initialize();
88    }
89    [StorableConstructor]
90    protected OperatorGraph(bool deserializing) : base(deserializing) { }
91
92    [StorableHook(HookType.AfterDeserialization)]
93    private void Initialize() {
94      RegisterOperatorsEvents();
95    }
96
97    /// <summary>
98    /// Clones the current instance (deep clone).
99    /// </summary>
100    /// <remarks>Deep clone through <see cref="cloner.Clone"/> method of helper class
101    /// <see cref="Auxiliary"/>.</remarks>
102    /// <param name="clonedObjects">Dictionary of all already cloned objects. (Needed to avoid cycles.)</param>
103    /// <returns>The cloned object as <see cref="OperatorGraph"/>.</returns>
104    public override IDeepCloneable Clone(Cloner cloner) {
105      OperatorGraph clone = (OperatorGraph)base.Clone(cloner);
106      clone.operators = (OperatorSet)cloner.Clone(operators);
107      clone.initialOperator = (IOperator)cloner.Clone(initialOperator);
108      clone.visualizationInfo = cloner.Clone(visualizationInfo);
109      clone.Initialize();
110      return clone;
111    }
112
113    /// <inheritdoc/>
114    public event EventHandler InitialOperatorChanged;
115    /// <summary>
116    /// Fires a new <c>InitialOperatorChanged</c> event.
117    /// </summary>
118    protected virtual void OnInitialOperatorChanged() {
119      if (InitialOperatorChanged != null)
120        InitialOperatorChanged(this, EventArgs.Empty);
121    }
122
123    #region Operators Events
124    private void AddOperator(IOperator op) {
125      RegisterOperatorEvents(op);
126      foreach (IParameter param in op.Parameters)
127        AddParameter(param);
128    }
129    private void RemoveOperator(IOperator op) {
130      foreach (IParameter param in op.Parameters)
131        RemoveParameter(param);
132      DeregisterOperatorEvents(op);
133
134      // remove edges to removed operator
135      var opParams = from o in Operators
136                     from p in o.Parameters
137                     where p is IValueParameter<IOperator>
138                     where (((IValueParameter<IOperator>)p).Value != null) && (((IValueParameter<IOperator>)p).Value == op)
139                     select (IValueParameter<IOperator>)p;
140      foreach (IValueParameter<IOperator> opParam in opParams)
141        opParam.Value = null;
142    }
143    private void AddParameter(IParameter param) {
144      IValueParameter<IOperator> opParam = param as IValueParameter<IOperator>;
145      if (opParam != null) {
146        RegisterOperatorParameterEvents(opParam);
147        if (opParam.Value != null) Operators.Add(opParam.Value);
148      }
149    }
150    private void RemoveParameter(IParameter param) {
151      IValueParameter<IOperator> opParam = param as IValueParameter<IOperator>;
152      if (opParam != null) {
153        DeregisterOperatorParameterEvents(opParam);
154      }
155    }
156
157    private void RegisterOperatorsEvents() {
158      if (operators != null) {
159        operators.ItemsAdded += new CollectionItemsChangedEventHandler<IOperator>(Operators_ItemsAdded);
160        operators.ItemsRemoved += new CollectionItemsChangedEventHandler<IOperator>(Operators_ItemsRemoved);
161        operators.CollectionReset += new CollectionItemsChangedEventHandler<IOperator>(Operators_CollectionReset);
162        foreach (IOperator op in operators) {
163          RegisterOperatorEvents(op);
164          foreach (IParameter param in op.Parameters) {
165            IValueParameter<IOperator> opParam = param as IValueParameter<IOperator>;
166            if (opParam != null) RegisterOperatorParameterEvents(opParam);
167          }
168        }
169      }
170    }
171    private void RegisterOperatorEvents(IOperator op) {
172      op.Parameters.ItemsAdded += new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsAdded);
173      op.Parameters.ItemsRemoved += new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsRemoved);
174      op.Parameters.ItemsReplaced += new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsReplaced);
175      op.Parameters.CollectionReset += new CollectionItemsChangedEventHandler<IParameter>(Parameters_CollectionReset);
176    }
177    private void DeregisterOperatorEvents(IOperator op) {
178      op.Parameters.ItemsAdded -= new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsAdded);
179      op.Parameters.ItemsRemoved -= new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsRemoved);
180      op.Parameters.ItemsReplaced -= new CollectionItemsChangedEventHandler<IParameter>(Parameters_ItemsReplaced);
181      op.Parameters.CollectionReset -= new CollectionItemsChangedEventHandler<IParameter>(Parameters_CollectionReset);
182    }
183    private void RegisterOperatorParameterEvents(IValueParameter<IOperator> opParam) {
184      opParam.ValueChanged += new EventHandler(opParam_ValueChanged);
185    }
186    private void DeregisterOperatorParameterEvents(IValueParameter<IOperator> opParam) {
187      opParam.ValueChanged -= new EventHandler(opParam_ValueChanged);
188    }
189
190    private void Operators_ItemsAdded(object sender, CollectionItemsChangedEventArgs<IOperator> e) {
191      foreach (IOperator op in e.Items)
192        AddOperator(op);
193    }
194    private void Operators_ItemsRemoved(object sender, CollectionItemsChangedEventArgs<IOperator> e) {
195      foreach (IOperator op in e.Items)
196        RemoveOperator(op);
197      if (!Operators.Contains(InitialOperator)) InitialOperator = null;
198    }
199    private void Operators_CollectionReset(object sender, CollectionItemsChangedEventArgs<IOperator> e) {
200      foreach (IOperator op in e.OldItems)
201        RemoveOperator(op);
202      foreach (IOperator op in e.Items)
203        AddOperator(op);
204      if (!Operators.Contains(InitialOperator)) InitialOperator = null;
205    }
206    private void Parameters_ItemsAdded(object sender, CollectionItemsChangedEventArgs<IParameter> e) {
207      foreach (IParameter param in e.Items)
208        AddParameter(param);
209    }
210    private void Parameters_ItemsRemoved(object sender, CollectionItemsChangedEventArgs<IParameter> e) {
211      foreach (IParameter param in e.Items)
212        RemoveParameter(param);
213    }
214    private void Parameters_ItemsReplaced(object sender, CollectionItemsChangedEventArgs<IParameter> e) {
215      foreach (IParameter param in e.OldItems)
216        RemoveParameter(param);
217      foreach (IParameter param in e.Items)
218        AddParameter(param);
219    }
220    private void Parameters_CollectionReset(object sender, CollectionItemsChangedEventArgs<IParameter> e) {
221      foreach (IParameter param in e.OldItems)
222        RemoveParameter(param);
223      foreach (IParameter param in e.Items)
224        AddParameter(param);
225    }
226    private void opParam_ValueChanged(object sender, EventArgs e) {
227      IValueParameter<IOperator> opParam = (IValueParameter<IOperator>)sender;
228      if (opParam.Value != null) Operators.Add(opParam.Value);
229    }
230    #endregion
231  }
232}
Note: See TracBrowser for help on using the repository browser.