Neko-TOP
A portable framework for high-order spectral element flow toplogy optimization.
Loading...
Searching...
No Matches
design::design_t Type Referenceabstract

An abstract design type. More...

Inheritance diagram for design::design_t:

Public Member Functions

procedure, pass(this) init_from_json_sim (this, parameters, simulation)
 Initialize the design.
 
procedure, pass(this) init_from_json (this, parameters)
 Initialize the design.
 
procedure(design_free), deferred, pass, public free (this)
 Free the design.
 
procedure(design_get_values), deferred, pass, public get_values (this)
 Retrieve the design variables.
 
procedure, pass(this), public get_x (this)
 Retrieve the x location of the design variables.
 
procedure, pass(this), public get_y (this)
 Retrieve the y location of the design variables.
 
procedure, pass(this), public get_z (this)
 Retrieve the z location of the design variables.
 
procedure(design_update_design), deferred, pass, public update_design (this, values)
 Update the design variables.
 
procedure(design_map_forward), deferred, pass, public map_forward (this)
 Run the forward mapping of the design.
 
procedure(design_map_backward), deferred, pass, public map_backward (this, sensitivity)
 Run the backward mapping of the design.
 
procedure(design_write), deferred, pass, public write (this, idx)
 Write the design.
 
procedure, pass(this) init_base (this, n)
 Initialize the base design.
 
procedure, pass(this) free_base (this)
 Free the base design.
 
procedure, pass(this), public size (this)
 Return the number of design variables.
 
procedure, pass(this), public size_global (this)
 Return the number of global design variables.
 

Public Attributes

integer n_global = 0
 The global number of design variables.
 

Detailed Description

This type is used to define the interface for the design variables. These design are used to define the optimization problem. A given design can be initialized from the factory and is responsible for providing any alterations to the simulation based on the design variables.

Definition at line 50 of file design.f90.

Member Function/Subroutine Documentation

◆ free()

procedure(design_free), deferred, pass, public design::design_t::free ( class(design_t), intent(inout)  this)
pure virtual

Definition at line 86 of file design.f90.

◆ free_base()

procedure, pass(this) design::design_t::free_base ( class(design_t), intent(inout)  this)
Parameters
thisThe design object.

Definition at line 116 of file design.f90.

◆ get_values()

procedure(design_get_values), deferred, pass, public design::design_t::get_values ( class(design_t), intent(in)  this)
pure virtual

Definition at line 89 of file design.f90.

◆ get_x()

procedure, pass(this), public design::design_t::get_x ( class(design_t), intent(in)  this)

Definition at line 91 of file design.f90.

◆ get_y()

procedure, pass(this), public design::design_t::get_y ( class(design_t), intent(in)  this)

Definition at line 93 of file design.f90.

◆ get_z()

procedure, pass(this), public design::design_t::get_z ( class(design_t), intent(in)  this)

Definition at line 95 of file design.f90.

◆ init_base()

procedure, pass(this) design::design_t::init_base ( class(design_t), intent(inout)  this,
integer, intent(in)  n 
)
Parameters
thisThe design object.
nThe number of design variables.

Definition at line 114 of file design.f90.

◆ init_from_json()

procedure, pass(this) design::design_t::init_from_json ( class(design_t), intent(inout)  this,
type(json_file), intent(inout)  parameters 
)

This method is used to initialize the design from a JSON file. The design object will be initialized based on the parameters provided in the JSON file.

Parameters
thisThe design object.
parametersThe JSON parameters.

Definition at line 83 of file design.f90.

◆ init_from_json_sim()

procedure, pass(this) design::design_t::init_from_json_sim ( class(design_t), intent(inout)  this,
type(json_file), intent(inout)  parameters,
type(simulation_t), intent(inout)  simulation 
)

This method is used to initialize the design from a JSON file. The design object will be initialized based on the parameters provided in the JSON file. The simulation object is also provided to allow for any additional setup.

Parameters
thisThe design object.
parametersThe JSON parameters.
simulationThe simulation object.

Definition at line 73 of file design.f90.

◆ map_backward()

procedure(design_map_backward), deferred, pass, public design::design_t::map_backward ( class(design_t), intent(inout)  this,
type(vector_t), intent(in)  sensitivity 
)
pure virtual

Definition at line 105 of file design.f90.

◆ map_forward()

procedure(design_map_forward), deferred, pass, public design::design_t::map_forward ( class(design_t), intent(inout)  this)
pure virtual

Definition at line 102 of file design.f90.

◆ size()

procedure, pass(this), public design::design_t::size ( class(design_t), intent(in)  this)
Parameters
thisThe design object.
Returns
The number of design variables.

Definition at line 118 of file design.f90.

◆ size_global()

procedure, pass(this), public design::design_t::size_global ( class(design_t), intent(in)  this)

Definition at line 120 of file design.f90.

◆ update_design()

procedure(design_update_design), deferred, pass, public design::design_t::update_design ( class(design_t), intent(inout)  this,
type(vector_t), intent(inout)  values 
)
pure virtual

Definition at line 98 of file design.f90.

◆ write()

procedure(design_write), deferred, pass, public design::design_t::write ( class(design_t), intent(inout)  this,
integer, intent(in)  idx 
)
pure virtual

Definition at line 108 of file design.f90.

Member Data Documentation

◆ n_global

integer design::design_t::n_global = 0

Definition at line 56 of file design.f90.


The documentation for this type was generated from the following file: