Parallel.For с обработкой растровых изображений

Я хочу ускорить мой код. Мне бы хотелось, чтобы этот фрагмент работал быстрее. Я пытался создать свой собственный Parallel.For Реализация цикла, но мне не удалось. Нет ошибок, но tifDS кажется пустым:/ Может ли что-нибудь1 помочь мне? Заранее спасибо!

Оригинальные петли:

for (int iY = 0; iY < srcDS.RasterYSize; iY++)
{
    byte[] srcData = new byte[srcDS.RasterXSize * 1];
    srcBand.ReadRaster(0, iY, srcDS.RasterXSize, 1, srcData, srcDS.RasterXSize, 1, 0, 0);

    for (int iBand = 0; iBand < _outBands; iBand++)
    {
        int[] bandLookup = lookup[iBand];

        int[] dstData = new int[srcData.Count()];
        for (int index = 0; index < srcData.Count(); index++)
        {
            byte b = srcData[index];
            dstData[index] = bandLookup[b];
        }

        tifDS.GetRasterBand(iBand + 1).WriteRaster(0, iY, srcDS.RasterXSize, 1, dstData,
                                                   srcDS.RasterXSize, 1, 0, 0);
    }
}

Мои попытки:

for (int iY = 0; iY < srcDS.RasterYSize; iY++)
{
    byte[] srcData = new byte[srcDS.RasterXSize * 1];
    srcBand.ReadRaster(0, iY, srcDS.RasterXSize, 1, srcData, srcDS.RasterXSize, 1, 0, 0);

    Parallel.For<object>((long) 0, _outBands, () => 0,
                         (iBand, state, subtotal) =>
                             {
                                 int[] bandLookup = lookup[iBand];

                                 int[] dstData = new int[srcData.Count()];
                                 for (int index = 0; index < srcData.Count(); index++)
                                 {
                                     byte b = srcData[index];
                                     dstData[index] = bandLookup[b];
                                 }

                                 return new object[] {iBand, dstData};
                             },
                         o =>
                             {
                                 int iBand = (int) (o as object[])[0];
                                 int[] dstData = (o as object[])[1] as int[];
                                 lock (_getRasterBandLock)
                                 {
                                     tifDS.GetRasterBand(iBand + 1).WriteRaster(0, iY, srcDS.RasterXSize, 1, dstData,
                                                   srcDS.RasterXSize, 1, 0, 0);
                                 }
                             });
}

0 ответов

Другие вопросы по тегам