hypre/struct_ls/general.c
2008-07-18 01:34:48 +00:00

46 lines
1.2 KiB
C

/*BHEADER**********************************************************************
* Copyright (c) 2008, Lawrence Livermore National Security, LLC.
* Produced at the Lawrence Livermore National Laboratory.
* This file is part of HYPRE. See file COPYRIGHT for details.
*
* 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*/
/******************************************************************************
*
*
*****************************************************************************/
#include "headers.h"
/*--------------------------------------------------------------------------
* hypre_Log2:
* This routine returns the integer, floor(log_2(p)).
* If p <= 0, it returns a -1.
*--------------------------------------------------------------------------*/
int
hypre_Log2(int p)
{
int e;
if (p <= 0)
return -1;
e = 0;
while (p > 1)
{
e += 1;
p /= 2;
}
return e;
}