class_cell Module

Class Constructor/destructor Parallel ops. Named constants


Uses

  • module~~class_cell~~UsesGraph module~class_cell class_cell module~class_psblas class_psblas module~class_cell->module~class_psblas module~class_stopwatch class_stopwatch module~class_psblas->module~class_stopwatch module~tools_psblas tools_psblas module~class_psblas->module~tools_psblas module~class_stopwatch->module~tools_psblas psb_base_mod psb_base_mod module~class_stopwatch->psb_base_mod psb_prec_mod psb_prec_mod module~tools_psblas->psb_prec_mod module~tools_psblas->psb_base_mod psb_krylov_mod psb_krylov_mod module~tools_psblas->psb_krylov_mod

Used by

  • module~~class_cell~~UsedByGraph module~class_cell class_cell proc~write_vtk_mesh write_vtk_mesh proc~write_vtk_mesh->module~class_cell module~class_mesh class_mesh proc~write_vtk_mesh->module~class_mesh module~class_output class_output proc~write_vtk_mesh->module~class_output proc~check_tet_quality check_tet_quality proc~check_tet_quality->module~class_cell proc~check_tet_quality->module~class_mesh proc~wr_vtk_mesh wr_vtk_mesh proc~wr_vtk_mesh->module~class_cell module~class_cell_procedures class_cell_procedures module~class_cell_procedures->module~class_cell module~class_mesh->module~class_cell proc~cmp_mesh_renum cmp_mesh_renum proc~cmp_mesh_renum->module~class_cell module~class_mesh_procedures class_mesh_procedures module~class_mesh_procedures->module~class_cell module~class_mesh_procedures->module~class_mesh module~geom_cell_implementation geom_cell_implementation module~geom_cell_implementation->module~class_cell proc~rd_exodus_mesh rd_exodus_mesh proc~rd_exodus_mesh->module~class_cell proc~smooth_mesh smooth_mesh proc~smooth_mesh->module~class_cell proc~smooth_mesh->module~class_mesh module~tools_mesh_optimize tools_mesh_optimize proc~smooth_mesh->module~tools_mesh_optimize module~tools_mesh_check tools_mesh_check proc~smooth_mesh->module~tools_mesh_check module~class_bc class_bc proc~smooth_mesh->module~class_bc proc~check_right_handed check_right_handed proc~check_right_handed->module~class_cell proc~check_right_handed->module~class_mesh proc~check_right_handed->module~tools_mesh_optimize proc~check_right_handed->module~tools_mesh_check proc~smooth_surf_vtx smooth_surf_vtx proc~smooth_surf_vtx->module~class_cell proc~smooth_surf_vtx->module~class_mesh proc~smooth_surf_vtx->module~tools_mesh_optimize proc~smooth_surf_vtx->module~tools_mesh_check proc~rd_cgns_mesh rd_cgns_mesh proc~rd_cgns_mesh->module~class_cell proc~write_vector_field write_vector_field proc~write_vector_field->module~class_cell proc~write_vector_field->module~class_mesh proc~write_vector_field->module~class_output module~class_vector_field class_vector_field proc~write_vector_field->module~class_vector_field proc~rd_gambit_mesh rd_gambit_mesh proc~rd_gambit_mesh->module~class_cell proc~write_mesh write_mesh proc~write_mesh->module~class_cell proc~write_mesh->module~class_mesh proc~write_mesh->module~class_output proc~apply_renum_cell apply_renum_cell proc~apply_renum_cell->module~class_cell proc~create_scalar_field create_scalar_field proc~create_scalar_field->module~class_cell proc~create_scalar_field->module~class_mesh proc~create_scalar_field->module~class_bc module~tools_output tools_output module~tools_output->module~class_cell module~tools_output->module~class_mesh module~tools_output->module~class_output module~tools_output->module~class_vector_field module~class_scalar_field class_scalar_field module~tools_output->module~class_scalar_field proc~check_mesh_quality check_mesh_quality proc~check_mesh_quality->module~class_cell proc~check_mesh_quality->module~class_mesh proc~check_mesh_quality->module~tools_mesh_check proc~check_mesh_quality->module~class_scalar_field module~class_exodus_procedures class_exodus_procedures module~class_exodus_procedures->module~class_cell module~class_exodus_procedures->module~class_mesh module~class_exodus_procedures->module~class_output module~class_exodus_procedures->module~class_vector_field module~class_exodus_procedures->module~class_scalar_field module~class_exodus class_exodus module~class_exodus_procedures->module~class_exodus proc~rd_gmsh_mesh rd_gmsh_mesh proc~rd_gmsh_mesh->module~class_cell proc~smooth_interior_vtx smooth_interior_vtx proc~smooth_interior_vtx->module~class_cell proc~smooth_interior_vtx->module~class_mesh proc~smooth_interior_vtx->module~tools_mesh_optimize proc~smooth_interior_vtx->module~tools_mesh_check proc~get_vector_field get_vector_field proc~get_vector_field->module~class_cell proc~get_vector_field->module~class_mesh proc~get_vector_field->module~class_output proc~get_vector_field->module~class_vector_field proc~get_vector_field->module~class_scalar_field proc~get_scalar_field get_scalar_field proc~get_scalar_field->module~class_cell proc~get_scalar_field->module~class_mesh proc~get_scalar_field->module~class_output proc~get_scalar_field->module~class_scalar_field module~tools_nemo tools_nemo module~tools_nemo->module~class_mesh module~tools_nemo->module~tools_output module~tools_nemo->module~tools_mesh_optimize module~tools_nemo->module~class_output module~tools_nemo->module~class_vector_field module~tools_nemo->module~tools_mesh_check module~class_scalar_pde class_scalar_pde module~tools_nemo->module~class_scalar_pde module~op_div op_div module~tools_nemo->module~op_div module~class_vector_pde class_vector_pde module~tools_nemo->module~class_vector_pde module~tools_nemo->module~class_scalar_field module~op_grad op_grad module~tools_nemo->module~op_grad module~op_field op_field module~tools_nemo->module~op_field module~op_ddt op_ddt module~tools_nemo->module~op_ddt module~op_d2dt2 op_d2dt2 module~tools_nemo->module~op_d2dt2 module~tools_nemo->module~class_bc module~op_laplacian op_laplacian module~tools_nemo->module~op_laplacian module~op_source op_source module~tools_nemo->module~op_source module~class_field class_field module~class_field->module~class_mesh module~class_field->module~class_bc proc~rhie_chow rhie_chow proc~rhie_chow->module~class_mesh proc~rhie_chow->module~class_field proc~rhie_chow->module~class_vector_field proc~rhie_chow->module~class_scalar_field proc~update_boundary_wall_v update_boundary_wall_v proc~update_boundary_wall_v->module~class_mesh proc~vector_pde_d2dt2 vector_pde_d2dt2 proc~vector_pde_d2dt2->module~class_mesh proc~vector_pde_d2dt2->module~class_vector_field proc~vector_pde_d2dt2->module~class_vector_pde proc~vector_pde_d2dt2->module~class_scalar_field proc~vector_pde_grad vector_pde_grad proc~vector_pde_grad->module~class_mesh proc~vector_pde_grad->module~class_vector_pde proc~vector_pde_grad->module~class_scalar_field module~tools_mesh_optimize->module~class_mesh module~tools_mesh_optimize->module~class_bc proc~vector_field_grad vector_field_grad proc~vector_field_grad->module~class_mesh proc~vector_field_grad->module~class_vector_field proc~set_scalar_field_group set_scalar_field_group proc~set_scalar_field_group->module~class_mesh proc~update_boundary_math update_boundary_math proc~update_boundary_math->module~class_mesh proc~tet_valid tet_valid proc~tet_valid->module~class_mesh proc~tet_valid->module~tools_mesh_optimize proc~geins_vector_pde_r geins_vector_pde_r proc~geins_vector_pde_r->module~class_mesh proc~set_vector_field_group set_vector_field_group proc~set_vector_field_group->module~class_mesh module~write_mesh_implementation write_mesh_implementation module~write_mesh_implementation->module~tools_output proc~write_scalar_pde write_scalar_pde proc~write_scalar_pde->module~class_mesh module~class_bc_wall class_bc_wall module~class_bc_wall->module~class_mesh proc~geins_scalar_pde geins_scalar_pde proc~geins_scalar_pde->module~class_mesh module~class_output->module~class_mesh module~class_output->module~class_vector_field module~class_output->module~class_scalar_field proc~vector_pde_div vector_pde_div proc~vector_pde_div->module~class_mesh proc~vector_pde_div->module~class_vector_pde proc~vector_pde_div->module~class_bc proc~free_pde~2 free_pde proc~free_pde~2->module~class_mesh proc~vector_pde_ddt vector_pde_ddt proc~vector_pde_ddt->module~class_mesh proc~vector_pde_ddt->module~class_vector_field proc~vector_pde_ddt->module~class_vector_pde proc~vector_pde_ddt->module~class_scalar_field proc~vector_pde_source vector_pde_source proc~vector_pde_source->module~class_mesh proc~vector_pde_source->module~class_vector_field proc~vector_pde_source->module~class_scalar_pde proc~vector_pde_source->module~class_vector_pde proc~update_vector_field update_vector_field proc~update_vector_field->module~class_mesh proc~update_vector_field->module~class_bc module~class_vector_field->module~class_mesh module~class_vector_field->module~class_field module~class_vector_field->module~class_bc module~class_vtk_output_procedures class_vtk_output_procedures module~class_vtk_output_procedures->module~class_mesh module~class_vtk_output class_vtk_output module~class_vtk_output_procedures->module~class_vtk_output proc~scalar_pde_source scalar_pde_source proc~scalar_pde_source->module~class_mesh module~class_vtk_output->module~class_mesh module~class_vtk_output->module~class_output module~class_vtk_output->module~class_vector_field module~class_vtk_output->module~class_scalar_field proc~check_mesh_consistency_bf check_mesh_consistency_bf proc~check_mesh_consistency_bf->module~class_mesh proc~flux_pde_div flux_pde_div proc~flux_pde_div->module~class_mesh proc~asb_pde_~2 asb_pde_ proc~asb_pde_~2->module~class_mesh proc~move_boundary move_boundary proc~move_boundary->module~class_mesh proc~move_boundaries move_boundaries proc~move_boundaries->module~class_mesh module~tools_mesh_check->module~class_mesh module~tools_mesh_check->module~class_scalar_field proc~scalar_pde_div scalar_pde_div proc~scalar_pde_div->module~class_mesh proc~scalar_pde_div->module~class_bc proc~interp_on_faces_v interp_on_faces_v proc~interp_on_faces_v->module~class_mesh proc~scalar_pde_ddt scalar_pde_ddt proc~scalar_pde_ddt->module~class_mesh proc~geins_vector_pde_v geins_vector_pde_v proc~geins_vector_pde_v->module~class_mesh module~class_scalar_pde->module~class_mesh module~class_scalar_pde->module~class_scalar_field module~class_pde class_pde module~class_scalar_pde->module~class_pde proc~check_field_operands check_field_operands proc~check_field_operands->module~class_mesh module~write_vector_field_implementation write_vector_field_implementation module~write_vector_field_implementation->module~tools_output proc~free_pde~3 free_pde proc~free_pde~3->module~class_mesh proc~create_vector_field create_vector_field proc~create_vector_field->module~class_mesh proc~create_vector_field->module~class_bc proc~create_bc_math create_bc_math proc~create_bc_math->module~class_mesh proc~asb_pde_~3 asb_pde_ proc~asb_pde_~3->module~class_mesh proc~update_boundary_wall_s update_boundary_wall_s proc~update_boundary_wall_s->module~class_mesh proc~create_pde~3 create_pde proc~create_pde~3->module~class_mesh module~write_scalar_field_implementation write_scalar_field_implementation module~write_scalar_field_implementation->module~tools_output proc~nemo_scalar_field_norm1 nemo_scalar_field_norm1 proc~nemo_scalar_field_norm1->module~class_mesh module~op_div->module~class_mesh module~op_div->module~class_vector_field module~op_div->module~class_scalar_pde module~op_div->module~class_vector_pde module~op_div->module~class_scalar_field proc~vector_pde_laplacian vector_pde_laplacian proc~vector_pde_laplacian->module~class_mesh proc~vector_pde_laplacian->module~class_vector_field proc~vector_pde_laplacian->module~class_vector_pde proc~vector_pde_laplacian->module~class_scalar_field proc~vector_pde_laplacian->module~op_grad proc~vector_pde_laplacian->module~class_bc proc~vector_field_flux vector_field_flux proc~vector_field_flux->module~class_mesh proc~vector_field_flux->module~class_field proc~vector_field_flux->module~class_vector_field proc~vector_field_flux->module~class_scalar_field module~class_vector_pde_procedures class_vector_pde_procedures module~class_vector_pde_procedures->module~class_mesh module~class_vector_pde_procedures->module~class_vector_pde module~class_vector_pde_procedures->module~class_pde proc~write_vector_pde write_vector_pde proc~write_vector_pde->module~class_mesh proc~create_bc create_bc proc~create_bc->module~class_mesh proc~update_boundary_s update_boundary_s proc~update_boundary_s->module~class_mesh proc~solve_vector_pde solve_vector_pde proc~solve_vector_pde->module~class_mesh proc~solve_vector_pde->module~class_vector_field proc~apply_abc_to_boundary_s apply_abc_to_boundary_s proc~apply_abc_to_boundary_s->module~class_mesh proc~update_scalar_field update_scalar_field proc~update_scalar_field->module~class_mesh proc~update_scalar_field->module~class_bc proc~scalar_pde_laplacian scalar_pde_laplacian proc~scalar_pde_laplacian->module~class_mesh proc~scalar_pde_laplacian->module~op_grad proc~scalar_pde_laplacian->module~class_bc module~class_vector_pde->module~class_mesh module~class_vector_pde->module~class_vector_field module~class_vector_pde->module~class_pde proc~create_pde~2 create_pde proc~create_pde~2->module~class_mesh proc~scalar_field_grad scalar_field_grad proc~scalar_field_grad->module~class_mesh proc~scalar_field_grad->module~class_scalar_field proc~apply_abc_to_boundary_v apply_abc_to_boundary_v proc~apply_abc_to_boundary_v->module~class_mesh proc~check_vertex_quality check_vertex_quality proc~check_vertex_quality->module~class_mesh module~class_scalar_field->module~class_mesh module~class_scalar_field->module~class_field module~class_scalar_field->module~class_bc proc~get_abc_math_s get_abc_math_s proc~get_abc_math_s->module~class_mesh proc~scalar_pde_d2dt2 scalar_pde_d2dt2 proc~scalar_pde_d2dt2->module~class_mesh proc~interp_on_faces_s interp_on_faces_s proc~interp_on_faces_s->module~class_mesh proc~update_boundary_v update_boundary_v proc~update_boundary_v->module~class_mesh module~class_exodus->module~class_mesh module~class_exodus->module~class_output module~class_exodus->module~class_vector_field module~class_exodus->module~class_scalar_field module~class_pde->module~class_mesh proc~solve_scalar_pde solve_scalar_pde proc~solve_scalar_pde->module~class_mesh proc~solve_scalar_pde->module~class_scalar_field proc~nemo_scalar_field_normi nemo_scalar_field_normi proc~nemo_scalar_field_normi->module~class_mesh proc~get_abc_math_v get_abc_math_v proc~get_abc_math_v->module~class_mesh module~smooth_surf_vtx_implementation smooth_surf_vtx_implementation module~smooth_surf_vtx_implementation->module~tools_mesh_optimize module~tools_mesh_check_tet tools_mesh_check_tet module~tools_mesh_check_tet->module~tools_mesh_check module~smooth_mesh_implementation smooth_mesh_implementation module~smooth_mesh_implementation->module~tools_mesh_optimize module~class_output_procedures class_output_procedures module~class_output_procedures->module~class_output module~op_grad->module~class_vector_field module~op_grad->module~class_vector_pde module~op_grad->module~class_scalar_field module~op_field->module~class_vector_field module~op_field->module~class_scalar_field module~flux_pde_div_implementation flux_pde_div_implementation module~flux_pde_div_implementation->module~op_div proc~create_output create_output proc~create_output->module~class_vtk_output module~op_ddt->module~class_vector_field module~op_ddt->module~class_scalar_pde module~op_ddt->module~class_vector_pde module~op_ddt->module~class_scalar_field module~laplacian_smooth_implementation laplacian_smooth_implementation module~laplacian_smooth_implementation->module~tools_mesh_optimize module~op_d2dt2->module~class_vector_field module~op_d2dt2->module~class_scalar_pde module~op_d2dt2->module~class_vector_pde module~op_d2dt2->module~class_scalar_field module~class_field_procedures class_field_procedures module~class_field_procedures->module~class_field module~class_vector_field_procedures class_vector_field_procedures module~class_vector_field_procedures->module~class_field module~class_vector_field_procedures->module~class_vector_field module~class_bc->module~class_bc_wall module~vector_pde_div_implementation vector_pde_div_implementation module~vector_pde_div_implementation->module~op_div module~tools_mesh_check_vertex tools_mesh_check_vertex module~tools_mesh_check_vertex->module~tools_mesh_check module~op_laplacian->module~class_vector_field module~op_laplacian->module~class_scalar_pde module~op_laplacian->module~class_vector_pde module~op_laplacian->module~class_scalar_field module~class_bc_wall_procedures class_bc_wall_procedures module~class_bc_wall_procedures->module~class_bc_wall module~check_right_handed_implementation check_right_handed_implementation module~check_right_handed_implementation->module~tools_mesh_optimize module~check_mesh_quality_implementation check_mesh_quality_implementation module~check_mesh_quality_implementation->module~tools_mesh_check module~op_source->module~class_scalar_pde module~op_source->module~class_scalar_field module~scalar_pde_div_implementation scalar_pde_div_implementation module~scalar_pde_div_implementation->module~op_div module~class_pde_procedures class_pde_procedures module~class_pde_procedures->module~class_pde proc~scalar_vector_fld_mul scalar_vector_fld_mul proc~scalar_vector_fld_mul->module~class_field proc~scalar_vector_fld_mul->module~class_vector_field proc~scalar_vector_fld_mul->module~class_scalar_field module~mobile_verts_implementation mobile_verts_implementation module~mobile_verts_implementation->module~tools_mesh_optimize proc~scalar_fld_vector_mul scalar_fld_vector_mul proc~scalar_fld_vector_mul->module~class_field proc~scalar_fld_vector_mul->module~class_vector_field proc~scalar_fld_vector_mul->module~class_scalar_field module~class_scalar_pde_procedures class_scalar_pde_procedures module~class_scalar_pde_procedures->module~class_scalar_pde module~class_scalar_field_procedures class_scalar_field_procedures module~class_scalar_field_procedures->module~class_field module~class_scalar_field_procedures->module~class_scalar_field module~smooth_interior_vtx_implementation smooth_interior_vtx_implementation module~smooth_interior_vtx_implementation->module~tools_mesh_optimize module~class_bc_procedures class_bc_procedures module~class_bc_procedures->module~class_bc module~scalar_pde_source_implementation scalar_pde_source_implementation module~scalar_pde_source_implementation->module~op_source module~vector_field_flux_implementation vector_field_flux_implementation module~vector_field_flux_implementation->module~op_field module~vector_field_grad_implementation vector_field_grad_implementation module~vector_field_grad_implementation->module~op_grad module~vector_pde_d2dt2_implementation vector_pde_d2dt2_implementation module~vector_pde_d2dt2_implementation->module~op_d2dt2 module~scalar_field_grad_implementation scalar_field_grad_implementation module~scalar_field_grad_implementation->module~op_grad module~vector_pde_laplacian_implementation vector_pde_laplacian_implementation module~vector_pde_laplacian_implementation->module~op_laplacian module~vector_pde_ddt_implementation vector_pde_ddt_implementation module~vector_pde_ddt_implementation->module~op_ddt module~op_laplacian_procedures op_laplacian_procedures module~op_laplacian_procedures->module~op_laplacian module~op_d2dt2_procedures op_d2dt2_procedures module~op_d2dt2_procedures->module~op_d2dt2 module~op_ddt_procedures op_ddt_procedures module~op_ddt_procedures->module~op_ddt module~scalar_pde_d2dt2_implementation scalar_pde_d2dt2_implementation module~scalar_pde_d2dt2_implementation->module~op_d2dt2 module~scalar_pde_ddt_implementation scalar_pde_ddt_implementation module~scalar_pde_ddt_implementation->module~op_ddt module~scalar_fld_vector_mul_implementation scalar_fld_vector_mul_implementation module~scalar_fld_vector_mul_implementation->module~op_field module~scalar_vector_fld_mul_implementation scalar_vector_fld_mul_implementation module~scalar_vector_fld_mul_implementation->module~op_field module~scalar_pde_laplacian_implementation scalar_pde_laplacian_implementation module~scalar_pde_laplacian_implementation->module~op_laplacian module~rhie_chow_implementation rhie_chow_implementation module~rhie_chow_implementation->module~op_field module~vector_pde_grad_implementation vector_pde_grad_implementation module~vector_pde_grad_implementation->module~op_grad

Contents


Variables

TypeVisibility AttributesNameInitial
integer, public, parameter:: ihex_ =6

prism, hexahedron

integer, public, parameter:: ipri_ =5

prism, hexahedron

integer, public, parameter:: ipyr_ =4

tetrahedral, pyramid

integer, public, parameter:: iqua_ =2

triangle, quadrilateral

integer, public, parameter:: itet_ =3

tetrahedral, pyramid

integer, public, parameter:: itri_ =1

triangle, quadrilateral

integer, private, parameter:: nlen =3

Interfaces

interface

  • public module subroutine alloc_cell(cells, n)

    Array constructor

    Arguments

    Type IntentOptional AttributesName
    type(cell), allocatable:: cells(:)
    integer, intent(in) :: n

interface

  • public module subroutine bcast_cell(cells)

    Arguments

    Type IntentOptional AttributesName
    type(cell), allocatable:: cells(:)

interface

  • public elemental module function cell_(nv, nf, group, geo)

    Arguments

    Type IntentOptional AttributesName
    integer, intent(in) :: nv
    integer, intent(in) :: nf
    integer, intent(in) :: group
    character(len=nlen), intent(in) :: geo

    Return Value type(cell)

interface

  • public module subroutine free_cell(cells)

    Arguments

    Type IntentOptional AttributesName
    type(cell), allocatable:: cells(:)

interface

  • public module subroutine g2l_cell(cells, desc_c)

    Arguments

    Type IntentOptional AttributesName
    type(cell), allocatable:: cells(:)
    type(psb_desc_type), intent(in) :: desc_c

interface

  • public module subroutine get_cells_type(cells, nctype, ictype, desc)

    Arguments

    Type IntentOptional AttributesName
    type(cell), intent(in) :: cells(:)

    array of cells structs

    integer, intent(out), allocatable:: nctype(:)

    count of each type

    integer, intent(out), allocatable:: ictype(:)

    array of cell id's sorted by type

    type(psb_desc_type), intent(in), optional :: desc

interface

  • public module subroutine l2g_cell(cells_loc, cells_glob, desc_c)

    WARNING! The global results is allocated only on P0. After its usage it must be deallocated in the calling unit by means of the statement: "if(associated(glob_res)) deallocate(glob_res)"

    Arguments

    Type IntentOptional AttributesName
    type(cell), allocatable:: cells_loc(:)
    type(cell), allocatable:: cells_glob(:)
    type(psb_desc_type), intent(in) :: desc_c

interface

  • private module function get_cell_geo(c)

    Arguments

    Type IntentOptional AttributesName
    class(cell), intent(in) :: c

    Return Value character(len=nlen)

interface

  • private module function get_cell_group(c)

    Arguments

    Type IntentOptional AttributesName
    class(cell), intent(in) :: c

    Return Value integer

interface

  • private elemental module function get_cell_nv(c)

    Arguments

    Type IntentOptional AttributesName
    class(cell), intent(in) :: c

    Return Value integer

interface

  • private elemental module function nemo_cell_sizeof(cll)

    Arguments

    Type IntentOptional AttributesName
    class(cell), intent(in) :: cll

    Return Value integer(kind=nemo_int_long_)


Derived Types

type, public :: cell

Components

TypeVisibility AttributesNameInitial
character(len=nlen), private :: geo

abbreviation for kind of cell

integer, private :: group

group ID of cell

integer, private :: nf

number of faces

integer, private :: nv

number of vertices

Type-Bound Procedures

generic, public :: geo_ => get_cell_geo
generic, public :: group_ => get_cell_group
generic, public :: nemo_sizeof => nemo_cell_sizeof
generic, public :: nv_ => get_cell_nv
procedure, private :: get_cell_geo
procedure, private :: get_cell_group
procedure, private :: get_cell_nv
procedure, private :: nemo_cell_sizeof