kis_bcontrast_benchmark.cpp 2.68 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
/*
 *  Copyright (c) 2010 Lukáš Tvrdý lukast.dev@gmail.com
 *
 *  This program 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.
 *
 *  This program 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 this program; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 */

#include <qtest_kde.h>

#include "kis_bcontrast_benchmark.h"
#include "kis_benchmark_values.h"

#include "kis_paint_device.h"

#include <KoColorSpace.h>
#include <KoColorSpaceRegistry.h>
#include <KoColor.h>

#include <kis_image.h>

#include "filter/kis_filter_registry.h"
#include "filter/kis_filter_configuration.h"
#include "filter/kis_filter.h"

#include "kis_processing_information.h"

#include "kis_selection.h"
39
#include <kis_iterator_ng.h>
40 41 42 43 44

void KisBContrastBenchmark::initTestCase()
{
    m_colorSpace = KoColorSpaceRegistry::instance()->rgb8();    
    m_device = new KisPaintDevice(m_colorSpace);
45
    m_color = KoColor(m_colorSpace);
46 47 48 49 50
    
    srand(31524744);
    
    int r,g,b;
    
51
    KisRectIteratorSP it = m_device->createRectIteratorNG(QRect(0, 0, GMP_IMAGE_WIDTH, GMP_IMAGE_HEIGHT));
52
    do {
53 54 55 56
        r = rand() % 255;
        g = rand() % 255;
        b = rand() % 255;
        
57
        m_color.fromQColor(QColor(r,g,b));
58 59
        memcpy(it->rawData(), m_color.data(), m_colorSpace->pixelSize());
    } while (it->nextPixel());
60 61 62 63 64 65 66 67
    
}

void KisBContrastBenchmark::cleanupTestCase()
{
}


68
void KisBContrastBenchmark::benchmarkFilter()
69 70 71 72
{
    KisFilterSP filter = KisFilterRegistry::instance()->value("brightnesscontrast");
    KisFilterConfiguration * kfc = filter->defaultConfiguration(m_device);

73
    // Get the predefined configuration from a file
74 75 76 77 78 79 80 81 82 83 84
    QFile file(QString(FILES_DATA_DIR) + QDir::separator() + filter->id() + ".cfg");
    if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
        file.open(QIODevice::WriteOnly | QIODevice::Text);
        QTextStream out(&file);
        out << kfc->toXML();
    } else {
        QString s;
        QTextStream in(&file);
        s = in.readAll();
        kfc->fromXML(s);
    }
85

86
    QBENCHMARK{
87
        filter->process(m_device, QRect(0, 0, GMP_IMAGE_WIDTH,GMP_IMAGE_HEIGHT), kfc);
88 89 90 91 92 93 94
    }
}



QTEST_KDEMAIN(KisBContrastBenchmark, GUI)
#include "kis_bcontrast_benchmark.moc"