athena_initialiser_ones.f90 Source File


Source Code

module athena__initialiser_ones
  !! Module containing the implementation of the Ones initialiser
  !!
  !! This module contains the implementation of the Ones initialiser
  !! for the weights and biases of a layer
  use coreutils, only: real32
  use athena__misc_types, only: base_init_type
  implicit none


  private

  public :: ones_init_type


  type, extends(base_init_type) :: ones_init_type
     !! Type for the Ones initialiser
   contains
     procedure, pass(this) :: initialise => ones_initialise
     !! Initialise the weights and biases using the Ones distribution
  end type ones_init_type


  interface ones_init_type
     module function initialiser_ones_setup() result(initialiser)
       !! Interface for the Ones initialiser
       type(ones_init_type) :: initialiser
       !! Ones initialiser object
     end function initialiser_ones_setup
  end interface ones_init_type



contains

!###############################################################################
  module function initialiser_ones_setup() result(initialiser)
    !! Interface for the Ones initialiser
    implicit none

    type(ones_init_type) :: initialiser
    !! Ones initialiser object

    initialiser%name = "ones"

  end function initialiser_ones_setup
!###############################################################################


!###############################################################################
  pure subroutine ones_initialise(this, input, fan_in, fan_out, spacing)
    !! Initialise the weights and biases using the Ones distribution
    implicit none

    ! Arguments
    class(ones_init_type), intent(inout) :: this
    !! Instance of the Ones initialiser
    real(real32), dimension(..), intent(out) :: input
    !! Weights and biases to initialise
    integer, optional, intent(in) :: fan_in, fan_out
    !! Number of input and output parameters
    integer, dimension(:), optional, intent(in) :: spacing
    !! Spacing of the input and output units

    select rank(input)
    rank(0)
       input = 1._real32
    rank(1)
       input = 1._real32
    rank(2)
       input = 1._real32
    rank(3)
       input = 1._real32
    rank(4)
       input = 1._real32
    rank(5)
       input = 1._real32
    rank(6)
       input = 1._real32
    end select

  end subroutine ones_initialise
!###############################################################################

end module athena__initialiser_ones