clearer names

This commit is contained in:
Martin Diehl 2019-03-12 09:28:06 +01:00
parent 2505c02c75
commit 1df8b22e23
1 changed files with 24 additions and 21 deletions

View File

@ -2272,38 +2272,41 @@ end function coordinateSystem_slip
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
!> @brief Populates reduced interaction matrix !> @brief Populates reduced interaction matrix
!-------------------------------------------------------------------------------------------------- !--------------------------------------------------------------------------------------------------
function buildInteraction(activeA,activeB,maxA,maxB,values,matrix) function buildInteraction(acting_used,reacting_used,acting_max,reacting_max,values,matrix)
use IO, only: & use IO, only: &
IO_error IO_error
implicit none implicit none
integer, dimension(:), intent(in) :: & integer, dimension(:), intent(in) :: &
activeA, & !< number of active systems as specified in material.config acting_used, & !< # of acting systems per family as specified in material.config
activeB, & !< number of active systems as specified in material.config reacting_used, & !< # of reacting systems per family as specified in material.config
maxA, & !< number of maximum available systems acting_max, &
maxB !< number of maximum available systems reacting_max
real(pReal), dimension(:), intent(in) :: values !< interaction values real(pReal), dimension(:), intent(in) :: values !< interaction values
integer, dimension(:,:), intent(in) :: matrix !< complete interaction matrix integer, dimension(:,:), intent(in) :: matrix !< interaction matrix
real(pReal), dimension(sum(activeA),sum(activeB)) :: buildInteraction real(pReal), dimension(sum(acting_used),sum(reacting_used)) :: buildInteraction
integer :: & integer :: &
index_myFamily, index_otherFamily, & acting_family_index, reacting_family_index, &
mf, ms, of, os acting_family, acting_system, reacting_family, reacting_system
myFamilies: do mf = 1,size(activeA,1) do acting_family = 1,size(acting_used,1)
index_myFamily = sum(activeA(1:mf-1)) acting_family_index = sum(acting_used(1:acting_family-1))
mySystems: do ms = 1,activeA(mf) do acting_system = 1,acting_used(acting_family)
otherFamilies: do of = 1,size(activeB,1) do reacting_family = 1,size(reacting_used,1)
index_otherFamily = sum(activeB(1:of-1)) reacting_family_index = sum(reacting_used(1:reacting_family-1))
otherSystems: do os = 1,activeB(of) do reacting_system = 1,reacting_used(reacting_family)
if(matrix(sum(maxA(1:mf-1))+ms, sum(maxB(1:of-1))+os) > size(values)) &
if(matrix(sum(acting_max(1:acting_family-1))+acting_system, &
sum(reacting_max(1:reacting_family-1))+reacting_system) > size(values)) &
call IO_error(138,ext_msg='buildInteraction') call IO_error(138,ext_msg='buildInteraction')
buildInteraction(index_myFamily+ms,index_otherFamily+os) = & buildInteraction(acting_family_index+acting_system,reacting_family_index+reacting_system) = &
values(matrix(sum(maxA(1:mf-1))+ms, sum(maxB(1:of-1))+os)) values(matrix(sum(acting_max(1:acting_family-1))+acting_system, &
enddo otherSystems; enddo otherFamilies; sum(reacting_max(1:reacting_family-1))+reacting_system))
enddo; enddo
enddo mySystems;enddo myFamilies enddo; enddo
end function buildInteraction end function buildInteraction