29{
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86 Int ilocblk, mydist, nblocks;
87
88
89
90
91 if( ( SRCPROC == -1 ) || ( NPROCS == 1 ) )
92
93
94
95
96 return( 0 );
97
98
99
100 if( ( INB -= I ) <= 0 )
101 {
102
103
104
105
106 nblocks = ( -INB ) / NB + 1;
107 SRCPROC += nblocks;
108 SRCPROC -= ( SRCPROC / NPROCS ) * NPROCS;
109 INB += nblocks * NB;
110 }
111
112
113
114
115 if( PROC == SRCPROC ) return( 0 );
116
117
118
119
120 if( N <= INB ) return( N );
121
122
123
124
125 nblocks = ( N - INB ) / NB + 1;
126
127
128
129
130 if( ( mydist = PROC - SRCPROC ) < 0 ) mydist += NPROCS;
131
132
133
134
135
136
137
138
139
140
141
142
143
144 if( nblocks < NPROCS )
145 return( ( ( mydist <= nblocks ) ? INB + NB * ( mydist - 1 ) : N ) );
146
147 ilocblk = nblocks / NPROCS;
148 return( ( ( mydist <= ( nblocks - ilocblk * NPROCS ) ) ?
149 INB - NB + ( ilocblk + 1 ) * NB * mydist :
150 N + NB * ilocblk * ( mydist - NPROCS ) ) );
151
152
153
154}