Graph Analytics 有哪些类型
node type (labels)
node schema: attributes 组成了schema.
同样的, Edge也有 Edge Type 和Edge Schema
如果是一个完整的图,会包含以下信息
weight 权重,比如两点之间的 距离
1. Path Analytics
一些定义:
walk - 图上随便走的轨迹
path - 没有中间node重复的walk,比如 A-B-C-D-B-E 这个属于walk 不属于 path, path 是constrained 的walk
Cycle - 3个以上节点组成的环
Acyclic - 无环图, 比如最常见的说法 DAG- directed acyclic graph.
trail - 没有edge 重复的walk
dimeter of graph - 从任何一个node出发, 到任何另一个node, 走最短路径,最后得到的最大hops 就是 dimeter
最短路径问题
Dijkstra's Algorithm
上面是简化版本的,现在考虑加上constrain
Dijkstra 算法在大数据情况下表现不好,计算量很大
2. Connectivity Analytics
名词 degree 指这个Node有多少个连接的edge
主要关注图的 robust 和 相似性
连接度 Connectivity
下图是基于node 的connectivity, 去掉三个node 就隔开了图,所有connectivity 等于 3
下图是基于edge 的connectivity, 去掉4个edge就隔开了图,所有说 edge connectivity = 4.
node degree: 就是有多少条edge连接到node上
- Define a node's in-degree (# of incoming edges) and out-degree (# of outgoing edges)
- Describe a process for calculating the similarity of two graphs by finding the following for each graph and comparing them: find the degree of each node in a graph, then create a histogram of how many nodes have a certain degree.
- Define listener nodes (greater in-degree than out-degree), talker nodes (greater out-degree than in-degree) and communicator nodes (high in-degree and high out-degree).
node degree 进一步分成 indegree 和 outdegree
3. Community Analytics
- List the three types of analytics questions asked about communities (static, evolution, and predictions) and identify a real world example of a question in those categories.
- Calculate the internal degree and external degree of nodes in a community.
- Recognize that, for a community to really be a community, the relative number of total edges within that community (cluster) should be high relative to the total number of edges from nodes in the community to nodes outside it.
怎么从network里面找到 community呢?这里介绍了两种方法,一种是关注 Local property
Clique - 小集团的意思,每个node都和其他node有连接
实际上,find 大于3或者4的clique比较难,所有我们要relax clique的定义,有两种relaxation, 一种基于distance, 一种基于density, 其中两种基于distance的定义是n-clique 和 n-clan, 基于density的是k-core.
下面是n-clique的说明,Mike 不属于绿色点形成的2-clique
n-clan 纠正了这种情况
前面是讲基于 local property 的community 发现算法,接着将基于 grobal property 的community 发现算法
By the end of this video you will be able to...
- Describe modularity conceptually -- a graph is more modular if there are more edges in that community than would be likely if edges were randomly assigned.
- Given two graphs, identify visually which is more modular.
- Identify the 6 ways in which communities are often tracked over time.
- Identify which of the 6 changes would happen when two companies merge and when a company spins off a start-up.
grobal property 特别关注的property 是 modularity
然后讲到了基于modularity 的community 发现方法叫 Louvain method. 具体详情见 https://www.youtube.com/watch?v=dGa-TXpoPz8
相对于static graph, 经常见的还有 evolving graph. 有6种类型的evolving method.
4. Centrality Analytics
By the end of this video you will be able to...
- Define an influencer in a social network as a node (e.g. person) who can reach all other nodes quickly.
- Identify the 2 key (central) player problems: Which nodes when removed will maximally disrupt a network and which set of nodes can reach (almost) all other nodes in a network.
- Identify the 4 types of centrality discussed: degree, group, closeness, and betweenness.
- Identify which type of centrality you would want to identify in the following 2 cases: when you have information you want to inject quickly into a graph that follows shortest paths for dissemination and when you have a commodity that flows through a network.
两个概念 Centrality and Centralization
Centralization is for a network. As the number of nodes in a network with high centrality increases (orange nodes), then the centralization of a network decreases -- because there is less variation in the centrality values of the nodes in the network.
有超过30种的测量centrality 的方法
讲 connectivity 时候提到了power law 算法,不知道具体是什么
Ref
https://afteracademy.com/blog/dijkstras-algorithm Dijkstras 算法有图解,很清楚