1997-12-11 04:38:24 +08:00
|
|
|
/*BHEADER**********************************************************************
|
2008-07-18 09:34:48 +08:00
|
|
|
* Copyright (c) 2008, Lawrence Livermore National Security, LLC.
|
2006-07-28 07:26:57 +08:00
|
|
|
* Produced at the Lawrence Livermore National Laboratory.
|
2008-07-18 09:34:48 +08:00
|
|
|
* This file is part of HYPRE. See file COPYRIGHT for details.
|
1997-12-11 04:38:24 +08:00
|
|
|
*
|
2008-07-18 09:34:48 +08:00
|
|
|
* HYPRE is free software; you can redistribute it and/or modify it under the
|
|
|
|
|
* terms of the GNU Lesser General Public License (as published by the Free
|
|
|
|
|
* Software Foundation) version 2.1 dated February 1999.
|
1997-12-11 04:38:24 +08:00
|
|
|
*
|
|
|
|
|
* $Revision$
|
2006-07-28 07:26:57 +08:00
|
|
|
***********************************************************************EHEADER*/
|
|
|
|
|
|
2012-03-07 03:15:29 +08:00
|
|
|
#include "_hypre_struct_ls.h"
|
1997-12-11 04:38:24 +08:00
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------------
|
1998-02-18 01:56:00 +08:00
|
|
|
* hypre_Log2:
|
1997-12-11 04:38:24 +08:00
|
|
|
* This routine returns the integer, floor(log_2(p)).
|
|
|
|
|
* If p <= 0, it returns a -1.
|
|
|
|
|
*--------------------------------------------------------------------------*/
|
|
|
|
|
|
2010-12-21 03:27:44 +08:00
|
|
|
HYPRE_Int
|
|
|
|
|
hypre_Log2(HYPRE_Int p)
|
1997-12-11 04:38:24 +08:00
|
|
|
{
|
2010-12-21 03:27:44 +08:00
|
|
|
HYPRE_Int e;
|
1997-12-11 04:38:24 +08:00
|
|
|
|
|
|
|
|
if (p <= 0)
|
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
|
|
e = 0;
|
|
|
|
|
while (p > 1)
|
|
|
|
|
{
|
|
|
|
|
e += 1;
|
|
|
|
|
p /= 2;
|
|
|
|
|
}
|
|
|
|
|
|
2012-05-04 01:17:14 +08:00
|
|
|
return e;
|
1997-12-11 04:38:24 +08:00
|
|
|
}
|