124 lines
3.0 KiB
C

#include "clapack.h"
/* Subroutine */ int slasdt_(integer *n, integer *lvl, integer *nd, integer *
inode, integer *ndiml, integer *ndimr, integer *msub)
{
/* System generated locals */
integer i__1, i__2;
/* Builtin functions */
double log(doublereal);
/* Local variables */
integer i__, il, ir, maxn;
real temp;
integer nlvl, llst, ncrnt;
/* -- LAPACK auxiliary routine (version 3.1) -- */
/* Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd.. */
/* November 2006 */
/* .. Scalar Arguments .. */
/* .. */
/* .. Array Arguments .. */
/* .. */
/* Purpose */
/* ======= */
/* SLASDT creates a tree of subproblems for bidiagonal divide and */
/* conquer. */
/* Arguments */
/* ========= */
/* N (input) INTEGER */
/* On entry, the number of diagonal elements of the */
/* bidiagonal matrix. */
/* LVL (output) INTEGER */
/* On exit, the number of levels on the computation tree. */
/* ND (output) INTEGER */
/* On exit, the number of nodes on the tree. */
/* INODE (output) INTEGER array, dimension ( N ) */
/* On exit, centers of subproblems. */
/* NDIML (output) INTEGER array, dimension ( N ) */
/* On exit, row dimensions of left children. */
/* NDIMR (output) INTEGER array, dimension ( N ) */
/* On exit, row dimensions of right children. */
/* MSUB (input) INTEGER. */
/* On entry, the maximum row dimension each subproblem at the */
/* bottom of the tree can be of. */
/* Further Details */
/* =============== */
/* Based on contributions by */
/* Ming Gu and Huan Ren, Computer Science Division, University of */
/* California at Berkeley, USA */
/* ===================================================================== */
/* .. Parameters .. */
/* .. */
/* .. Local Scalars .. */
/* .. */
/* .. Intrinsic Functions .. */
/* .. */
/* .. Executable Statements .. */
/* Find the number of levels on the tree. */
/* Parameter adjustments */
--ndimr;
--ndiml;
--inode;
/* Function Body */
maxn = max(1,*n);
temp = log((real) maxn / (real) (*msub + 1)) / log(2.f);
*lvl = (integer) temp + 1;
i__ = *n / 2;
inode[1] = i__ + 1;
ndiml[1] = i__;
ndimr[1] = *n - i__ - 1;
il = 0;
ir = 1;
llst = 1;
i__1 = *lvl - 1;
for (nlvl = 1; nlvl <= i__1; ++nlvl) {
/* Constructing the tree at (NLVL+1)-st level. The number of */
/* nodes created on this level is LLST * 2. */
i__2 = llst - 1;
for (i__ = 0; i__ <= i__2; ++i__) {
il += 2;
ir += 2;
ncrnt = llst + i__;
ndiml[il] = ndiml[ncrnt] / 2;
ndimr[il] = ndiml[ncrnt] - ndiml[il] - 1;
inode[il] = inode[ncrnt] - ndimr[il] - 1;
ndiml[ir] = ndimr[ncrnt] / 2;
ndimr[ir] = ndimr[ncrnt] - ndiml[ir] - 1;
inode[ir] = inode[ncrnt] + ndiml[ir] + 1;
/* L10: */
}
llst <<= 1;
/* L20: */
}
*nd = (llst << 1) - 1;
return 0;
/* End of SLASDT */
} /* slasdt_ */