#region License Information
/* HeuristicLab
* Copyright (C) 2002-2018 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 HeuristicLab.Common;
using HeuristicLab.IGraph.Wrappers;
using Microsoft.VisualStudio.TestTools.UnitTesting;
namespace HeuristicLab.Tests {
[TestClass]
public class IGraphWrappersGraphTest {
[TestMethod]
[TestCategory("ExtLibs")]
[TestCategory("ExtLibs.igraph")]
[TestProperty("Time", "short")]
public void IGraphWrappersGraphConstructionAndFinalizationTest() {
using (var graph = new Graph(5, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 3),
Tuple.Create(2, 4),
Tuple.Create(3, 4),
})) {
Assert.AreEqual(5, graph.Vertices);
Assert.IsFalse(graph.IsDirected);
}
using (var graph = new Graph(3, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
}, directed: true)) {
Assert.AreEqual(3, graph.Vertices);
Assert.IsTrue(graph.IsDirected);
}
}
[TestMethod]
[TestCategory("ExtLibs")]
[TestCategory("ExtLibs.igraph")]
[TestProperty("Time", "short")]
public void IGraphWrappersGraphDensityTest() {
using (var graph = new Graph(5, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 3),
Tuple.Create(2, 4),
Tuple.Create(3, 4),
})) {
var density = graph.Density();
// in un-directed graphs edges count twice
Assert.IsTrue(density.IsAlmost(12 / 20.0));
}
using (var graph = new Graph(5, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 3),
Tuple.Create(2, 4),
Tuple.Create(3, 4),
}, directed: true)) {
var density = graph.Density();
// in directed graphs edges count twice
Assert.IsTrue(density.IsAlmost(6 / 20.0));
}
}
[TestMethod]
[TestCategory("ExtLibs")]
[TestCategory("ExtLibs.igraph")]
[TestProperty("Time", "short")]
public void IGraphWrappersGraphPageRankTest() {
using (var graph = new Graph(4, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 0),
Tuple.Create(3, 2),
}, directed: true)) {
var ranks = graph.PageRank();
Assert.AreEqual(4, ranks.Length);
Assert.AreEqual(0.372, ranks[0], 0.01);
Assert.AreEqual(0.195, ranks[1], 0.01);
Assert.AreEqual(0.394, ranks[2], 0.01);
Assert.AreEqual(0.037, ranks[3], 0.01);
}
using (var graph = new Graph(4, new[] {
Tuple.Create(0, 1),
Tuple.Create(1, 2),
Tuple.Create(2, 3),
Tuple.Create(3, 0),
}, directed: true)) {
var ranks = graph.PageRank();
Assert.AreEqual(4, ranks.Length);
Assert.AreEqual(0.250, ranks[0], 0.01);
Assert.AreEqual(0.250, ranks[1], 0.01);
Assert.AreEqual(0.250, ranks[2], 0.01);
Assert.AreEqual(0.250, ranks[3], 0.01);
}
using (var graph = new Graph(4, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(0, 3),
Tuple.Create(1, 0),
Tuple.Create(2, 0),
Tuple.Create(3, 0),
}, directed: true)) {
var ranks = graph.PageRank();
Assert.AreEqual(4, ranks.Length);
Assert.AreEqual(0.480, ranks[0], 0.01);
Assert.AreEqual(0.173, ranks[1], 0.01);
Assert.AreEqual(0.173, ranks[2], 0.01);
Assert.AreEqual(0.173, ranks[3], 0.01);
}
}
[TestMethod]
[TestCategory("ExtLibs")]
[TestCategory("ExtLibs.igraph")]
[TestProperty("Time", "short")]
public void IGraphWrappersGraphBreadthFirstWalkTest() {
using (var graph = new Graph(4, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 0),
Tuple.Create(3, 2),
}, directed: true)) {
var visited = new HashSet();
BreadthFirstHandler handler = (graph1, currentVertexId, previousVertexId, nextVertexId, rank, distance, tag) => {
visited.Add(currentVertexId);
return false;
};
graph.BreadthFirstWalk(handler, 0, DirectedWalkMode.All, true, null);
Assert.AreEqual(4, visited.Count);
Assert.IsTrue(visited.Contains(0));
Assert.IsTrue(visited.Contains(1));
Assert.IsTrue(visited.Contains(2));
Assert.IsTrue(visited.Contains(3));
}
}
[TestMethod]
[TestCategory("ExtLibs")]
[TestCategory("ExtLibs.igraph")]
[TestProperty("Time", "short")]
public void IGraphWrappersGraphDepthFirstWalkTest() {
using (var graph = new Graph(4, new[] {
Tuple.Create(0, 1),
Tuple.Create(0, 2),
Tuple.Create(1, 2),
Tuple.Create(2, 0),
Tuple.Create(3, 2),
}, directed: true)) {
var visited = new HashSet();
DepthFirstHandler handler = (graph1, vertexId, distance, tag) => {
visited.Add(vertexId);
return false;
};
graph.DepthFirstWalk(handler, handler, 0, DirectedWalkMode.All, true, null);
Assert.AreEqual(4, visited.Count);
Assert.IsTrue(visited.Contains(0));
Assert.IsTrue(visited.Contains(1));
Assert.IsTrue(visited.Contains(2));
Assert.IsTrue(visited.Contains(3));
}
}
}
}