From 99462118cc80f1f8e9c6407f4f8825c82b301c24 Mon Sep 17 00:00:00 2001 From: Melissa Linkert Date: Thu, 29 Aug 2024 17:19:45 -0500 Subject: [PATCH] Reduce number of calls to getSamplesPerPixel() Especially when repacking tiles, many duplicate calls to this method can get expensive. --- .../src/loci/formats/out/DicomWriter.java | 22 +++++++++++-------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/components/formats-bsd/src/loci/formats/out/DicomWriter.java b/components/formats-bsd/src/loci/formats/out/DicomWriter.java index de3850248ea..d578d10e06c 100644 --- a/components/formats-bsd/src/loci/formats/out/DicomWriter.java +++ b/components/formats-bsd/src/loci/formats/out/DicomWriter.java @@ -500,6 +500,7 @@ public void saveBytes(int no, byte[] buf, int x, int y, int w, int h) int bytesPerPixel = FormatTools.getBytesPerPixel( FormatTools.pixelTypeFromString( r.getPixelsType(series).toString())); + int samplesPerPixel = getSamplesPerPixel(); out.seek(out.length()); long start = out.getFilePointer(); @@ -512,9 +513,9 @@ public void saveBytes(int no, byte[] buf, int x, int y, int w, int h) if ((x + w == getSizeX() && w < thisTileWidth) || (y + h == getSizeY() && h < thisTileHeight)) { - if (interleaved || getSamplesPerPixel() == 1) { - int srcRowLen = w * bytesPerPixel * getSamplesPerPixel(); - int destRowLen = thisTileWidth * bytesPerPixel * getSamplesPerPixel(); + if (interleaved || samplesPerPixel == 1) { + int srcRowLen = w * bytesPerPixel * samplesPerPixel; + int destRowLen = thisTileWidth * bytesPerPixel * samplesPerPixel; paddedBuf = new byte[thisTileHeight * destRowLen]; for (int row=0; row