本文整理汇总了C#中BlueSpider.Blob.Basic.Network.AdjList.BasicAdjList类的典型用法代码示例。如果您正苦于以下问题:C# BasicAdjList类的具体用法?C# BasicAdjList怎么用?C# BasicAdjList使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
BasicAdjList类属于BlueSpider.Blob.Basic.Network.AdjList命名空间,在下文中一共展示了BasicAdjList类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C#代码示例。
示例1: ChangeEventsEnabled_When_False_Prevents_NetworkChanged_Fired_When_RemoveEdge_Is_Called
public void ChangeEventsEnabled_When_False_Prevents_NetworkChanged_Fired_When_RemoveEdge_Is_Called(int nodeCount, int edgeCount, int edgesToRemove)
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
Random rand = new Random();
for (int i = 0; i < nodeCount; i++)
net.CreateNode();
INode nodeA = null;
INode nodeB = null;
IEdge[] edges = new IEdge[edgeCount];
for (int i = 0; i < edgeCount; i++)
{
nodeA = net.Nodes[rand.Next(nodeCount)];
nodeB = net.Nodes[rand.Next(nodeCount)];
edges[i] = net.CreateEdge(nodeA, nodeB);
}
//---------------------
var helper = new NetworkChangedEventsTestHelper();
net.NetworkChanged += new NetworkChangedEventHandler<INetwork, NetworkChangedEventArgs>(helper.NetworkChanged_DummyHandler);
net.ChangeEventsEnabled = false;
for (int i = 0; i < edges.Length; i++)
{
net.RemoveEdge(edges[i]);
}
Assert.Equal(0, helper.NetworkChanged_TimesCalled);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:31,代码来源:BasicAdjList_As_INetworkChangeEventsFixture.cs
示例2: ContainsSelfLoops
public void ContainsSelfLoops()
{
var net =new BasicAdjList(Guid.NewGuid());
BasicNode nodeA = net.CreateNode() as BasicNode;
BasicNode nodeB = net.CreateNode() as BasicNode;
BasicNode nodeC = net.CreateNode() as BasicNode;
BasicNode nodeD = net.CreateNode() as BasicNode;
net.CreateEdge(nodeA, nodeB);
net.CreateEdge(nodeA, nodeA);
net.CreateEdge(nodeA, nodeD);
net.CreateEdge(nodeD, nodeD);
net.CreateEdge(nodeD, nodeD);
bool result = nodeA.ContainsSelfLoops();
Assert.True(result);
result = nodeB.ContainsSelfLoops();
Assert.False(result);
result = nodeC.ContainsSelfLoops();
Assert.False(result);
result = nodeD.ContainsSelfLoops();
Assert.True(result);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:26,代码来源:BasicNodeFixture.cs
示例3: AddingEdges_Adds_Row_With_Matching_Key_In_EdgeData
public void AddingEdges_Adds_Row_With_Matching_Key_In_EdgeData(int nodeCount, int edgeCount)
{
Random rand = new Random();
var net = new BasicAdjList(Guid.NewGuid());
var table = new DataAttributeTable<IEdge>();
table.Network = net;
net.EdgeData = table;
for (int i = 0; i < nodeCount; i++)
{
var node = net.CreateNode();
}
INode nodeA = null;
INode nodeB = null;
IEdge edge = null;
for (int i = 0; i < edgeCount; i++)
{
nodeA = net.Nodes[rand.Next(nodeCount)];
nodeB = net.Nodes[rand.Next(nodeCount)];
edge = net.CreateEdge(nodeA, nodeB);
Assert.Equal((i + 1), net.EdgeCount);
Assert.Equal((i + 1), table.RowCount);
Assert.True(table.RowOwnerMap.ContainsKey(edge));
}
}
开发者ID:BgRva,项目名称:Blob1,代码行数:26,代码来源:BasicAdjList_DataAttributes_Fixture.cs
示例4: ModifyIsDirectedProperty
public void ModifyIsDirectedProperty(BasicAdjList network, bool isDirected)
{
if (network.IsDirected != isDirected)
{
network.IsDirected = isDirected;
}
}
开发者ID:BgRva,项目名称:Blob1,代码行数:7,代码来源:SimpleAdjListDirectedModifier.cs
示例5: AddEdge_Throws_Ex_If_Edge_Is_Null
public void AddEdge_Throws_Ex_If_Edge_Is_Null()
{
var net =new BasicAdjList(Guid.NewGuid());
BasicNode node0 = new BasicNode(net);
BasicEdge edge0 = null;
var ex = Assert.Throws<ArgumentNullException>(() => node0.AddEdge(edge0));
}
开发者ID:BgRva,项目名称:Blob1,代码行数:8,代码来源:BasicNodeFixture.cs
示例6: AddEdge_Throws_Ex_If_Edge_Is_Invalid_Type
public void AddEdge_Throws_Ex_If_Edge_Is_Invalid_Type()
{
var net =new BasicAdjList(Guid.NewGuid());
BasicNode node0 = new BasicNode(net);
DummyBasicEdge edge0 = new DummyBasicEdge();
var ex = Assert.Throws<ArgumentException>(() => node0.AddEdge(edge0));
}
开发者ID:BgRva,项目名称:Blob1,代码行数:8,代码来源:BasicNodeFixture.cs
示例7: Contains_ReturnsTrueWhenANodeExists
public void Contains_ReturnsTrueWhenANodeExists()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
INode node = net.CreateNode();
bool result = net.Contains(node);
Assert.True(result);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:8,代码来源:BasicAdjListFixture.cs
示例8: Ctor_With_Different_Network_Parent_Than_Source_Node
public void Ctor_With_Different_Network_Parent_Than_Source_Node()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
BasicAdjList net2 = new BasicAdjList(Guid.NewGuid());
var nodeA = new BasicNode(net2);
var nodeB = new BasicNode(net);
var ex = Assert.Throws<ArgumentException>(() => new BasicEdge(net, nodeA, nodeB));
}
开发者ID:BgRva,项目名称:Blob1,代码行数:9,代码来源:BasicEdgeFixture.cs
示例9: Ctor_Throws_Ex_With_Null_Passed_InAsSourceNode
public void Ctor_Throws_Ex_With_Null_Passed_InAsSourceNode()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
IBasicNode nodeA = null;
var nodeB = new BasicNode(net);
//Act, Assert
var ex = Assert.Throws<ArgumentException>(() => new BasicEdge(net, nodeA, nodeB));
}
开发者ID:BgRva,项目名称:Blob1,代码行数:10,代码来源:BasicEdgeFixture.cs
示例10: CreateEdge_Increments_Edge_Count_By_1
public void CreateEdge_Increments_Edge_Count_By_1()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
Assert.Equal(0, net.EdgeCount);
INode nodeA = net.CreateNode();
INode nodeB = net.CreateNode();
IEdge edge = net.CreateEdge(nodeA, nodeB);
Assert.Equal(1, net.EdgeCount);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:10,代码来源:BasicAdjListFixture.cs
示例11: Ctor_Throws_Ex_With_Null_Passed_In_As_Network
public void Ctor_Throws_Ex_With_Null_Passed_In_As_Network()
{
//Assign
IBasicAdjList net = new BasicAdjList(Guid.NewGuid());
var nodeA = new BasicNode(net);
var nodeB = new BasicNode(net);
//Act, Assert
var ex = Assert.Throws<ArgumentNullException>(() => new BasicEdge(null, nodeA, nodeB));
}
开发者ID:BgRva,项目名称:Blob1,代码行数:10,代码来源:BasicEdgeFixture.cs
示例12: Contains_ReturnsTrueWhenAnEdgeExists
public void Contains_ReturnsTrueWhenAnEdgeExists()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
INode nodeA = net.CreateNode();
INode nodeB = net.CreateNode();
IEdge edge = net.CreateEdge(nodeA, nodeB);
bool result = net.Contains(edge);
Assert.True(result);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:10,代码来源:BasicAdjListFixture.cs
示例13: EdgeDataAttributeCount_Returns0_IfEdgeDataIsNull
public void EdgeDataAttributeCount_Returns0_IfEdgeDataIsNull()
{
var net = new BasicAdjList(Guid.NewGuid());
int count = 0;
net.EdgeData = null;
int result = net.EdgeDataAttributeCount;
Assert.Equal(count, result);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:11,代码来源:BasicAdjList_DataAttributes_Fixture.cs
示例14: CreateEdge_Assigns_Edge_Index
public void CreateEdge_Assigns_Edge_Index()
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
INode nodeA = net.CreateNode();
INode nodeB = net.CreateNode();
INode nodeC = net.CreateNode();
BasicEdge edgeA = net.CreateEdge(nodeA, nodeB) as BasicEdge;
BasicEdge edgeB = net.CreateEdge(nodeC, nodeB) as BasicEdge;
Assert.Equal(0, edgeA.Index);
Assert.Equal(1, edgeB.Index);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:12,代码来源:BasicAdjListFixture.cs
示例15: ChangeEventsEnabled_When_False_Prevents_NetworkChanged_Fired_When_CreateNode_Is_Called
public void ChangeEventsEnabled_When_False_Prevents_NetworkChanged_Fired_When_CreateNode_Is_Called(int nodeCount)
{
//Arrange
var net = new BasicAdjList(Guid.NewGuid());
var helper = new NetworkChangedEventsTestHelper();
net.NetworkChanged += new NetworkChangedEventHandler<INetwork, NetworkChangedEventArgs>(helper.NetworkChanged_DummyHandler);
net.ChangeEventsEnabled = false;
for (int i = 0; i < nodeCount; i++)
net.CreateNode();
Assert.Equal(0, helper.NetworkChanged_TimesCalled);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:13,代码来源:BasicAdjList_As_INetworkChangeEventsFixture.cs
示例16: EdgeDataAttributeCount
public void EdgeDataAttributeCount()
{
var net = new BasicAdjList(Guid.NewGuid());
int count = 3;
var mockMgr = new Mock<IDataAttributes<IEdge>>();
net.EdgeData = mockMgr.Object;
mockMgr.Setup(foo => foo.ColumnCount).Returns(count);
int result = net.EdgeDataAttributeCount;
Assert.Equal(count, result);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:13,代码来源:BasicAdjList_DataAttributes_Fixture.cs
示例17: AddEdge_IncrementsDegree_ForSelfLoop
public void AddEdge_IncrementsDegree_ForSelfLoop()
{
var net =new BasicAdjList(Guid.NewGuid());
BasicNode node0 = new BasicNode(net);
BasicNode node1 = new BasicNode(net);
BasicEdge edge0 = new BasicEdge(net, node0, node0);
int degree = node0.Degree;
Assert.Equal(0, degree);
node0.AddEdge(edge0);
degree = node0.Degree;
Assert.Equal(2, degree);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:14,代码来源:BasicNodeFixture.cs
示例18: AddRow_ThrowsIfValuesTypesDoesNotMatchListsTypes
public void AddRow_ThrowsIfValuesTypesDoesNotMatchListsTypes(Type[] dataTypes, object[] values)
{
BasicAdjList net = new BasicAdjList(Guid.NewGuid());
DataAttributeMgr mgr = new DataAttributeMgr(NODE_ATTRIB_LIST, net);
CreateLists(dataTypes, mgr);
object[] badVals = new object[values.Length];
for (int i = 0; i < values.Length; i++)
{
badVals[i] = Guid.NewGuid();
}
mgr.AddRow(badVals);
}
开发者ID:BgRva,项目名称:Blob1,代码行数:14,代码来源:AttributeListMgrFixture.cs
示例19: AddingNodes_Adds_Row_With_Matching_Key_In_NodeData
public void AddingNodes_Adds_Row_With_Matching_Key_In_NodeData(int nodeCount)
{
var net = new BasicAdjList(Guid.NewGuid());
var table = new DataAttributeTable<INode>();
table.Network = net;
net.NodeData = table;
for(int i=0; i<nodeCount; i++)
{
var node = net.CreateNode();
Assert.Equal((i+1), net.NodeCount);
Assert.Equal((i+1), table.RowCount);
Assert.True(table.RowOwnerMap.ContainsKey(node));
}
}
开发者ID:BgRva,项目名称:Blob1,代码行数:15,代码来源:BasicAdjList_DataAttributes_Fixture.cs
示例20: ParseToNetwork
/// <summary>
/// Parses a particular string format to a network. Format is
/// "n,e,d|pair;pair;pair" where n = node count, e = edge count, d = true/false for directedness and
/// pair is a number pair of node indices indicating an edges. Ex: "5,3,false|0,1;1,2;3,5" *note that the
/// number of pairs should match the number of edges
/// </summary>
public static IBasicAdjList ParseToNetwork(string input, bool enableNodeData, bool enableEdgeData)
{
// n,e,directed|pair;
// 7,23,false|0,3;0,2;0,4;1,4;1,2;1,3;2,5;2,4;2,4;3,5;3,1;3,6;3,0;4,4;4,5;4,3;5,1;5,1;5,4;5,6;5,0;6,3;6,1;
IBasicAdjList network = null;
var split1 = input.Split(new[] {'|'});
var split2 = split1[0].Split(new[] { ',' });
int n = int.Parse(split2[0]);
int m = int.Parse(split2[1]);
bool directed = bool.Parse(split2[2]);
var split3 = split1[1].Split(new[] { ';' }); // pairs
if(split3.Length != m)
throw new ArgumentException(string.Format("The number of pairs {0} did not match the number of edges {1} in {2}", split3.Length, m, input));
INode a = null;
INode b = null;
using (var fac = new BasicAdjListFactory())
{
network = new BasicAdjList(Guid.NewGuid(), directed);
for(int i=0; i<n; i++)
network.CreateNode();
}
string[] pair = null;
int indexA = -1;
int indexB = -1;
for (int i = 0; i < split3.Length; i++ )
{
pair = split3[i].Split(new[] { ',' });
indexA = int.Parse(pair[0]);
indexB = int.Parse(pair[1]);
a = network.Nodes[indexA];
b = network.Nodes[indexB];
network.CreateEdge(a, b);
}
using (var fac = new DataAttributeTableFactory(network))
{
if (enableNodeData)
fac.CreateNodeDataTable();
if (enableEdgeData)
fac.CreateEdgeDataTable();
}
return network;
}
开发者ID:BgRva,项目名称:Blob1,代码行数:54,代码来源:BasicAdjListParser.cs
注:本文中的BlueSpider.Blob.Basic.Network.AdjList.BasicAdjList类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论