1
/* ---------------------------------------------------------------------
3
* -- Automatically Tuned Linear Algebra Software (ATLAS)
4
* (C) Copyright 2000 All Rights Reserved
6
* -- ATLAS routine -- Version 3.2 -- December 25, 2000
8
* -- Suggestions, comments, bugs reports should be sent to the follo-
9
* wing e-mail address: atlas@cs.utk.edu
11
* Author : Antoine P. Petitet
12
* University of Tennessee - Innovative Computing Laboratory
13
* Knoxville TN, 37996-1301, USA.
15
* ---------------------------------------------------------------------
17
* -- Copyright notice and Licensing terms:
19
* Redistribution and use in source and binary forms, with or without
20
* modification, are permitted provided that the following conditions
23
* 1. Redistributions of source code must retain the above copyright
24
* notice, this list of conditions and the following disclaimer.
25
* 2. Redistributions in binary form must reproduce the above copyright
26
* notice, this list of conditions, and the following disclaimer in
27
* the documentation and/or other materials provided with the distri-
29
* 3. The name of the University, the ATLAS group, or the names of its
30
* contributors may not be used to endorse or promote products deri-
31
* ved from this software without specific written permission.
35
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
36
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
37
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
38
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY
39
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPE-
40
* CIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
41
* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
42
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEO-
43
* RY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (IN-
44
* CLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
45
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
47
* ---------------------------------------------------------------------
52
#include "atlas_ptmisc.h"
54
DIM_1DSPLIT_T ATL_1dsplit
56
const unsigned int NT,
70
* ATL_1dsplit splits a problem dimension N within NT threads. This
71
* function returns whether or not the problem size N should be split.
76
* NT (input) const unsigned int
77
* On entry, NT specifies the initial total number of threads.
80
* On entry, N specifies the problem dimension to be split.
82
* NB (input) const int
83
* On entry, NB specifies the blocking factor to be used along
86
* NT1 (output) unsigned int *
87
* On exit, NT1 specifies the number of threads to be used for
88
* the first part of the problem size N1.
90
* NT2 (output) unsigned int *
91
* On exit, NT2 specifies the number of threads to be used for
92
* the second part of the problem size N2.
95
* On exit, N1 specifies the length of the problem size to be
96
* run on the NT1 threads.
99
* On exit, N2 specifies the length of the problem size to be
100
* run on the NT2 threads.
102
* RATIO (output) double *
103
* On exit, RATIO specifies the relative work distribution ratio
104
* namely | ( N1 / NT1 ) - ( N2 / NT2 ) | / ( N / NT ).
106
* ---------------------------------------------------------------------
109
* .. Local Variables ..
112
DIM_1DSPLIT_T split = Atlas1dNoSplit;
113
unsigned int nt1, nt2, ntm1;
114
int n1, n2, nblks, nbm1;
116
* .. Executable Statements ..
119
nblks = ( N + ( nbm1 = NB - 1 ) ) / NB;
120
if( ( nblks < 2 ) || ( NT < 2 ) ) return( split );
122
n1 = ( ( ( ( N + ( ntm1 = NT - 1 ) ) / NT ) + nbm1 ) / NB ) * NB;
130
nt1 = (int)floor( ( (double)(n1) / n ) * nt + 0.5 );
131
nt2 = NT - ( nt1 = Mmin( nt1, ntm1 ) );
137
*RATIO = ( (double)(n1) / (double)(nt1) ) - ( (double)(n2) / (double)(nt2) );
138
*RATIO = Mabs( *RATIO ) / ( n / nt );
140
return( Atlas1dSplit );