Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.EvolutionTracking/HeuristicLab.EvolutionTracking/3.4/DirectedGraph/Interfaces/IDirectedGraph.cs @ 10278

Last change on this file since 10278 was 10278, checked in by bburlacu, 10 years ago

#1772: Implemented generic genealogy analyzer (should work with any encoding provided the proper wiring is performed in the problem class), and before/after operators for creation, mutation and crossover.

File size: 1.7 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 HeuristicLab.Core;
25
26namespace HeuristicLab.EvolutionTracking {
27  public interface IDirectedGraph : IItem { }
28  public interface IDirectedGraph<TVertex> : IDirectedGraph
29    where TVertex : class, IVertex {
30    bool Contains(TVertex vertex);
31    bool Any(Func<TVertex, bool> predicate); // graph contains any nodes matching the given predicate?
32    void Clear(); // clear graph
33    void AddVertex(TVertex vertex);
34    void RemoveVertex(TVertex vertex); // remove node if contained in the graph
35    List<TVertex> Nodes { get; }
36  }
37  public interface IDirectedGraph<TVertex, in TContent> : IDirectedGraph<TVertex>
38    where TVertex : class, IVertex
39    where TContent : class, IItem {
40    bool Contains(TContent content); // graph contains node with given content?
41  }
42}
Note: See TracBrowser for help on using the repository browser.