(*********************************************************************************** * Copyright (c) University of Exeter, UK * * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright notice, this * * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * SPDX-License-Identifier: BSD-2-Clause ***********************************************************************************) section‹Neural Networks as Graphs› text‹ In this theory, we use the AFP entry ``Graph Theory''~\<^cite>‹"noschinski:graph:2013"› to model neural networks. In particular, we make use of the formalization of directed graphs. › theory NN_Digraph imports Graph_Theory.Digraph begin definition pipe :: ‹'a ⇒ ('a ⇒ 'b) ⇒ 'b› (infixl ‹ ▹ › 70) where ‹a ▹ f = f a› text‹ We follow the notation used in \<^cite>‹"aggarwal:neural:2018"›, i.e., a neural network consists our of edges and neurons (nodes). › type_synonym id = nat record ('a, 'b) Neuron = φ :: 'b ― ‹activation function› α :: 'a ― ‹learning rate› β :: 'a ― ‹bias› uid :: id ― ‹unique identifier›