Neko-TOP
A portable framework for high-order spectral element flow toplogy optimization.
Loading...
Searching...
No Matches
base_functional.f90
Go to the documentation of this file.
1! Copyright (c) 2024, The Neko Authors
2! All rights reserved.
3!
4! Redistribution and use in source and binary forms, with or without
5! modification, are permitted provided that the following conditions
6! are met:
7!
8! * Redistributions of source code must retain the above copyright
9! notice, this list of conditions and the following disclaimer.
10!
11! * Redistributions in binary form must reproduce the above
12! copyright notice, this list of conditions and the following
13! disclaimer in the documentation and/or other materials provided
14! with the distribution.
15!
16! * Neither the name of the authors nor the names of its
17! contributors may be used to endorse or promote products derived
18! from this software without specific prior written permission.
19!
20! THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21! "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22! LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23! FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24! COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25! INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26! BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27! LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
28! CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29! LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30! ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31! POSSIBILITY OF SUCH DAMAGE.
32
35 use design, only: design_t
36 use json_module, only: json_file
37 use num_types, only: rp
38 use point_zone, only: point_zone_t
39 use simulation, only: simulation_t
40 use vector, only: vector_t
41 implicit none
42 private
43
54 type, abstract, public :: base_functional_t
55
57 real(kind=rp) :: value
59 type(vector_t) :: sensitivity
61 character(len=25) :: name
63 logical :: has_mask
65 class(point_zone_t), pointer :: mask => null()
66
67 contains
68
69 ! ----------------------------------------------------------------------- !
70 ! Derived class interfaces
71
73 procedure(functional_init), pass(this), deferred :: init_json
75 procedure(functional_free), pass(this), deferred :: free
76
78 procedure(functional_update_value), pass(this), deferred :: update_value
80 procedure(functional_update_sensitivity), pass(this), deferred :: &
81 update_sensitivity
82 end type base_functional_t
83
84 ! -------------------------------------------------------------------------- !
85 ! Interface specifications for the derived types, these are the constructors
86 ! for the different types of objective functions.
87
88 abstract interface
89
91 subroutine functional_init(this, json, design, simulation)
92 import base_functional_t, design_t, simulation_t, json_file
93 class(base_functional_t), intent(inout) :: this
94 type(json_file), intent(inout) :: json
95 class(design_t), intent(in) :: design
96 type(simulation_t), target, intent(inout) :: simulation
97 end subroutine functional_init
98
100 subroutine functional_free(this)
101 import base_functional_t
102 class(base_functional_t), intent(inout) :: this
103 end subroutine functional_free
104
106 subroutine functional_update_value(this, design)
108 class(base_functional_t), intent(inout) :: this
109 class(design_t), intent(in) :: design
110 end subroutine functional_update_value
111
113 subroutine functional_update_sensitivity(this, design)
115 class(base_functional_t), intent(inout) :: this
116 class(design_t), intent(in) :: design
117 end subroutine functional_update_sensitivity
118
119 end interface
120
121end module base_functional
Initialize the objective function.
Compute the objective function.
Defines the abstract the base_functional_t type.
Implements the design_t.
Definition design.f90:34
Sensitivity module. This module contains the sensitivity computation of the topology optimization.
Implements the steady_problem_t type.
An abstract design type.
Definition design.f90:48