libStatGen Software
1
|
00001 /* 00002 * Copyright (C) 2010 Regents of the University of Michigan 00003 * 00004 * This program is free software: you can redistribute it and/or modify 00005 * it under the terms of the GNU General Public License as published by 00006 * the Free Software Foundation, either version 3 of the License, or 00007 * (at your option) any later version. 00008 * 00009 * This program is distributed in the hope that it will be useful, 00010 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 * GNU General Public License for more details. 00013 * 00014 * You should have received a copy of the GNU General Public License 00015 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00016 */ 00017 00018 #include "BaseQualityHelper.h" 00019 00020 #include <math.h> 00021 00022 baseQualityConvertor bQualityConvertor; 00023 00024 baseQualityConvertor::baseQualityConvertor() 00025 { 00026 // Create a quick lookup table to speed up conversion of 00027 // base quality values stored as log10 (error rates) into 00028 // fractional error rates 00029 for (int i = 0; i <= 255; i++) 00030 doubleLookup[i] = pow(0.1, i * 0.1); 00031 // doubleLookup[255] = 0.0; 00032 } 00033 00034 double baseQualityConvertor::toDouble(unsigned char bq) 00035 { 00036 return doubleLookup[bq]; 00037 } 00038