00001 // This file is a part of Aurelia. 00002 // Copyright (C) 2010 Valentin David 00003 // Copyright (C) 2010 University of Bergen 00004 // 00005 // This program is free software: you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License as published by 00007 // the Free Software Foundation, either version 3 of the License, or 00008 // (at your option) any later version. 00009 // 00010 // This program is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 // GNU General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU General Public License 00016 // along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 #ifndef __RESET_MSB_HH 00018 # define __RESET_MSB_HH 00019 00020 # include "bin_log.hh" 00021 00022 namespace fast { 00023 00024 template <typename integral_type> 00025 integral_type reset_msb(integral_type v) { 00026 static_assert(std::is_integral<integral_type>::value, 00027 "Cannot use non integral types."); 00028 return v^(1 << bin_log(v)); 00029 } 00030 00031 } 00032 00033 #endif