Ignore:
Timestamp:
Apr 2, 2023, 9:08:46 PM (21 months ago)
Author:
emillour
Message:

Mars PCM:
Adapt topmons_setup to handle both cartesian and icosahedral grids
EM

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.MARS/libf/phymars/topmons_mod.F90

    r2826 r2930  
    989989      use comcstfi_h,only: pi,g
    990990      use planetwide_mod,only: planetwide_maxval, planetwide_minval
     991      use mod_grid_phy_lmdz, only: nvertex !number of encompassing vertex
    991992      use geometry_mod,only: longitude_deg,latitude_deg,&
    992                              boundslon,boundslat !boundslon/lat(ngrid,4) :
     993                             boundslon,boundslat ! if nvertex==4 then we have
     994                                                 ! boundslon/lat(ngrid,4) :
    993995                                                 !  |------------------------------|
    994996                                                 !  |north_west=2      north_east=1|
     
    9981000                                                 !  |south_west=3      south_east=4|
    9991001                                                 !  |------------------------------|
     1002                                                 ! if nvertex==6 (isocahedral grid)
     1003                                                 ! there is no dedicated ordering
    10001004                             
    10011005      implicit none
     
    10221026                   -44.8,-32.1,-21.1,26.8/
    10231027      integer,parameter :: ntop = 19 ! the topmons scheme is limited to the first ntop mounts
    1024       real :: boundslon_deg(4),boundslat_deg(4)
     1028      real :: boundslon_deg(nvertex),boundslat_deg(nvertex)
    10251029      real :: hmax,hmin
     1030      real :: minlon,maxlon ! min/max encompassing vertex longitude (deg)
     1031      real :: minlat,maxlat ! min/max encompassing vertex latitude (deg)
    10261032      integer :: ig,itop
    10271033     
     
    10401046          boundslon_deg(:)=boundslon(ig,:)/pi*180.
    10411047          boundslat_deg(:)=boundslat(ig,:)/pi*180.
     1048         
     1049          minlon=minval(boundslon_deg)
     1050          maxlon=maxval(boundslon_deg)
     1051          minlat=minval(boundslat_deg)
     1052          maxlat=maxval(boundslat_deg)
    10421053
    10431054          do itop=1,ntop
    1044             if ( (lon_top(itop).gt.boundslon_deg(2)).and.(lon_top(itop).lt.boundslon_deg(1)) &
    1045             .and.(lat_top(itop).gt.boundslat_deg(3)).and.(lat_top(itop).lt.boundslat_deg(2)) ) then
     1055            if ((lon_top(itop).ge.minlon).and.(lon_top(itop).le.maxlon).and. &
     1056                (lat_top(itop).ge.minlat).and.(lat_top(itop).le.maxlat)) then
    10461057              contains_mons(ig)=.true.
    1047               write(*,*) "topmons_setup: Found a mount at:"
    1048               write(*,*) "(",boundslon_deg(2),",",boundslat_deg(2),")  (",boundslon_deg(1),",",boundslat_deg(1),")"
    1049               write(*,*) "             ((",lon_top(itop),",",lat_top(itop),"))"
    1050               write(*,*) "(",boundslon_deg(3),",",boundslat_deg(3),")  (",boundslon_deg(4),",",boundslat_deg(4),")"
     1058              write(*,*) "topmons_setup: Found a mount for ig:",ig
     1059              write(*,*) " at : lon=",longitude_deg(ig)," lat=",latitude_deg(ig)
     1060              if (nvertex==4) then
     1061               write(*,*) "(",boundslon_deg(2),",",boundslat_deg(2),")  (",boundslon_deg(1),",",boundslat_deg(1),")"
     1062               write(*,*) "             ((",lon_top(itop),",",lat_top(itop),"))"
     1063               write(*,*) "(",boundslon_deg(3),",",boundslat_deg(3),")  (",boundslon_deg(4),",",boundslat_deg(4),")"
     1064              endif
    10511065            endif
    1052           enddo
    1053         enddo
     1066          enddo ! of do itop=1,ntop
     1067        enddo ! of do ig=1,ngrid
    10541068
    10551069        ! Compute alpha_hmons
    10561070        call planetwide_maxval(hmons,hmax)
    10571071        call planetwide_minval(hmons,hmin)
     1072
     1073        ! Add a sanity check in case there is no topography:
     1074        if (hmin==hmax) then
     1075          write(*,*) "topmons_setup: hmin=",hmin," hmax=",hmax
     1076          write(*,*) "topmons_setup: thus no topflows !!!"
     1077          contains_mons(:)=.false.
     1078        endif
     1079
    10581080        do ig=1,ngrid
    10591081          if (contains_mons(ig)) then
     
    10701092            alpha_hmons(ig)= 0
    10711093          endif
    1072         enddo
     1094        enddo ! of do ig=1,ngrid
    10731095
    10741096        ! Compute hsummit
Note: See TracChangeset for help on using the changeset viewer.