hypre/struct_ls/general.c

38 lines
1.0 KiB
C
Raw Normal View History

/*BHEADER**********************************************************************
2008-07-18 09:34:48 +08:00
* Copyright (c) 2008, Lawrence Livermore National Security, LLC.
* 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.
*
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.
*
* $Revision$
***********************************************************************EHEADER*/
2012-03-07 03:15:29 +08:00
#include "_hypre_struct_ls.h"
/*--------------------------------------------------------------------------
1998-02-18 01:56:00 +08:00
* hypre_Log2:
* This routine returns the integer, floor(log_2(p)).
* If p <= 0, it returns a -1.
*--------------------------------------------------------------------------*/
HYPRE_Int
hypre_Log2(HYPRE_Int p)
{
HYPRE_Int e;
if (p <= 0)
return -1;
e = 0;
while (p > 1)
{
e += 1;
p /= 2;
}
return e;
}