Application Overview
====================
In GraphVite, the pipelines are packaged into classes, which we call applications.
There are 3 main applications, node embedding, knowledge graph embedding, and
graph & high-dimensional data visualization. For each application, GraphVite loads
an input graph, perfoms embedding training, and finally evaluates the embeddngs on
downstream tasks.
.. _node embedding:
Node Embedding
--------------
Node embedding is a family of algorithms that learn a representation for each node
in a graph. It is important for graph analysis and a variety of downstream tasks.
For example, node embedding can be leveraged for analyzing social networks, citation
networks, or protein-protein interaction networks. It may be also helpful to other
unsupervised learning problems with graph structures.
To qualify the learned embeddings, we evaluate them on the node classification and
link prediction tasks.
.. seealso::
Package Reference:
:class:`GraphApplication `
.. _knowledge graph embedding:
Knowledge Graph Embedding
-------------------------
Knowledge graph (aka. knowledge base) is a family of graphs where each edge has a
type, indicating the relation of the connected nodes. In knowledge graphs, nodes
are called entities, and edges are called relations. The knowledge graph embedding
algorithm aims to learn a representation for each entity and relation.
With knowledge graph embeddings, it is easy to compare entities or relations in a
uniform space, and further infer unobserved links in a knowledge graph.
The learned embeddings are evaluated under the link prediction task in GraphVite.
.. seealso::
Package Reference:
:class:`KnowledgeGraphApplication `
.. _visualization:
Graph & High-dimensional Data Visualization
-------------------------------------------
Visualization is a critical step in exploring and analyzing graphs and
high-dimensional data. Typically, visualization methods project each data points into
a low-dimensional space.
As most projection methods treat the similarity between data points as a graph,
GraphVite is also able to provide acceleration for this application. Taking a graph
or a group of high-dimensional vectors, GraphVite can produce either 2D or 3D
projections in a very short time.
.. seealso::
Package Reference:
:class:`VisualizationApplication `