| Type | Visibility | Attributes | Name | Initial | |||
|---|---|---|---|---|---|---|---|
| integer, | public, | parameter | :: | GLOBAL_RUN | = | -45 |
Check whether an ilut belongs to the core space for performance reasons (decoding is expensive and we likely already know nI at this point)
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(in) | :: | ilut(0:NIfTot) | |||
| integer, | intent(in) | :: | nI(:) | |||
| integer, | intent(in), | optional | :: | run_ |
Check where an ilut is in the core space for performance reasons (decoding is expensive and we likely already know nI at this point)
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(in) | :: | ilut(0:NIfTot) | |||
| integer, | intent(in) | :: | nI(:) | |||
| integer, | intent(in), | optional | :: | run_ |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(in) | :: | ilut(0:NIfTot) | |||
| integer, | intent(in), | optional | :: | run_ |
Weight function for picking the most populated states. Trivial in single run mode, but multiple options exist in mneci
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp), | intent(in) | :: | sign_curr(lenof_sign) | |||
| integer, | intent(in) | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp), | intent(inout), | allocatable | :: | partial_vecs(:,:) | ||
| real(kind=dp), | intent(inout), | allocatable | :: | full_vecs(:,:) | ||
| type(core_space_t), | intent(inout) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in), | optional | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in), | optional | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp) | :: | old_Hii | ||||
| real(kind=dp) | :: | new_Hii |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(inout) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(inout) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(inout) | :: | ilut_list(0:NIfTot,1:num_states) | |||
| integer, | intent(inout) | :: | num_states | |||
| integer, | intent(in) | :: | target_num_states | |||
| logical, | intent(in) | :: | tParallel |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(inout) | :: | ilut_list(0:NIfTot,1:num_states) | |||
| integer, | intent(in) | :: | num_states | |||
| logical, | intent(in) | :: | tSortDoubles |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer(kind=n_int), | intent(inout) | :: | ilut_list(0:,:) | |||
| integer, | intent(in) | :: | ilut_list_size | |||
| integer(kind=MPIArg), | intent(out) | :: | num_states_procs(0:nProcessors-1) |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | n_keep | |||
| integer, | intent(in) | :: | run | |||
| integer(kind=n_int), | intent(out) | :: | largest_walkers(0:NIfTot,n_keep) | |||
| integer(kind=n_int), | intent(in), | optional | :: | opt_source(0:,1:) | ||
| integer(kind=int64), | intent(in), | optional | :: | opt_source_size | ||
| real(kind=dp), | intent(out), | optional | :: | norm |
@brief Return the most populated states over all processors.
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | n_keep | |||
| integer, | intent(in) | :: | run | |||
| integer(kind=n_int), | intent(out) | :: | largest_walkers(0:NIfTot,n_keep) | |||
| real(kind=dp), | intent(out), | optional | :: | norm | ||
| integer, | intent(out), | optional | :: | rank_of_largest(n_keep) | ||
| real(kind=dp), | intent(inout), | optional | :: | hdiag_largest(n_keep) |
Specialized routine that returns the number of determinants that are going into the core-space on this processor. Once the leading determinants have been obtained on each processor, this function requires the minimal and maximal populations among these for all processors (requires previous MPI_Gather), then the procedure to determine the core-space size on this processor is as follows: 1) Get the minimum of the maximal populations, then count the number of determinants above this population. This count is then broadcasted to the other procs, and the total number of determinants above the smallest maximum is determined. If it is smaller than the core-space size, these determinants are put into the core-space, else we repeat with the second smallest of the maximal populations, and so on. 2) Get the maximum of the minimal populations, then count the number of determinants below this population. This count is then broadcasted to the other procs, and the total number of determinants below the largest minimum is determined. If the number of determinants that are remaining (i.e. larger than the largest minimum and smaller than the smallest maximum) is sufficient to fill up the core-space (in particular, the smallest maximum has to be bigger than the largest minimum), the small determinants are discarded. Else, we repeat this with the second largest minimum, and so on. 3) From the remaining determinants, each processor contributes a share that equals to the ratio of the remaining determinants on this proc to the total remaining determinants
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | n_keep |
core-space size |
||
| real(kind=dp), | intent(inout) | :: | min_vals(0:nProcessors-1) | |||
| real(kind=dp), | intent(inout) | :: | max_vals(0:nProcessors-1) | |||
| integer, | intent(in) | :: | lengths(0:nProcessors-1) |
core-space size |
||
| real(kind=dp), | intent(in) | :: | list(:) | |||
| integer, | intent(out) | :: | n_dets_this_proc |
number of core-space determinants on this processor |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | n_keep | |||
| integer, | intent(in) | :: | list_size | |||
| real(kind=dp), | intent(in) | :: | list(list_size) | |||
| integer, | intent(out) | :: | largest_indices(n_keep) |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| logical, | intent(in) | :: | tPrintInfo | |||
| integer, | intent(in) | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| logical, | intent(in) | :: | tPrintInfo | |||
| integer, | intent(in) | :: | run |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp), | intent(out) | :: | e_value | |||
| real(kind=dp), | intent(out), | allocatable | :: | e_vector(:) | ||
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp), | intent(out), | allocatable | :: | e_values(:) | ||
| real(kind=dp), | allocatable | :: | e_vectors(:,:) | |||
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| real(kind=dp), | intent(out), | allocatable | :: | hamil(:,:) | ||
| type(core_space_t) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| type(core_space_t), | intent(in) | :: | rep |
| Type | Intent | Optional | Attributes | Name | ||
|---|---|---|---|---|---|---|
| integer, | intent(in) | :: | nI(nel) | |||
| integer(kind=n_int), | intent(in) | :: | ilut(0:NIfTot) | |||
| integer, | intent(in) | :: | ex(2,maxExcit) | |||
| logical, | intent(in) | :: | tParity | |||
| real(kind=dp), | intent(out) | :: | amp | |||
| real(kind=dp), | intent(out) | :: | energy_contrib |