| Functions/Subroutines | |
| subroutine | c_bpack_eigen (bmat_A, option_A, ptree_A, stats_A, bmat_B, option_B, ptree_B, stats_B, bmat_sh, option_sh, ptree_sh, stats_sh, Nunk, Nunk_loc, nev, tol, CMmode, SI, shift, which, nconv, eigval, eigvec) | 
| **** eigen solver using ARPACK  More... | |
| subroutine | c_bpack_convert2dense (bmat, option, stats, msh, ker, ptree) | 
| subroutine | c_bpack_eigen_dense (bmat, option, stats, msh, ker, ptree, eigval, eigvec) | 
| subroutine | c_bpack_solution (bmat, x, b, Ns_loc, num_vectors, option, ptree, stats) | 
| subroutine | c_bpack_md_solution (Ndim, bmat, x, b, Ns_loc, num_vectors, option, ptree, stats, msh) | 
| subroutine | c_bpack_ztfqmr_usermatvec_noprecon (ntotal, nn_loc, b, x, err, iter, r0_initial, blackbox_MVP, ptree, option, stats, ker) | 
| subroutine | c_bpack_md_ztfqmr_usermatvec_noprecon (Ndim, ntotal, nn_loc_MD, b, x, err, iter, r0_initial, blackbox_MVP, ptree, option, stats, ker) | 
| subroutine | c_bpack_ztfqmr (precond, ntotal, nn_loc, b, x, err, iter, r0_initial, bmat, ptree, option, stats) | 
| subroutine | c_bpack_md_ztfqmr (Ndim, precond, ntotal, nn_loc_md, b, x, err, iter, r0_initial, bmat, ptree, option, stats, msh) | 
| subroutine | c_bpack_applyprecon (precond, nn_loc, x, y, ptree, bmat, option, stats) | 
| subroutine | c_bpack_test_solve_error (bmat, N_unk_loc, option, ptree, stats) | 
| subroutine | c_bpack_inv_mult (trans, Ns, num_vectors, Vin, Vout, bmat, ptree, option, stats) | 
| subroutine | c_test_bpack_mult (Ns, bmat, ptree, option, stats) | 
| subroutine | c_bpack_mult (trans, Ns, num_vectors, Vin, Vout, bmat, ptree, option, stats) | 
| subroutine | c_bpack_md_mult (Ndim, trans, Ns, num_vectors, Vin, Vout, bmat, ptree, option, stats, msh) | 
| subroutine | c_hodlr_inv_mult (trans, Ns, num_vectors, Vin, Vout, ho_bf1, ptree, option, stats) | 
| subroutine | c_hss_inv_mult (trans, Ns, num_vectors, Vin, Vout, hss_bf1, ptree, option, stats) | 
| subroutine | c_hodlr_mult (trans, Ns, num_vectors, level_start, level_end, Vin, Vout, ho_bf1, ptree, option, stats) | 
| subroutine | c_hmat_redistribute1dto2d_vector (Vin, Ns, num_vectors, vector2D, h_mat, ptree, nproc, stats, mode) | 
| ***** redistribute the vector fed to c_Hmat from 1D to 2D layouts  More... | |
| subroutine | c_hmat_redistribute2dto1d_vector (Vin, Ns, num_vectors, vector2D, h_mat, ptree, nproc, stats, mode) | 
| ***** redistribute the vector fed to c_Hmat from 2D to 1D layouts  More... | |
| subroutine | c_hss_mult (trans, Ns, num_vectors, Vin, Vout, hss_bf1, ptree, option, stats) | 
| subroutine | c_hss_md_mult (Ndim, trans, Ns, num_vectors, Vin, Vout, hss_bf_md1, ptree, option, stats, msh) | 
| subroutine | c_hmat_inv_mult (trans, Ns, num_vectors, Vin, Vout, h_mat, ptree, option, stats) | 
| subroutine | c_hmat_mult (trans, Ns, num_vectors, level_start, level_end, Vin, Vout, h_mat, ptree, option, stats, use_blockcopy) | 
| subroutine | c_hmat_lsolve_toplevel (h_mat, trans, xloc, nloc, nvec, ptree, stats) | 
| subroutine | c_hmat_usolve_toplevel (h_mat, trans, xloc, nloc, nvec, ptree, stats) | 
| subroutine c_bpack_solve_mul::c_bpack_applyprecon | ( | integer | precond, | 
| integer | nn_loc, | ||
| complex(kind=4), dimension(1:nn_loc) | x, | ||
| complex(kind=4), dimension(1:nn_loc) | y, | ||
| type(c_proctree) | ptree, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_convert2dense | ( | type(c_bmatrix) | bmat, | 
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh) | msh, | ||
| type(c_kernelquant) | ker, | ||
| type(c_proctree) | ptree | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_eigen | ( | type(c_bmatrix) | bmat_A, | 
| type(c_hoption) | option_A, | ||
| type(c_proctree) | ptree_A, | ||
| type(c_hstat) | stats_A, | ||
| type(c_bmatrix) | bmat_B, | ||
| type(c_hoption) | option_B, | ||
| type(c_proctree) | ptree_B, | ||
| type(c_hstat) | stats_B, | ||
| type(c_bmatrix) | bmat_sh, | ||
| type(c_hoption) | option_sh, | ||
| type(c_proctree) | ptree_sh, | ||
| type(c_hstat) | stats_sh, | ||
| integer | Nunk, | ||
| integer | Nunk_loc, | ||
| integer | nev, | ||
| real(kind=8) | tol, | ||
| integer | CMmode, | ||
| integer | SI, | ||
| complex(kind=8) | shift, | ||
| character(len=2) | which, | ||
| integer | nconv, | ||
| complex(kind=8), dimension(nev) | eigval, | ||
| complex(kind=8), dimension(nunk_loc, nev) | eigvec | ||
| ) | 
**** eigen solver using ARPACK
| subroutine c_bpack_solve_mul::c_bpack_eigen_dense | ( | type(c_bmatrix) | bmat, | 
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh) | msh, | ||
| type(c_kernelquant) | ker, | ||
| type(c_proctree) | ptree, | ||
| complex(kind=4), dimension(:) | eigval, | ||
| complex(kind=4), dimension(:, :) | eigvec | ||
| ) | 
| subroutine c_bpack_solve_mul::c_bpack_inv_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_md_mult | ( | integer | Ndim, | 
| character | trans, | ||
| integer, dimension(ndim) | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(product(ns), num_vectors) | Vin, | ||
| complex(kind=4), dimension(product(ns), num_vectors) | Vout, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh), dimension(ndim) | msh | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_md_solution | ( | integer | Ndim, | 
| type(c_bmatrix) | bmat, | ||
| complex(kind=4), dimension(product(ns_loc), num_vectors) | x, | ||
| complex(kind=4), dimension(product(ns_loc), num_vectors) | b, | ||
| integer, dimension(ndim) | Ns_loc, | ||
| integer | num_vectors, | ||
| type(c_hoption) | option, | ||
| type(c_proctree) | ptree, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh), dimension(ndim) | msh | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_md_ztfqmr | ( | integer | Ndim, | 
| integer | precond, | ||
| integer, intent(in) | ntotal, | ||
| integer, dimension(ndim) | nn_loc_md, | ||
| complex(kind=4), dimension(1:product(nn_loc_md)) | b, | ||
| complex(kind=4), dimension(1:product(nn_loc_md)) | x, | ||
| real(kind=8) | err, | ||
| integer | iter, | ||
| complex(kind=4), dimension(:) | r0_initial, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh), dimension(ndim) | msh | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_md_ztfqmr_usermatvec_noprecon | ( | integer | Ndim, | 
| integer, intent(in) | ntotal, | ||
| integer, dimension(ndim) | nn_loc_MD, | ||
| complex(kind=4), dimension(1:product(nn_loc_md),1) | b, | ||
| complex(kind=4), dimension(1:product(nn_loc_md),1) | x, | ||
| real(kind=8) | err, | ||
| integer | iter, | ||
| complex(kind=4), dimension(product(nn_loc_md),1) | r0_initial, | ||
| procedure(c_hmatvec_md) | blackbox_MVP, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_kernelquant) | ker | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_solution | ( | type(c_bmatrix) | bmat, | 
| complex(kind=4), dimension(ns_loc, num_vectors) | x, | ||
| complex(kind=4), dimension(ns_loc, num_vectors) | b, | ||
| integer | Ns_loc, | ||
| integer | num_vectors, | ||
| type(c_hoption) | option, | ||
| type(c_proctree) | ptree, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_test_solve_error | ( | type(c_bmatrix) | bmat, | 
| integer | N_unk_loc, | ||
| type(c_hoption) | option, | ||
| type(c_proctree) | ptree, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_ztfqmr | ( | integer | precond, | 
| integer, intent(in) | ntotal, | ||
| integer | nn_loc, | ||
| complex(kind=4), dimension(1:nn_loc) | b, | ||
| complex(kind=4), dimension(1:nn_loc) | x, | ||
| real(kind=8) | err, | ||
| integer | iter, | ||
| complex(kind=4), dimension(:) | r0_initial, | ||
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_bpack_ztfqmr_usermatvec_noprecon | ( | integer, intent(in) | ntotal, | 
| integer | nn_loc, | ||
| complex(kind=4), dimension(1:nn_loc,1) | b, | ||
| complex(kind=4), dimension(1:nn_loc,1) | x, | ||
| real(kind=8) | err, | ||
| integer | iter, | ||
| complex(kind=4), dimension(:,:) | r0_initial, | ||
| procedure(c_hmatvec) | blackbox_MVP, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_kernelquant) | ker | ||
| ) | 

| subroutine c_bpack_solve_mul::c_hmat_inv_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hmat) | h_mat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 

| subroutine c_bpack_solve_mul::c_hmat_lsolve_toplevel | ( | type(c_hmat) | h_mat, | 
| character | trans, | ||
| complex(kind=4), dimension(:, :) | xloc, | ||
| integer | nloc, | ||
| integer | nvec, | ||
| type(c_proctree) | ptree, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hmat_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| integer | level_start, | ||
| integer | level_end, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hmat) | h_mat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| integer | use_blockcopy | ||
| ) | 

| subroutine c_bpack_solve_mul::c_hmat_redistribute1dto2d_vector | ( | complex(kind=4), dimension(ns, num_vectors) | Vin, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| type(c_vectorsblock), dimension(:) | vector2D, | ||
| type(c_hmat) | h_mat, | ||
| type(c_proctree) | ptree, | ||
| integer | nproc, | ||
| type(c_hstat) | stats, | ||
| character | mode | ||
| ) | 
***** redistribute the vector fed to c_Hmat from 1D to 2D layouts
| subroutine c_bpack_solve_mul::c_hmat_redistribute2dto1d_vector | ( | complex(kind=4), dimension(ns, num_vectors) | Vin, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| type(c_vectorsblock), dimension(:) | vector2D, | ||
| type(c_hmat) | h_mat, | ||
| type(c_proctree) | ptree, | ||
| integer | nproc, | ||
| type(c_hstat) | stats, | ||
| character | mode | ||
| ) | 
***** redistribute the vector fed to c_Hmat from 2D to 1D layouts
| subroutine c_bpack_solve_mul::c_hmat_usolve_toplevel | ( | type(c_hmat) | h_mat, | 
| character | trans, | ||
| complex(kind=4), dimension(:, :) | xloc, | ||
| integer | nloc, | ||
| integer | nvec, | ||
| type(c_proctree) | ptree, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hodlr_inv_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hobf) | ho_bf1, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hodlr_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| integer | level_start, | ||
| integer | level_end, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hobf) | ho_bf1, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hss_inv_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hssbf) | hss_bf1, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hss_md_mult | ( | integer | Ndim, | 
| character | trans, | ||
| integer, dimension(ndim) | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(product(ns), num_vectors) | Vin, | ||
| complex(kind=4), dimension(product(ns), num_vectors) | Vout, | ||
| type(c_hssbf_md) | hss_bf_md1, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats, | ||
| type(c_mesh), dimension(ndim) | msh | ||
| ) | 
| subroutine c_bpack_solve_mul::c_hss_mult | ( | character | trans, | 
| integer | Ns, | ||
| integer | num_vectors, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vin, | ||
| complex(kind=4), dimension(ns, num_vectors) | Vout, | ||
| type(c_hssbf) | hss_bf1, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 
| subroutine c_bpack_solve_mul::c_test_bpack_mult | ( | integer | Ns, | 
| type(c_bmatrix) | bmat, | ||
| type(c_proctree) | ptree, | ||
| type(c_hoption) | option, | ||
| type(c_hstat) | stats | ||
| ) | 
