2779
2780
2781
2782
2783
2784
2785
2786 INTEGER I, INB, N, NB, NPROCS, PROC, SRCPROC
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838 INTEGER I1, ILOCBLK, INB1, MYDIST, N1, NBLOCKS,
2839 $ SRCPROC1
2840
2841
2842
2843 IF( ( srcproc.EQ.-1 ).OR.( nprocs.EQ.1 ) ) THEN
2845 RETURN
2846 END IF
2847
2848
2849
2850 IF( i.LE.inb ) THEN
2851
2852
2853
2854 srcproc1 = srcproc
2855 inb1 = inb - i + 1
2856
2857 ELSE
2858
2859
2860
2861 i1 = i - 1 - inb
2862 nblocks = i1 / nb + 1
2863 srcproc1 = srcproc + nblocks
2864 srcproc1 = srcproc1 - ( srcproc1 / nprocs ) * nprocs
2865 inb1 = nblocks*nb - i1
2866
2867 END IF
2868
2869
2870
2871
2872 IF( n.LE.inb1 ) THEN
2873 IF( proc.EQ.srcproc1 ) THEN
2875 ELSE
2877 END IF
2878 RETURN
2879 END IF
2880
2881 n1 = n - inb1
2882 nblocks = n1 / nb + 1
2883
2884 IF( proc.EQ.srcproc1 ) THEN
2885 ilocblk = nblocks / nprocs
2886 IF( ilocblk.GT.0 ) THEN
2887 IF( ( nblocks - ilocblk * nprocs ).GT.0 ) THEN
2889 ELSE
2890 pb_numroc = n + nb * ( ilocblk - nblocks )
2891 END IF
2892 ELSE
2894 END IF
2895 ELSE
2896 mydist = proc - srcproc1
2897 IF( mydist.LT.0 )
2898 $ mydist = mydist + nprocs
2899 ilocblk = nblocks / nprocs
2900 IF( ilocblk.GT.0 ) THEN
2901 mydist = mydist - nblocks + ilocblk * nprocs
2902 IF( mydist.LT.0 ) THEN
2904 ELSE IF( mydist.GT.0 ) THEN
2906 ELSE
2907 pb_numroc = n1 + nb * ( ilocblk - nblocks + 1 )
2908 END IF
2909 ELSE
2910 mydist = mydist - nblocks
2911 IF( mydist.LT.0 ) THEN
2913 ELSE IF( mydist.GT.0 ) THEN
2915 ELSE
2917 END IF
2918 END IF
2919 END IF
2920
2921 RETURN
2922
2923
2924
integer function pb_numroc(n, i, inb, nb, proc, srcproc, nprocs)