kis_vline_iterator_benchmark.cpp 4.96 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
/*
 *  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 "kis_vline_iterator_benchmark.h"
#include "kis_benchmark_values.h"

#include "kis_paint_device.h"

#include <KoColorSpace.h>
#include <KoColorSpaceRegistry.h>
#include <KoColor.h>
27
#include <kis_iterator_ng.h>
28
#include <QTest>
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50


void KisVLineIteratorBenchmark::initTestCase()
{
    m_colorSpace = KoColorSpaceRegistry::instance()->rgb8();
    m_device = new KisPaintDevice(m_colorSpace);
    m_color = new KoColor(m_colorSpace);
    // some random color
    m_color->fromQColor(QColor(0,120,250));
    m_device->fill(0,0,TEST_IMAGE_WIDTH,TEST_IMAGE_HEIGHT,m_color->data());
}

void KisVLineIteratorBenchmark::cleanupTestCase()
{
    delete m_color;
    delete m_device;
}


void KisVLineIteratorBenchmark::benchmarkCreation()
{
    QBENCHMARK{
51
        KisVLineIteratorSP it = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
52 53 54 55 56
    }
}

void KisVLineIteratorBenchmark::benchmarkWriteBytes()
{
57
    KisVLineIteratorSP it = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
58 59 60

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
61 62 63 64
            do {
                memcpy(it->rawData(), m_color->data(), m_colorSpace->pixelSize());
            } while (it->nextPixel());
            it->nextColumn();
65 66 67 68 69 70 71
        }
    }
}
    

void KisVLineIteratorBenchmark::benchmarkReadBytes()
{
72
    KisVLineIteratorSP it = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
73 74 75

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
76 77 78 79
            do {
                memcpy(m_color->data(), it->rawData(), m_colorSpace->pixelSize());
            } while (it->nextPixel());
            it->nextColumn();
80 81 82 83 84 85 86
        }
    }
}


void KisVLineIteratorBenchmark::benchmarkConstReadBytes()
{
87
    KisVLineConstIteratorSP it = m_device->createVLineConstIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
88 89 90

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
91 92 93 94
            do {
                memcpy(m_color->data(), it->oldRawData(), m_colorSpace->pixelSize());
            } while (it->nextPixel());
            it->nextColumn();
95 96 97 98 99 100 101 102 103 104
        }
    }
}

void KisVLineIteratorBenchmark::benchmarkReadWriteBytes(){
    KoColor c(m_colorSpace);
    c.fromQColor(QColor(250,120,0));
    KisPaintDevice dab(m_colorSpace);
    dab.fill(0,0,TEST_IMAGE_WIDTH,TEST_IMAGE_HEIGHT, c.data());
    
105 106
    KisVLineIteratorSP writeIterator = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
    KisVLineConstIteratorSP constReadIterator = dab.createVLineConstIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
107 108 109

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
110 111 112 113 114
            do {
                memcpy(writeIterator->rawData(), constReadIterator->oldRawData(), m_colorSpace->pixelSize());
            } while (constReadIterator->nextPixel() && writeIterator->nextPixel());
            constReadIterator->nextColumn();
            writeIterator->nextColumn();
115 116 117 118 119
        }
    }
    
}

120
void KisVLineIteratorBenchmark::benchmarkNoMemCpy()
121
{
122
    KisVLineIteratorSP it = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
123 124 125

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
126 127 128
            do {
            } while (it->nextPixel());
            it->nextColumn();
129 130 131 132 133
        }
    }
}
    

134 135 136


void KisVLineIteratorBenchmark::benchmarkConstNoMemCpy()
137
{
138
    KisVLineConstIteratorSP it = m_device->createVLineConstIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
139 140 141

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
142 143
            do {} while (it->nextPixel());
            it->nextColumn();
144 145 146 147 148
        }
    }
}


149
void KisVLineIteratorBenchmark::benchmarkTwoIteratorsNoMemCpy()
150
{
151 152 153 154 155
    KoColor c(m_colorSpace);
    c.fromQColor(QColor(250,120,0));
    KisPaintDevice dab(m_colorSpace);
    dab.fill(0,0,TEST_IMAGE_WIDTH,TEST_IMAGE_HEIGHT, c.data());
    
156 157
    KisVLineIteratorSP writeIterator = m_device->createVLineIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
    KisVLineConstIteratorSP constReadIterator = dab.createVLineConstIteratorNG(0, 0, TEST_IMAGE_HEIGHT);
158 159 160

    QBENCHMARK{
        for (int j = 0; j < TEST_IMAGE_WIDTH; j++) {
161 162 163
            do {} while (constReadIterator->nextPixel() && writeIterator->nextPixel());
            constReadIterator->nextColumn();
            writeIterator->nextColumn();
164 165 166 167 168
        }
    }
}


169
QTEST_MAIN(KisVLineIteratorBenchmark)