/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /*************************************************************************** * mipmap.cc * * Fri Sep 3 16:39:46 CEST 2010 * Copyright 2010 Bent Bisballe Nyeng * deva@aasimon.org ****************************************************************************/ /* * This file is part of DrumGizmo. * * DrumGizmo is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * DrumGizmo is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with DrumGizmo; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ #include "mipmap.h" MipMap::MipMap(float *data, size_t size) { this->data = data; this->size = size; this->zoom = 1; } MipMapValue MipMap::data_lookup(size_t begin, size_t end) { MipMapValue val; size_t numlavg = 0; size_t numuavg = 0; for(size_t i = begin; i <= end; i++) { if(i > size || i < 0) break; if(data[i] > val.max) val.max = data[i]; if(data[i] < val.min) val.min = data[i]; if(data[i] > 0) { val.uavg += data[i]; numuavg++; } if(data[i] < 0) { val.lavg += data[i]; numlavg++; } } if(numlavg) val.lavg /= (float) numlavg; if(numuavg) val.uavg /= (float) numuavg; return val; } MipMapValue MipMap::mipmap_lookup(size_t begin, size_t end) { MipMapValue val; size_t numlavg = 0; size_t numuavg = 0; for(size_t i = begin; i <= end; i++) { if(i > size || i < 0) break; if(data[i] > val.max) val.max = data[i]; if(data[i] < val.min) val.min = data[i]; if(data[i] > 0) { val.uavg += data[i]; numuavg++; } if(data[i] < 0) { val.lavg += data[i]; numlavg++; } } if(numlavg) val.lavg /= (float) numlavg; if(numuavg) val.uavg /= (float) numuavg; return val; } #define ABS(x) (x>0?x:-x) MipMapValue MipMap::lookup(size_t begin, size_t end) { return data_lookup(begin, end); /* size_t zoom_factor = ABS(end - begin); if(zoom_factor < zoom / 2) { if(zoom == 1) { // Lookup in original data. return data_lookup(begin, end); } return mipmap_lookup(begin, end); } if(lowerlevel) return lowerlevel->lookup(begin,end); return MipMapValue(); */ }