<!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>
    
      Physics-Aware Difference Graph Networks for Sparsely-Observed Dynamics &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/2021/12/01/padgn-blog/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/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/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/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/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/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">Physics-Aware Difference Graph Networks for Sparsely-Observed Dynamics</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#pa-dgn"> PA-DGN </a>
  
    <a class="content-tag" href="/tags/#pde"> PDE </a>
  
    <a class="content-tag" href="/tags/#graph-networks"> Graph Networks </a>
  
    <a class="content-tag" href="/tags/#sparse-data"> Sparse Data </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <blockquote>
  <p><strong>It is well known that the central problem of the whole of modern mathematics</strong>
<strong>is the study of transcendental functions defined by differential equations</strong></p>

  <p><em>-Felix Klein</em></p>
</blockquote>

<p>Real world dynamic systems are often modelled using differential equations. Solving these equations give insights to the underlying behaviour of the system. The characteristic of such systems are complex and difficult to capture using Ordinary Differential Equations (ODEs), as the behaviour depends on different factors. Partial Differential Equations (PDEs) are thus used to model the dynamics of a complex physical system. PDEs are used widely in heat-flow studies, stress-strain relationships, electrodynamics, wave equations in sounds and much more. PDEs can be solved using analytical as well as approximate methods. The work on solving PDEs analytically goes back to 18th century when Joseph Fourier studied the heat conductance equation, which later went on to become the core for Fourier transform.</p>

<p>Not all ODEs and PDEs can be solved in a closed form manner and thus numerical methods evolved around this fact. Numerical methods are used by the modern day computers to solve complex PDEs, for which the closed form solution is difficult to obtain. Numerical or approximate methods of solving differential equation dates back to the time of Newton and Euler where a diffferential equation was solved by approximating it as a difference equation. Approximating a partial derivative in the form of difference equations leads to a numerical error, as derivatives are defined on a continuous domain and difference equations are defined on a discrete domain.</p>

<p>In this blog, we try to review and summarize the work on Physics-Aware Difference Graph Networks which tries to discover the underlying dynamical relations between temporal and spatial differences through sparse sequential observations (more on this as you proceed). This work also applies approximate difference operators on graph signals and solves PDE using sparse data. The contents of blog are as follows:</p>

<ul>
  <li><a href="#modelling-physical-systems">Modelling physical systems</a></li>
  <li><a href="#graph-signals-and-fundamentals">Graph Signals and Fundamentals</a>
    <ul>
      <li><a href="#graph-signals-on-node">Graph signals on node</a></li>
      <li><a href="#graph-signals-on-edge">Graph signals on edge</a></li>
      <li><a href="#gradient-on-graphs">Gradient on Graphs</a></li>
      <li><a href="#laplace-beltrami-operator-on-graphs">Laplace-Beltrami Operator on graphs</a></li>
      <li><a href="#difference-operator-on-triangulated-mesh">Difference operator on Triangulated Mesh</a></li>
    </ul>
  </li>
  <li><a href="#previous-works">Previous Works</a></li>
  <li><a href="#network-architecture">Network Architecture</a>
    <ul>
      <li><a href="#spatial-difference-layer-sdl">Spatial Difference Layer (SDL)</a></li>
      <li><a href="#recurrent-graph-networks">Recurrent Graph Networks</a></li>
      <li><a href="#objective-function">Objective Function</a></li>
    </ul>
  </li>
  <li><a href="#effectiveness-of-sdl">Effectiveness of SDL</a>
    <ul>
      <li><a href="#approximation-of-directional-derivatives">Approximation of directional derivatives</a></li>
      <li><a href="#predicting-synthetic-graph-signals">Predicting synthetic graph signals</a></li>
    </ul>
  </li>
  <li><a href="#prediction-graph-signals-on-land-based-weather-sensors">Prediction: Graph Signals on Land-based weather sensors</a></li>
  <li><a href="#implementation-tricks">Implementation Tricks</a></li>
  <li><a href="#abalation-study">Abalation Study</a></li>
  <li><a href="#take-away-from-the-blog">Take away from the blog</a></li>
  <li><a href="#references">References</a></li>
</ul>

<h2 id="modelling-physical-systems">Modelling physical systems</h2>

<p>Physical systems have an inherent property, connectedness. There is an underlying structure in these systems which can be modelled. We tend to observe the physical system by measurements, and try to make sense of the behaviour. These observations or measurements are inter-related to each other and there is a underlying structure which can be modelled very well using graphs.</p>

<p>An image can be considered as a graph of pixels, a speech sequence can be considered as a graph of frames, a process can be considered as a graph of state, social networks can be thought of as a graph of users connected with each other and so on. Each node can have different properties, like pixel intensities for a pixel-node in image-graph. Since, the nodes are connected in some way any affect on one of the nodes also tend to have an impact on the neighboring nodes. These interactions are very important to model the overall behaviour of the physical system.</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/AU4-brow-lowerer.gif" />
<em>Fig. 1. A facial image can be considered as a collection of facial muscles interconnected with each other. Influence of one muscle is visible on other neighboring muscles as well. (Image source: <a href="https://imotions.com/blog/facial-action-coding-system/">Imotions</a>)</em>
</p>

<p>In real world scenarios, the observations are made using equipments and we usually lack resources or apparatus for measuring many such phenomena due to expensive setup. <strong>Some examples of physical phenomena are climate observations, heat-flow, diffusion of gases, weather data and many more.</strong></p>

<p>In weather or meteorological setup we donot have access to a lot of data, as it is impossible to measure temperature at each and every point in this world, instead having weather stations might help as they can act as the representative of that particular region. This indicates that we have to deal with sparse data. PDEs usually capture the behaviour accurately when the data is assumed to be from a continuous domain. While solving PDEs on sparse data, a numerical error is incurred since the derivative can only occur in continuous domain. This error is known as <strong>discretization error</strong> which happens due to sampling the continuous function. Further these errors can very well affect our understanding on modelling the dynamics of physical system.</p>

<p>As the observations become highly sparse and irregular in nature it becomes more hard to build efficient Deep learning models on top of them. Why would we do that? Because with dynamic systems we would like to predict what is going to happen. Predicting the future has always been tempting and if done accurately can save us a lot of resources and unnecessary efforts. Imagine if we can predict the temperature at a particular location for the whole region, then we know before hand that installing solar panels in regions with high temperature will be cost effective and efficient.</p>

<p>Coming to the sparse nature of the data, these sparse data observations have spatial relations but these observations also vary with time (dynamic systems). The temporal relation amongst these sparse data can be very helpful in predicting properties in near as well as far-future.</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/TG.jpg" />
<em>Fig. 2. Temporal graph, a graph which evolves with time. Here each graph is having spatial relations amongst the nodes and the node properties change with time creating a temporal relation. (Image source: <a href="https://towardsdatascience.com/temporal-graph-networks-ab8f327f2efe">Blog on Temporal Graph Networks</a>)</em>
</p>

<p><strong>To summarize, if we want to understand underlying behaviour of complex dynamic systems we should:</strong></p>
<ol>
  <li>Model the sparse data observations using graph (nodes, edges)</li>
  <li>Approximate original PDEs in continuous domain to difference equations in discrete domain. This will incur a discretization error.</li>
  <li>Solve PDEs on these graphs defined on sparse data using difference operators. We have to define operators which will act on sparse data (analogous to derivatives).</li>
  <li>Predict the properties of system by treating them as graph signals and leveraging both spatial and temporal differences.</li>
</ol>

<h2 id="graph-signals-and-fundamentals">Graph Signals and Fundamentals</h2>
<p><br />
A graph signal is a mapping from set of nodes or edges to real space. Say, we have a graph \(\mathcal G = (\mathbb V, \mathbb E)\) where \(\mathbb V =\{1,2,...N_{\mathbb V}\}\) is the set of vertices or nodes and \(\mathbb E = \{(i,j) | i,j \in \mathbb V\}\) is the set of edges then graph signal can be defined in two ways.
<br /></p>
<blockquote>
  <p>Readers can go through <a href="#shuman">[<strong>Shuman et al</strong>]</a> for an awesome introduction on graph signal processing.</p>
</blockquote>

<h3 id="graph-signals-on-node">Graph signals on node</h3>

<p>Consider for $i^{th}$ node in $\mathbb V$ there exists a function $f_i:\mathbb V \rightarrow \mathbb R^d$, where $d$ is the dimension of graph signal, then the graph signal on all nodes at time $t$ is defined as set of all such $f_i$ ‘s.
\(f(t) = \{f_i(t)|i\in\mathbb E\}\)</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/Graphsignal.jpg" />
<em>Fig. 3. Sample graph signal defined on nodes, here $\mathbb R^N$ can also be written as $\mathbb R^{N\times d}$ to represent multidimensional graph signal on nodes.
<br />(Image source: <a href="https://noamgit.github.io/2018-12-01-gsp/">Blog on GSP</a>)</em>
</p>

<h3 id="graph-signals-on-edge">Graph signals on edge</h3>
<p>Similarly, graph signals can also be defined on edges, \(F(t) = \{F_{ij}(t)|(i,j)\in\mathbb E\}\) where \(F_{ij}:\mathbb E\rightarrow \mathbb R^p\), here for simplicity p can be used to represent multi-dimensional graph signal on edges.</p>

<h3 id="gradient-on-graphs">Gradient on graphs</h3>

<p>Gradient of graph signal on nodes (aka function on nodes of a graph) is represented by a finite difference. This function is from hilbert space on nodes to hilbert space on edge. Finite difference of graph signals becomes edge features.</p>

\[{\nabla:L^2(\mathbb V) \rightarrow L^2(\mathbb E) },\\
(\nabla f)_{ij} = (f_j-f_i) \forall (i,j) \in\mathbb E, \text{otherwise 0}\]

<blockquote>
  <p>Readers are advised to go through <a href="#crane">[<strong>Crane K</strong>]</a> for an introduction on discrete differential geometry which involves the study of difference operators defined on graphs.</p>
</blockquote>

<h3 id="laplace-beltrami-operator-on-graphs">Laplace-Beltrami Operator on graphs</h3>

<p>Laplacian in graph domain is a function from Hilbert space of node functions to another Hilbert space on node functions. This becomes the laplacian matrix $L = D - A$, where $D$ is a diagonal degree matrix and $A$ is adjacency matrix.</p>

\[{\Delta:L^2(V) \rightarrow L^2(V) },\\ 
{(\Delta f)_i = \displaystyle\sum_{j:j\neq i}(f_i - f_j) \space \forall i,j \in V}\]

<h3 id="difference-operator-on-triangulated-mesh">Difference operator on Triangulated Mesh</h3>
<p>The operator on triangulated mesh not only considers gradient and laplacian but also the geometry of the surface through the angles that arrive at the mesh. The Finite Element Method discretization is given below:</p>

\[(\Delta f)_i = \frac{1}{2} \displaystyle \sum_{j:(i,j)\in\mathbb E}(\cot\alpha_j + \cot\beta_j)(f_j - f_i)\]

<p>where node $j$ belong to $i$’s immediate neighbors $(j\in\mathbb N_i)$ and $(\alpha_j,\beta_j)$ are two angles on the edge $(i,j)$</p>

<h2 id="previous-works">Previous Works</h2>

<blockquote>
  <p><strong>Assumption:</strong> Densely distributed data or input is on a continuous domain, if the data is sparse we cannot consider the input to be on a continuous domain.</p>
</blockquote>

<ol>
  <li>
    <p><strong>Physics-Informed Neural Networks (PINN)</strong> <a href="#raissi">[<strong>Raissi et al.</strong>]</a> learns non linear relations between input $(x,t)$  where $x$ is spatial coordinates and output simulated with a given PDE.</p>
  </li>
  <li>
    <p>Previous works like <a href="#chen">[<strong>Chen et al.</strong>]</a> also implement methods that incorporate prior domain knowledge with data driven approach. These methods can not capture the overall continuous nature of the domain as in real world scenarios we have a limited number of points.</p>
  </li>
  <li>
    <p>Some works like <a href="#long">[<strong>Long et al.</strong>]</a> also try to learn the underlying PDEs, but these works are good for regular grid structures only.</p>
  </li>
  <li>
    <p>Data first approaches for regular grid data have proved to be efficient in dealing with sparsity, which completely ignore physical equations of the dynamic systems.</p>
  </li>
</ol>

<p>Difference equations are very important in physical systems, as difference between the quantities hold useful information about the physical systems like Navier Stokes’, Traffic Flow and so on. In images, weighted differences are used to detect edges from images.</p>

<p>An example of system of coupled non-linear difference equations is given below:</p>

\[y[n] = nx[n] + \cos(x[n]) \\ 
y[n+1] = e^{y[n-1]}\]

<p><strong>Contributions of this work:</strong></p>

<ol>
  <li>Spatial Difference Layer based on GNNs, to exploit neighboring information in sparse data points.(Learning localized spatial features using sparse data) GNNs are used as they can leverage structural information.</li>
  <li>Recurrent Graph Network (RGN) layer after SDL, to learn the temporal difference.</li>
  <li>PA-DGN as an efficient method to approximate directional derivatives and predict graph signals in synthetic data. Experimentation to predict climate observations from weather stations, PA-DGN outperforms other baselines.</li>
</ol>

<h2 id="network-architecture">Network Architecture</h2>

<p>To exploit neighboring information to learn finite differences inspired by physics equations, a novel architecture PA-DGN is proposed. PA-DGN leverages data-driven end-to-end learning to discover underlying dynamical relations between spatial and temporal differences in given sequential observations.</p>

<p>PA-DGN consists of 2 modules, a Spatial Difference Layer (SDL) and a Recurrent Graph Network (RGN). Let us look them one by one.</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/PA-DGN.jpg" />
<em>Fig. 4. PA-DGN architecture with SDL and RGN modules. (Image source: <a href="https://openreview.net/pdf?id=r1gelyrtwH">Seo et. al</a>)</em>
</p>

<h3 id="spatial-difference-layer-sdl">Spatial Difference Layer (SDL)</h3>

<p>As the data is sparse, while considering the spatial features only relying on the neighboring nodes will be inaccurate.  To overcome this., SDL Layer aims at learning a difference operator which is a combination of both the gradient and Laplacian operator on the graph signal, to utilize the neighboring information. The learnable difference operator has the following representation:</p>

\[{(^w\nabla f)_{ij} = w_{ij}^{(g_1)}(f_j - w_{ij}^{(g_2)}f_i)}\]

\[{(^w\Delta f)_{i}} = {\displaystyle \sum_{j:(i,j)\in \mathbb E} w_{ij}^{(l_1)}(f_i - w_{ij}^{(l_2)}f_j)}\]

<p>The parameter $w_{ij}$ is used to tune the difference operators with corresponding edge direction ${\textbf e_{ij}}$. The superscript in the parameters represent aggregation functions which is the core of any GNN based architecture.</p>

\[w_{ij} = g(\{f_k, F_{mn}\space|\space k, (m,n) \in h-\text{hop neighborhood of edge}  \space e_{ij}\})\]

<p>$w_{ij}$ become the edge features of the output of aggregating function. This combination of gradient and laplacian operators result in a general difference operator which can be used in various other scenarios like sharpening, edge detection, modulating gradients and so on.</p>

<h3 id="recurrent-graph-networks">Recurrent Graph Networks</h3>

<p>After obtaining the spatial differences from SDL layer output in form of updated gradient and laplacian, the modulated graph signal is concatenated with the original graph signal to construct node-wise and edge-wise  features. The graph is thus called difference graph. 
This difference graph has information about the graph signal at time $t$. This graph can be used to predict graph signals in the next time step. To include both spatial and temporal variations the authors use a Recurrent Graph Network layer which takes an input graph state ${\mathcal G_{h}}$, node features $z_i$ and edge features $z_{ij}$. The output is graph state: \({\mathcal {G}_{h}^{*}} = (\mathit{h^{*(v)},h^{*(e)})}\) and the next node features are \(z_{i}^{*}\) and edge features \(z_{ij}^*\).</p>

<p><strong>Update rules:</strong></p>

\[{(z_{ij}^*, \mathit{h^{*(e)})}\leftarrow \phi^e(z_{ij},z_i,z_j,h^{(e)})}\space\forall\space(i,j)\in\mathbb{E}\]

\[{(z_{i}^*, \mathit{h^{*(v)})}\leftarrow \phi^v(z_{i},\bar z_i',h^{(v)})}\space\forall\space i\in\mathbb{V}\]

<p>Here $\bar z_i’$ is aggregated edge attribute of node $i$ . $\phi^e,\phi^v$ are edge and node update functions. Target is predicted through a decoder with inputs \(z_{i}^*\) , \(z_{ij}^*\).</p>

<h3 id="objective-function">Objective Function</h3>

<p>Loss function is the squared loss over all node functions and edge functions.
The following objective function is minimized:</p>

\[{\mathcal L = \displaystyle\sum_{v \in \mathbb V}||f_i-\hat f_i||^2 + \displaystyle \sum_{(i,j)\in \mathbb E}||F_{ij}-\hat F_{ij}||^2}\]

<h2 id="effectiveness-of-sdl">Effectiveness of SDL</h2>

<h3 id="approximation-of-directional-derivatives">Approximation of directional derivatives</h3>

<p>The following experiment was carried out to approximate directional derivative.</p>

<p><strong>Experiment:</strong> 2 Synthetic functions were considered with 200 sample points. Underlying graph was created using k = 4. With known gradient at each point, directional derivative can be computed by projecting ${\nabla f}$ to connected edge $e_{ij}$. A total of 4 baselines were considered for the above task and compared.</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/SDL.jpg" />
</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/SDL2.jpg" />
<em>Fig. 5. Gradients and graph structure of sampled points from synthetic functions. Left one is $0.1x^2+0.5y^2$ and right one is $\sin (x)+\cos(y)$. (Image Source : <a href="https://openreview.net/pdf?id=r1gelyrtwH">Seo et. al</a>)</em>
</p>
<p><br /></p>

<table>
  <thead>
    <tr>
      <th style="text-align: center">Functions</th>
      <th style="text-align: center">Mathematical expression</th>
      <th style="text-align: center">Remarks</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td style="text-align: center"><strong>FinGrad</strong></td>
      <td style="text-align: center">\(\frac{f_j-f_i}{\Vert x_j-x_i \Vert}\)</td>
      <td style="text-align: center">No learnable parameters, fixed 2 point approach</td>
    </tr>
    <tr>
      <td style="text-align: center"><strong>MLP</strong></td>
      <td style="text-align: center">Input : \((f_i,f_j,x_i, x_j)\)</td>
      <td style="text-align: center">Input same as FinGrad, but parameters are learnable</td>
    </tr>
    <tr>
      <td style="text-align: center"><strong>GN</strong></td>
      <td style="text-align: center">Edge features: \(d(x_i,x_j)\), Node features: \(f_i, f_j\)</td>
      <td style="text-align: center">Edge feature output is used as prediction for computing directional derivative</td>
    </tr>
    <tr>
      <td style="text-align: center"><strong>One-w</strong></td>
      <td style="text-align: center">\({(^w\nabla f)_{ij} = w_{ij}f_j - f_i}\)</td>
      <td style="text-align: center">Not very robust, as it doesn’t capture all possible combinations of fi and fj</td>
    </tr>
    <tr>
      <td style="text-align: center"><strong>SDL</strong></td>
      <td style="text-align: center">\({(^w\nabla f)_{ij} = w_{ij}^{(g_1)}(f_j - w_{ij}^{(g_2)}f_i)}\) \({(^w\Delta f)_{i}} = {\displaystyle \sum_{j:(i,j)\in \mathbb E} w_{ij}^{(l_1)}(f_i - w_{ij}^{(l_2)}f_j)}\)</td>
      <td style="text-align: center">Better than all baselines</td>
    </tr>
  </tbody>
</table>

<h3 id="predicting-synthetic-graph-signals">Predicting synthetic graph signals</h3>

<p>Experiment: PA-DGN is used on synthetic data sampled from simulation of convection-diffusion equations, to check the prediction performance of simulated dynamics from observations on discrete nodes itself. The equation used for this is:</p>

\[{\frac{df_i(t)}{dt} = a(i)(\nabla f)_{\hat x}+b(i)(\nabla f)_{\hat y}+c(i)\Delta f},\space
{f_i(0) = f_o(i)}\]

<p>\(i^{th}\) node coordinate is \((x_i,y_i)\) in the 2D space $([0,2\pi]\times[0,2\pi])$ $\hat x, \hat y$ are directions.</p>

\[a(i) = 0.5(\cos(y_i)+x_i(2\pi-x_i)\sin(x_i))+0.6\]

\[b(i) = 2(\cos(y_i)+ \sin(x_i))+0.8\]

\[c(i) = 0.5(1-\frac{\sqrt{(x_i-\pi)^2+(y_i-\pi)^2}}{\sqrt{2}\pi})\]

<p>A total of 250 sample points are uniformly chosen. Using these equations, it is possible to predict graph signal values of all points in future M steps, given that we have the previous N steps. N = 5, M = 15 is chosen for this experiment, and graph is created using KNN (K = 4). As the equation is a linear PDE, the SDL layer is cascaded with a linear regression model at the prediction end.</p>

<table>
  <thead>
    <tr>
      <th style="text-align: center">Models</th>
      <th style="text-align: center">Architecture</th>
      <th style="text-align: center">Remarks</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td style="text-align: center">VAR</td>
      <td style="text-align: center">2 lags with input concatenated from previous 2 frames</td>
      <td style="text-align: center">Weights are shared among all nodes</td>
    </tr>
    <tr>
      <td style="text-align: center">MLP</td>
      <td style="text-align: center">2 hidden layers network, input concatenated from previous 2 frames</td>
      <td style="text-align: center">Weights are shared among all nodes</td>
    </tr>
    <tr>
      <td style="text-align: center">RGN</td>
      <td style="text-align: center">2 GN Blocks, one edge update block and one node update block</td>
      <td style="text-align: center">Both blocks use 2 cell GRU with hidden dimension 73</td>
    </tr>
    <tr>
      <td style="text-align: center">StandardOP</td>
      <td style="text-align: center">Uses the standard difference operator on graphs</td>
      <td style="text-align: center">Hidden dimensions = 73</td>
    </tr>
    <tr>
      <td style="text-align: center">MeshOP</td>
      <td style="text-align: center">Uses the triangulated mesh operator on graphs</td>
      <td style="text-align: center">Hidden dimensions = 73</td>
    </tr>
  </tbody>
</table>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/SDL3.jpg" />
</p>

<p>StandardOP, MeshOP, SDL outperform rest of methods which shows that spatial difference information is crucial for prediction.</p>

<h2 id="prediction-graph-signals-on-land-based-weather-sensors">Prediction: Graph Signals on Land-based weather sensors</h2>

<p>The following experiment was carried out using 2 datasets.</p>

<p><strong>Experiment</strong>: Predicting Temperature from land-based weather stations located in USA</p>

<p><strong>Data</strong>: Weather stations group from western and southeastern states of USA were sampled from Online Climate Data Directory of the <strong>National Oceanic and Atmospheric Administration (NOAA)</strong> on the basis of how actively they measured meterological observations during 2015. K-NN graph with K = 4 is created and <strong>output adjacency matrix was transformed by $A \rightarrow (A+A^T)/2$ to make the adjacency matrix symmetric</strong>. Over a timeperiod of 1 year on hourly step basis was aggregated from all the stations and was split in the following way: <strong>8 months data for Training, 2 months data for Validation data, 2 months data for Test data</strong>. The loss function L is used for training using Adam optimizer and scheduled sampling <a href="#bengio">[<strong>Bengio et al</strong>]</a>. Two types of predictions are done, 1-step and multi-step. Four baselines are used : VAR, MLP, GRU, RGN <a href="#sanchez">[<strong>Sanchez-Gonzalez et al</strong>]</a></p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/Data.jpg" />
<em>Fig. 6. Weather stations from western and south-eastern states of USA. (Image Source: <a href="https://openreview.net/pdf?id=r1gelyrtwH">Seo et. al</a>)</em>
</p>

<p><strong>PA-DGN outperforms RGN</strong> as spatial differences and temporal differences are able to capture the predicted graph signal accurately due to the fact that the signal is not dependent on previous signal but also on the neighborhood and their signal values. This leads to a better understanding of the underlying physics of the dynamic system.</p>

<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/RGN.jpg" />
</p>
<p align="center">
<img src="https://iclr.iro.umontreal.ca/88050291-761c-42fa-8bfc-bd78b518b79a_1643555598/public/images/2021-12-01-padgn-blog/Params.jpg" />
</p>

<h2 id="implementation-tricks">Implementation Tricks</h2>

<ul>
  <li>NVIDIA GTX 1080Ti GPUs were used to run the experiments</li>
  <li>$h=2$</li>
  <li>Each experiment was run 3 times and std deviation was computed</li>
  <li>Synthetic data was trained by taking 5 frames input and predicting 15 frames</li>
  <li>NOAA dataset was trained by taking 12 frames input and predicting 12 frames</li>
  <li><strong>Hyperparameters:</strong></li>
</ul>

\[lr = 10^{-3}\\
\text{batch_size} = 8\\
\text{weight decay} = 5\times 10^{-4}\\
\text{Epochs} = 2000\]

<h2 id="abalation-study">Abalation Study</h2>

<p>RGN without spatial derivatives is evaluated on the graph signals from the dataset. RGN is then added with StandardOP (discrete spatial differences from Gradient and Laplacian) and evaluated. RGN is also added with MeshOP (triangular mesh approximation of differential operators) as separate input signals to RGN. The final model evaluated is PA-DGN which used RGN with SDL. <strong>PA-DGN shows least Mean Absolute Errors</strong> (3.56%, 5.50%, 8.51% and 8.73%, 8.32%, 5.49% on two datasets, respectively)</p>

<h2 id="take-away-from-the-blog">Take away from the blog</h2>

<ul>
  <li>Real world systems can be modelled using graphs, sparse data is a challenging frontier to deal with while it comes to solving PDEs and they cannot be applied directly.</li>
  <li>PDEs can be approximated as Difference equations, incurring an error.</li>
  <li>To solve both sparsity and approximation problem of PDEs, the work suggests PA-DGN which tries to solve the underlying dynamics by using spatial and temporal differences.</li>
  <li>Spatial differences were found to be very informative in various experiments carried out,</li>
  <li>PA-DGN was found to be superior in approximation of directional derivatives and prediction of graph signals on synthetic data and the real-world climate observations from weather stations.</li>
  <li>Operators with learnable parameters are better than approximated operators.</li>
</ul>

<h2 id="references">References</h2>

<p>[1]. Seo et al., <a href="https://openreview.net/pdf?id=r1gelyrtwH">“Physics-aware Difference Graph Networks for Sparsely-Observed Dynamics”</a>, ICLR 2020.</p>

<p>[2]. Stanković, L., &amp; Sejdić, E. (Eds.). (2019). Vertex-frequency analysis of graph signals. Springer International Publishing.</p>

<p>[3]. <a id="shuman"></a>Shuman et al., <a href="https://ieeexplore.ieee.org/abstract/document/6494675/">“The Emerging Field of Signal Processing on Graphs”</a>, IEEE Signal Processing Magazine.</p>

<p>[4]. <a id="raissi"></a>Raissi et al. <a href="https://arxiv.org/abs/1711.10561">“Physics informed deep learning (part i):
Data-driven solutions of nonlinear partial differential equations.”</a>, arXiv preprint</p>

<p>[5]. <a id="chen"></a>Chen et al. <a href="https://arxiv.org/abs/1503.05768">“On learning optimized reaction diffusion processes for
effective image restoration”</a>, CVPR 2015</p>

<p>[6]. <a id="long"></a>Long et al. <a href="https://arxiv.org/abs/1710.09668">“Pde-net: Learning pdes from data”</a>, ICML 2018</p>

<p>[7]. <a id="crane"></a>Crane K, <a href="">“Discrete differential geometry: An applied introduction”</a>, Notices of the AMS, Communication, 2018</p>

<p>[8]. <a id="bengio"></a>Bengio et al., <a href="https://arxiv.org/abs/1506.03099">“Scheduled sampling for sequence prediction with recurrent neural networks”</a>, NIPS 2015</p>

<p>[9]. <a id="sanchez"></a>Sanchez-Gonzalez et al., <a href="https://arxiv.org/abs/1806.01242">“Graph networks as learnable physics engines for inference and control”</a>, ICML 2018</p>

<p>[10]. Sandryhaila et al., <a href="https://arxiv.org/pdf/1210.4752.pdf">“Discrete Signal Processing on Graphs”</a>, IEEE Transactions on Signal Processing, 2013</p>


</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/#pa-dgn"> PA-DGN </a>
  
    <a class="content-tag" href="/tags/#pde"> PDE </a>
  
    <a class="content-tag" href="/tags/#graph-networks"> Graph Networks </a>
  
    <a class="content-tag" href="/tags/#sparse-data"> Sparse Data </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/#pa-dgn"> PA-DGN </a>
  
    <a class="content-tag" href="/tags/#pde"> PDE </a>
  
    <a class="content-tag" href="/tags/#graph-networks"> Graph Networks </a>
  
    <a class="content-tag" href="/tags/#sparse-data"> Sparse Data </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>
