<!DOCTYPE html>
<html lang="en-us">

  <head>
  <link href="http://gmpg.org/xfn/11" rel="profile">
  <meta http-equiv="content-type" content="text/html; charset=utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">

  <title>
    
      Euclidean geometry meets graph, a geometric deep learning perspective &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/2022/01/06/euclidean_geometric_graph/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/css/custom.css">
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Serif:400,400italic,700%7CPT+Sans:400">

  <link rel="apple-touch-icon-precomposed" sizes="144x144" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/atom.xml">

  

  <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type="text/javascript" ></script>
 <!-- <script type="text/x-mathjax-config"> MathJax.Hub.Config({ TeX: { equationNumbers: { autoNumber: "AMS" } } }); </script> -->
  <script type="text/x-mathjax-config">
      MathJax.Hub.Config({
        tex2jax: { inlineMath: [ ['$','$'], ["\\(","\\)"] ],
         processEscapes: false
        }
      });
</script>
</head>


  <body>

    <!-- Target for toggling the sidebar `.sidebar-checkbox` is for regular
     styles, `#sidebar-checkbox` for behavior. -->
<input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox">
<!-- <input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox" > -->

<!-- Toggleable sidebar -->
<div class="sidebar" id="sidebar">
  <div class="sidebar-item">
    <p>For short-term, peer-sourced tests of time, generalizations, specializations, reproductions, etc.!</p>
  </div>

  <nav class="sidebar-nav">

    

    
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/tags/">Tags</a>
        
      
    

    <a class="sidebar-nav-item" href="https://github.com/iclr-blog-track/iclr-blog-track.github.io">GitHub project</a>
    <span class="sidebar-nav-item">Currently vICLR Spring 2021</span>
  </nav>

  <div class="sidebar-item">
    <p>
      &copy; 2022. All rights reserved.
    </p>
  </div>
</div>


    <!-- Wrap is the content to shift when toggling the sidebar. We wrap the
         content to avoid any CSS collisions with our real content. -->
    <div class="wrap">
      <div class="masthead">
        <div class="container">
          <h3 class="masthead-title">
            <a href="/" title="Home">The ICLR Blog Track</a>
            <small></small>
          </h3>
        </div>
      </div>

      <div class="container content">
        <div class="post">
  <h1 id="iclr-post-title" class="post-title">Euclidean geometry meets graph, a geometric deep learning perspective</h1>
  <span class="post-date">06 Jan 2022 | 
    <a class="content-tag" href="/tags/#graph-neural-network"> graph neural network </a>
  
    <a class="content-tag" href="/tags/#geometric-deep-learning"> geometric deep learning </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <p>Graph neural networks (GNN) have been an active area of machine learning research to tackle various problems in graph data. A graph is a powerful way of representing relationships among entities as nodes connected by edges. Sometimes nodes and edges can have spatial features, such as 3D coordinates of nodes and directions along edges. How do we reason over the topology of graphs while considering those geometric features? In this post, we discuss a paper published in ICLR 2021:</p>

<ul>
  <li>Bowen Jing, Stephan Eismann, Patricia Suriana, Raphael J Townshend, Ron Dror (2021): <a href="https://iclr.cc/virtual/2021/spotlight/3449">Learning from Protein Structure with Geometric Vector Perceptrons</a>.</li>
</ul>

<h2 id="graphs-and-geometric-graph">Graphs and geometric graph</h2>
<p>A graph is a common data structure using nodes connected by edges to represent complex relationships among entities. Nodes and edges are usually features on them for GNNs to learn from. Sometimes nodes and edges can have some spatial features, such as 3D coordinates of nodes and directions along edges, adding a layer of geometric relationships (including distance, direction, angle, etc.) among the entities. In this post, we term this type of graph with geometric feature vectors on nodes and/or edges as <strong>geometric graph</strong>.</p>

<p>Small molecules, macro-molecules, and geospatial data are all examples where one can construct geometric graphs: small molecules can be represented by a graph of atoms connected by chemical bonds, where atoms can be described by their coordinates in the 3D Euclidean space and chemical bonds can be described by vectors along their directions. The angles between adjacent chemical bonds are known to be indicative of the chemical properties of the molecule such as stability. Similarly, macro-molecules such as proteins can be represented by graphs of amino acid residues connected based on their spatial proximity. Each amino acid residue contains $k$ key atoms, allowing the node’s vector feature to be $\mathbf{V}_n \in \mathbb{R}^{k \times 3}$. Spatial networks and transportation networks can be constructed by treating intersections as nodes and roads as edges from urban geospatial data. Furthermore, the geographic coordinates of the intersections and the directions of the roads can be encoded as vector features on nodes and edges, respectively.</p>

<h2 id="a-geometric-deep-learning-perspective">A Geometric Deep Learning perspective</h2>
<p>The term “geometry” in a narrow sense is equivalent to the classic Euclidean geometry. However, other schools of geometries exist, such as Riemannian geometry. To unify the divergent schools of geometries, the <a href="https://en.wikipedia.org/wiki/Erlangen_program">Klein’s Erlangen Program</a> views geometry as a study of <strong>invariance</strong> with respect to various transformations.</p>

<p>In the broader sense of geometry, a graph is also an important geometric object because its nodes are invariant to permutations: the ordering of its nodes does not change the property of the entire graph. At a local level, the ordering of direct neighbors does not affect a node’s attributes such as degree and centrality. With this perspective, when we impose Euclidean geometric features onto a graph to form a <em>geometric graph</em>, it is further invariant to Euclidean group transformations, $E(n)$, including rotations, translations and reflections.</p>

<p>Following the geometric deep learning blueprint (<a href="https://arxiv.org/abs/2104.13478">Bronstein et al. 2021</a>), in order to develop an effective geometric deep learning algorithm on <em>geometric graphs</em>, one needs to invent equivariant and invariant layers with respect to permutation and $E(n)$ symmetry groups. This can be achieved by extending the GNN to operate in $E(3)$ symmetries (assuming we are dealing with 3D Euclidean space).</p>

<h2 id="introducing-the-geometric-vector-perceptron-gvp-paper">Introducing the geometric vector perceptron (GVP) paper</h2>
<p>Most GNN architectures are unable to reason over the spatial relationships among the nodes and edges in a geometric graph. The study by Jing et al. focuses on the tasks operating on the tertiary structures of proteins and frames the method as “learning from structures”. In fact, the problem of learning from a geometric graph can be naively solved by ignoring either aspect of the data: 1) relational reasoning on graphs using GNN while ignoring the Euclidean geometry, and 2) geometric reasoning on the protein structures using 3D CNN with voxelized representations. Motivated by combining the best from both worlds of GNN and CNN, the authors developed GVP-GNN, which is a novel GNN architecture with GVP as building blocks.</p>

<h3 id="gvp-the-euclids-neuron">GVP, the Euclid’s neuron</h3>
<p>As its name suggests, GVP is a type of perceptron, just like a basic perceptron used in dense layers of neural networks. The novelty of GVP lies in its ability to jointly process features from two independent modalities: scalar and geometric vector features.</p>

<p>So how does GVP do that? Let’s first revisit how perceptrons work. We denote $\mathbf{s} \in \mathbb{R}^h$ as a feature vector whose entries are irrelevant to the spatial information. A perceptron is simply the linear transformation of $\mathbf{s}$ followed by nonlinearity:</p>

\[\begin{equation}
    \mathbf{s}' = Perceptron(\mathbf{s}) = \sigma(\mathbf{w}^\intercal\mathbf{s} + b)
    \tag{1}
\end{equation}\]

<p>A GVP jointly process $\mathbf{s}$ and $\mathbf{V} \in \mathbb{R}^{\nu \times 3}$ with the following computations:
\(\begin{equation}
    \mathbf{s}', \mathbf{V}' = GVP(\mathbf{s}, \mathbf{V})
    \tag{2}
\end{equation}\)</p>

\[\begin{equation}
    \mathbf{s}' = \sigma(\mathbf{W}_m
    \begin{bmatrix}
        \| \mathbf{W}_h \mathbf{V} \|_2\\
        \mathbf{s}
    \end{bmatrix}  + \mathbf{b})
    \tag{3}
\end{equation}\]

<p>\(\begin{equation}
    \mathbf{V}' = \sigma^+(\| \mathbf{W}_{\mu} \mathbf{W}_{h} \mathbf{V} \|_2) \odot \mathbf{W}_{\mu} \mathbf{W}_{h} \mathbf{V} 
    \tag{4}
\end{equation}\)
, where \(\mathbf{W}_{\mu}\), \(\mathbf{W}_{h}\), \(\mathbf{W}_{m}\) are weight matrices for linear transformations of \(\mathbf{s}\) and \(\mathbf{V}\).</p>

<p>The output $\mathbf{s}’$, $\mathbf{V}’$ from GVP can be proved to be $E(3)$ invariant and equivariant, respectively, with respect to rotations and reflections, respectively. It can be observed from equation (3) that the scalar output $\mathbf{s}’$ only depends on the l2-norm of the vector, which is constant after any rotations/reflections. Similarly, in equation (4), the directions in the vector output $\mathbf{V}’$ is a function of \(\mathbf{W}_{\mu} \mathbf{W}_{h} \mathbf{V}\), which means it only changes with transformation of $\mathbf{V}$.</p>

<p>The authors further extended the universal approximation theorem from perceptron to GVP: they proved that GVP can approximate any rotation-invariant functions. Now that we have GVP to take care of the Euclidean transformations, we can use it to build a GNN to tackle geometric graphs.</p>

<h3 id="refresher-on-gnn-basics">Refresher on GNN basics</h3>

<p>GNN typically reasons among neighboring nodes by exchanging messages between them to update the node representations with node and edge features, thus integrating the topological structures of the graph when making inferences. The message passing paradigm (<a href="https://arxiv.org/abs/1704.01212">Gilmer et al. 2017</a>) unifies many GNN architectures as collecting and aggregating messages from neighbors to update the node representations.</p>

<p>The message function describes how a pair of nodes and the edge connecting them contribute in generating a message: 
\(\begin{equation}
    \mathbf{m}_{ij} = M(\mathbf{h}_i, \mathbf{h}_j, \mathbf{e}_{ij})    
    \tag{5}
\end{equation}\)</p>

<p>Afterwards, messages collected from all neighbors of a node are aggregated and used for updating the node’s representation:
\(\begin{equation}
    \mathbf{h}_{i} \leftarrow U(\mathbf{h}_i, AGG_{j\in \mathcal{N}(i)}\mathbf{m}_{ij} )
    \tag{6}
\end{equation}\)</p>

<h3 id="gvp-gnn-message-from-vector-features">GVP-GNN: Message from vector features</h3>

<p>GVP-GNN adopts the general message passing scheme of GNNs, additionally allowing nodes and edges to have scalar and vector features. It generates messages using both node features \((\mathbf{s}_j, \mathbf{V}_j)\) and edge features \((\mathbf{s}_{ij}, \mathbf{V}_{ij})\):
\(\begin{align}
\mathbf{m}_{ij} &amp;= M_{GVP}(\mathbf{s}_j, \mathbf{V}_j, \mathbf{s}_{ij}, \mathbf{V}_{ij})\\
 &amp;= GVP(concat(\mathbf{s}_j, \mathbf{s}_{ij}), concat(\mathbf{V}_j, \mathbf{V}_{ij})) \\
 \tag{7}
\end{align}\)</p>

<p>We use \(\mathbf{h}=(\mathbf{s}, \mathbf{V})\) and \(\mathbf{m}_{ij}=(\mathbf{s}_{ij}', \mathbf{V}_{ij}')\) to simplify notations, GVP-GNN’s update function aggregates scalar and vector messages:
\(\begin{equation}
\mathbf{h}_{i} \leftarrow LayerNorm(\mathbf{h}_i + \frac{1}{|\mathcal{N}(i)|} Dropout( \sum_{j\in \mathcal{N}(i)}\mathbf{m}_{ij}))
\tag{8}
\end{equation}\)</p>

<p>It’s worth mentioning that GVP-GNN is not the first neural architecture to reason over geometric graphs. Other prominent algorithms developed prior to GVP-GNN include SchNet (<a href="https://arxiv.org/abs/1706.08566">Schütt et al., 2017</a>), Tensor Field Network (TFN) (<a href="https://arxiv.org/abs/1802.08219">Thomas et al., 2018</a>), and SE(3)-Transformer (<a href="https://arxiv.org/abs/2006.10503">Fuchs et al., 2020</a>).</p>

<ul>
  <li>
    <p>SchNet is a form of continuous convolution on GNN, with $\phi_{CF}$ being the continuous convolution filter and $\phi_{S}$ being the nonlinearity on the node scalar feature $\mathbf{s}$:
\(\begin{align}
\mathbf{m}_{ij} 
% &amp;= M_{SchNet}(\mathbf{s}_j, \mathbf{V}_j, \mathbf{V}_{i}) \\
&amp;=  \phi_{CF}(\Vert\mathbf{V}_j - \mathbf{V}_i\Vert) \phi_{S}(\mathbf{s}_j)
\tag{9}
\end{align}\)</p>
  </li>
  <li>
    <p>TFN uses <a href="https://en.wikipedia.org/wiki/Spherical_harmonics">spherical harmonics</a> to compute its learnable weight kernel $\mathbf{W}^{lk}$ to preserves $SE(3)$ equivariance: 
\(\begin{align}
\mathbf{m}_{ij} 
% &amp;= M_{TFN}(\mathbf{s}_j, \mathbf{V}_j, \mathbf{V}_{i}) \\
&amp;= \sum_k\mathbf{W}^{lk}(\mathbf{V}_j - \mathbf{V}_i) \mathbf{s}_j^{lk}
\tag{10}
\end{align}\)</p>
  </li>
  <li>
    <p>$SE(3)$-transformer enhances TFN with the attention mechanims:
\(\begin{align}
\mathbf{m}_{ij} 
% &amp;= M_{SE3}(\mathbf{s}_i, \mathbf{V}_i, \mathbf{V}_{j}) \\
&amp;= \sum_k\alpha_{ij} \mathbf{W}^{lk}(\mathbf{V}_j - \mathbf{V}_i) \mathbf{s}_j^{lk}
\tag{11}
\end{align}\)</p>
  </li>
</ul>

<p>Observing the message functions (equations 9, 10, 11) from the three preceding algorithms, we note that they all depend on the direction between the vector features: \(\mathbf{V}_j - \mathbf{V}_i\). In contrast, GVP-GNN achieves $SE(3)$ equivariance of the message via concatenation of vector features of node <strong>and</strong> edge: \(concat(\mathbf{V}_j, \mathbf{V}_{ij})\), allowing it to incorporate edge features. The concatenation allows GVP-GNN to generate an ensemble of vector messages from both nodes and edges, making it more flexible and versatile than the competing methods.</p>

<p>More concretely, the competing methods are unable to reason with edge vector features that are independent of node vector features. Having independent vector features from nodes and edges allows one to construct more expressive geometric graphs. For instance, in a protein graph, the authors encoded unit vector in the direction of neighboring amnio acids as edge vector feature $C\alpha_j - C\alpha_i$, whereas node vector features can represent amino acid’s internal direction along $C\beta_i - C\alpha_i$.</p>

<p><img src="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/images/2021-12-20-euclidean_geometric_graph/geometric_protein_graph.png" alt="protein geomtric graph" />
<em>Illustration of vector features on a protein geometric graph.</em> The left panel depicts amino acid residues from a local neighborhood on a protein in 3D Euclidean space. Amino acid residues are colored by their types. Key atoms ($C$, $O$, $C\alpha$, $C\beta$) are labeled for two selected residues. Within residues, two vectors ($C\alpha - C\beta$ and $C\alpha - C$) are plotted in dashed arrows form the node feature \(\mathbf{V}_i \in \mathbb{R}^{2 \times 3}\). Between residue i and j, the vector $C\alpha_i - C\alpha_j$ can be used as the edge vector features $\mathbf{V}_{ij} \in \mathbb{R}^{1 \times 3}$. The right panel abstracts the protein geometric graph and their vector features.</p>

<h3 id="inherently-interpretable-by-visualizing-the-learned-vector-field">Inherently interpretable by visualizing the learned vector field</h3>

<p>Because GVP-GNN learns and updates vector features on nodes and edges, it’s possible to visualize the learned vector features at the intermediate GVP-GNN layers. The set of learned vector features on a geometric graph actually resembles a <strong>vector field</strong>. We can try to interpret the learned vector field with some intuitions from physics. For instance, we can imagine the learned vector field represents force or velocity, although such interpretation needs to be rigorously investigated.</p>

<p>The authors visualized the learned node vector features on protein geometric graphs. We can clearly see the distinctive patterns on different protein graphs: contracting (A and D), rotating (B) expanding (C). It would be really interesting to study if those learned vector fields actually are correlated with intramolecular forces among the amino acid residues in the protein graphs.</p>

<p><img src="https://iclr.iro.umontreal.ca/37d553f4-5488-4daa-b653-5fbad5dac815_1642106842/public/images/2021-12-20-euclidean_geometric_graph/GVP_figure2.png" alt="Figure 2 in the GVP paper" /></p>

<p>In addition to looking at the resultant vector fields (analogous to feature maps in CNN), one should also analyze GVP’s kernels (\(\mathbf{W}_{\mu}\) and \(\mathbf{W}_{h}\)) because they are the counterpart to CNN’s kernels (aka filters), where lower level kernels learn to detect edge and texture and higher level kernels learn more complex images components such as animal eyes (think DeepDream/<a href="_https://ai.googleblog.com/2015/06/inceptionism-going-deeper-into-neural.html_">Inceptionism</a>).</p>

<h2 id="applications-of-gvp-gnn-within-and-beyond-macro-molecules">Applications of GVP-GNN within and beyond macro-molecules</h2>

<p>Jing et al. demonstrated the application of their GVP-GNN to various supervised learning tasks on proteins represented as geometric graphs of amino acid residues. A natural next step is to model the protein geometric graphs at atomic level. With its expressiveness in geometric graphs, it would be interesting to see if high-resolution atomic graph representation of proteins improves various benchmarks in protein biology including protein design, and model quality assessment. Looking ahead, GVP-GNN has promising potential in improving protein structure prediction. For instance, in the AlphaFold2 framework (<a href="http://doi.org/10.1038/s41586-021-03819-2">Jumper et al. 2021</a>), invariant point attention (IPA) module is currently used to refine the high-resolution residue protein structure. Can GVP-GNN perform better than the IPA module on this task? Geometric graphs constructed from other macro-molecules like RNA and small molecules are immediate testbed for GVP-GNN, we also foresee broader applications in other domains.</p>

<h3 id="geospatial-data-as-geometric-graphs">Geospatial data as geometric graphs</h3>

<p>In recent development of intelligent transportation systems (ITS), forecasting traffic speed, volume or the density of roads in traffic networks is fundamentally important. Considering the traffic network as a spatial-temporal graph, GNNs are ideally suited to traffic forecasting problems because of their ability to capture spatial dependency. A widely used application is the estimated times of arrival (ETAs) prediction in Google Map by DeepMind (<a href="https://deepmind.com/blog/article/traffic-prediction-with-advanced-graph-neural-networks">Lange and Perez, 2020</a>). However, current GNN solutions for these use cases only represent the data using regular graphs without geometric features. Traffic accident and anomaly prediction is a particularly challenging example: it involves accident records, geometric road structures, and meteorological conditions in addition to road networks. For example, the direct sunlight behind a steep hill or a sharp turn with no lane separation significantly increase the accident risk, and could be modeled in the GVP-GNN by considering geometric relations between road nodes and edges, i.e., encoding nodes with 3D vector features representing the geographic coordinates (latitude, longitude, and altitude). <a href="https://arxiv.org/abs/2101.11174">Jiang and Luo (2021)</a> mentioned other use cases such as parking availability and lane occupancy forecasting that are likely to benefit from introducing geometric relations.</p>

<p>Another geospatial use case is the problem of collision-free navigation in multi-robot systems where the robots are restricted in observation and communication range. Positional relations between the robot fleet are crucial to the task. In <a href="https://arxiv.org/abs/1912.06095">Li et al. (2019)</a>, they jointly trained two networks: a CNN that extracts adequate features from local observations, and a GNN that learns to explicitly communicate these features among robots. GVP-GNN has the potential to determine what information is necessary and effectively communicate to facilitate efficient path planning.</p>

<h3 id="application-in-graph-drawing">Application in graph drawing</h3>

<p>Graph drawing algorithms (aka network layout algorithms) are used to compute the 2D or 3D coordinates of nodes from a graph to preserve their local and global topological structures. They are commonly used for visualizing graphs and are closely related to some non-linear dimensionality reduction algorithms such as Laplacian Eigenmaps, which applies principal component analysis on the Lapacian matrix of the affinity graph constructed from the input data. Common graph drawing algorithms simulate physical forces among nodes and edges. For instance, the Fruchterman-Reingold algorithm is an iterative method that defines attractive and repulsive forces among nodes based on whether they are connected, with the objective of minimizing the energy of the system until equilibrium. Force-directed graph drawing algorithms are computationally expensive: cubic time to the number of nodes $\mathcal{O}(n^3)$. This is because the number of iterations is estimated to be $\mathcal{O}(n)$, and in every iteration, all pairs of nodes are visited and their mutual repulsive forces computed ($\mathcal{O}(n^2)$ complexity).</p>

<p>When we revisit the graph drawing problem, we notice that it can be formulated as a node-level task on a geometric graph: given a graph, we compute the coordinates of nodes ($\mathbf{V}_i \in \mathbb{R}^{1 \times d}$, where $d$ equals 2 or 3, for visualization in 2D or 3D, respectively) that minimize the energy function. GVP-GNN can be plugged in as a function approximator to solve this problem. The node vector features can be initialized randomly, just like in force-directed graph drawing algorithms where the positions of the nodes are initialized randomly. Graph drawing with GVP-GNN can reduce the time complexity of force-directed algorithms because each message passing epoch of GVP-GNN only costs $\mathcal{O}(m)$, where $m$ is the number of edges, which is guaranteed to be $m \leq n^2$.</p>

<h2 id="conclusion">Conclusion</h2>

<p>In this post, we highlighted the novelties of GVP-GNN developed by Jing and colleagues, including the provable $E(3)$-invariance and equivariance, extension of the universal approximation guarantee, inherent interpretability by visualizing the learned vector features, and its SoTA performance on tasks related to protein structures.</p>

<p>More importantly, we analyzed how GVP-GNN fits into the Geometric Deep Learning blueprint and how it unifies two types of symmetries in geometric graphs. Through this post, we hope we inspire the readers with the breadth of under-utilized applications of geometric graphs and Euclidean equivariant GNNs: spanning from biochemical and geospatial data to network visualization and many more to follow!</p>

<h2 id="references">References</h2>
<ul>
  <li>Justin Gilmer, Samuel S. Schoenholz, Patrick F. Riley, Oriol Vinyals and George E. Dahl (2017): “Neural Message Passing for Quantum Chemistry” <a href="https://arxiv.org/abs/1704.01212">arXiv:1704.01212</a></li>
  <li>Kristof T. Schütt, Pieter-Jan Kindermans, Huziel E. Sauceda, Stefan Chmiela, Alexandre Tkatchenko and Klaus-Robert Müller (2017): “SchNet: A continuous-filter convolutional neural network for modeling quantum interactions” <a href="https://arxiv.org/abs/1706.08566">arXiv:1706.08566</a></li>
  <li>Nathaniel Thomas, Tess Smidt, Steven Kearnes, Lusann Yang, Li Li, Kai Kohlhoff and Patrick Riley (2018): “Tensor field networks: Rotation- and translation-equivariant neural networks for 3D point clouds” <a href="https://arxiv.org/abs/1802.08219">arXiv:1802.08219</a></li>
  <li>Fabian B. Fuchs, Daniel E. Worrall, Volker Fischer and Max Welling (2020): “SE(3)-Transformers: 3D Roto-Translation Equivariant Attention Networks” <a href="https://arxiv.org/abs/2006.10503">arXiv:2006.10503</a></li>
  <li>Michael M. Bronstein, Joan Bruna, Taco Cohen and Petar Veličković (2021): “Geometric Deep Learning: Grids, Groups, Graphs, Geodesics, and Gauges” <a href="https://arxiv.org/abs/2104.13478">arXiv:2104.13478</a></li>
  <li>John Jumper et al. (2021) “Highly accurate protein structure prediction with AlphaFold” Nature <a href="http://doi.org/10.1038/s41586-021-03819-2">doi.org/10.1038/s41586-021-03819-2</a></li>
  <li>Andrew Y. Ng, Michael I. Jordan, Yair Weiss (2001): <a href="http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.19.8100">“On Spectral Clustering: Analysis and an algorithm”</a></li>
  <li>Fruchterman, Thomas M. J.; Reingold, Edward M. (1991), “Graph Drawing by Force-Directed Placement”, Software – Practice &amp; Experience, Wiley, 21 (11): 1129–1164, <a href="https://doi.org/10.1002/spe.4380211102">doi:10.1002/spe.4380211102</a></li>
  <li>Oliver Lange, Luis Perez (2020): <a href="https://deepmind.com/blog/article/traffic-prediction-with-advanced-graph-neural-networks">“Traffic prediction with advanced Graph Neural Networks”</a></li>
  <li>Weiwei Jiang, Jiayun Luo (2021): “Graph Neural Network for Traffic Forecasting: A Survey” <a href="https://arxiv.org/abs/2101.11174">arXiv:2101.11174</a></li>
  <li>Qingbiao Li, Fernando Gama, Alejandro Ribeiro, Amanda Prorok (2019): “Graph Neural Networks for Decentralized Multi-Robot Path Planning” <a href="https://arxiv.org/abs/1912.06095">arXiv:1912.06095</a></li>
</ul>

</div>

<div id="bibtex-container" class="related">
  For attribution in academic contexts, please cite this work as
  <pre id="bibtex-academic-attribution">

  </pre>

  BibTeX citation
  <pre id="bibtex-box">

  </pre>
</div>
<script>
  let authorsSpan = document.getElementById("iclr-post-authors");
  let authorsText = authorsSpan.textContent;
  let lnameFnameInstitution = authorsText.split(";");
  let lfiList = lnameFnameInstitution.map(lfi => lfi.split(",").map(item => item.trim()));
  let bibtexLFI = lfiList.map(lfi => lfi[0] + ", " + lfi[1]).join(" and ")
  let academicLFI = lfiList.map(lfi => lfi[0]);
  {
    if(academicLFI.length > 2) academicLFI = academicLFI[0] + ", et al.";
    else if(academicLFI.length == 2) academicLFI = academicLFI[0] + " & " + academicLFI[1];
    else academicLFI = academicLFI[0];
  }

  let titleSpan = document.getElementById("iclr-post-title");
  let titleText = titleSpan.textContent.trim();
  let bibtexTitleShorthand = (lfiList[0][1]+
    "2022"+
    titleText.split(" ").slice(0, 3).join("")
  ).replace(" ", "").replace(/[\p{P}$+<=>^`|~]/gu, '').toLowerCase().trim();

  let bibtexTemplate = `
@inproceedings{${bibtexTitleShorthand}},
  author = {${bibtexLFI}},
  title = {${titleText}},
  booktitle = {ICLR Blog Track},
  year = {2022},
  note = {${window.location.href}},
  url  = {${window.location.href}}
}
  `.trim();
  document.getElementById("bibtex-box").innerText = bibtexTemplate;

  let academicTemplate = `
${academicLFI}, "${titleText}", ICLR Blog Track, 2022.
`.trim();
  document.getElementById("bibtex-academic-attribution").innerText = academicTemplate;

</script>


<div class="related">
  <h2>Related posts</h2>
  <ul class="related-posts">
    
      <li>
        <h3>
          <a href="/2021/09/01/sample-submission/">
            Sample Submission
            <small>01 Sep 2021 | 
    <a class="content-tag" href="/tags/#graph-neural-network"> graph neural network </a>
  
    <a class="content-tag" href="/tags/#geometric-deep-learning"> geometric deep learning </a>
  </small>
          </a>
        </h3>
      </li>
    
      <li>
        <h3>
          <a href="/2020/04/02/example-content/">
            Example content (Basic Markdown)
            <small>02 Apr 2020 | 
    <a class="content-tag" href="/tags/#graph-neural-network"> graph neural network </a>
  
    <a class="content-tag" href="/tags/#geometric-deep-learning"> geometric deep learning </a>
  </small>
          </a>
        </h3>
      </li>
    
  </ul>
</div>


<script src="https://utteranc.es/client.js"
        repo="iclr-blog-track/iclr-blog-track.github.io"
        issue-term="pathname"
        label="utterance"
        theme="boxy-light"
        crossorigin="anonymous"
        >
</script>


      </div>
    </div>

    <label for="sidebar-checkbox" class="sidebar-toggle"></label>

    <script src='/public/js/script.js'></script>
  </body>
</html>
