Recent comments

Reply to: Version Marking for 202403 Snapshot   4 days 3 hours ago

We have no requirements or wishes for how applications display the version of our library they are using.

Version defines for 202403 snapshot are:
#define LIBRAW_MAJOR_VERSION 0
#define LIBRAW_MINOR_VERSION 22
#define LIBRAW_PATCH_VERSION 0
#define LIBRAW_VERSION_TAIL Devel202403

Reply to: cuda / opencl port?   2 weeks 3 days ago

The library is intended (primarily) for decoding/decompressing RAW and RAW metadata. Compressed RAW data is arranged (compressed) in such a way that no gain can be obtained from using highly parallel computing (except for partial bulk operations, such as tone conversion on the curve/LUT, but for these operations there will be no gain either, since the transfer of data to/from the accelerator is slower than the LUT conversion directly on the CPU (esp. today multi-core CPU).

Postprocessing can certainly gain a lot from using parallel computing, but postprocessing is not the task of the library and the corresponding code is included there only as a minimal and imperfect example.

However, you can try to do parallel decompression of RAW data. If the result obtained is many times faster than on the CPU and you agree to provide your code for our library, we will gladly accept this contribution.

Everything related to post-processing (debayering and so on) should be done outside of LibRaw: we do not plan to extend this part of our library

Reply to: Identifying/decomposing raw formats   1 month 4 days ago

Hi Alex,

Thank you so much for the quick reply and the helpful information!

I still shoot uncompressed raw on my old Sony cameras as the compressed raw format isn't lossless. I do convert everything to DNG eventually as the format I'm working with, but I do like to archive the original out-of-camera files, probably out of paranoia. :)

I'll take a look at the fields you've mentioned and see if I can build something on top of that!

Cheers,
Marcus

Reply to: Identifying/decomposing raw formats   1 month 4 days ago

Unfortunately, the information you are asking about and in the form you are asking about is not available in the library (in its direct form).

You can query the (function) name of the decoder used by calling LibRaw:get_decoder_info() and create your own table indexed by the decoder name and containing the properties you need.

In practice, there are very few uncompressed formats now: photographers prefer to save space on flash cards and camera manufacturers follow this wish. Such uncompressed files may still present in archives, but it is hard to find an uncompressed file produced by modern camera (even if camera supports it, photographer will, most likely, switch to compressed format).

If you still want to handle uncompressed formats separately: they can be tiled/striped, so you'll need to add own code that interprets this correctly.

For uncompressed/not tiled data, data starts at libraw_internal_data.unpacker_data.data_offset and
data size is libraw_internal_data.unpacker_data.data_size
These fields are protected (in C++ terms), you may need to subclass LibRaw to access these fields.

Reply to: Steps for building dcraw_emu with USE_DNGSDK   1 month 1 week ago

No worries Alex, thanks for the reply and thanks joostn for your CMake steps!

I had started on a process from scratch last week after seeing Alex's reply and put up a gist for the macOS side here before I saw joostn's reply: https://gist.github.com/mikamikem/4e826bb9cf5beacd86ba00e42ba0b115#file-...

Linux steps here: https://gist.github.com/mikamikem/6cf1530b2fa7b011eadd46e19ed9aab7#file-...

I'm not a huge fan of my steps (a few of the stages feel like major hacks), so I might re-approach this with your CMake file and diff when I have time in the future. Thanks again for sharing!

Reply to: Sony YCbCr white balance difference seems off   1 month 1 week ago

Not sure it will be available in the next snapshot, sorry.

Reply to: Sony YCbCr white balance difference seems off   1 month 1 week ago

Ah yes, the problem is fixed!

Will this be fixed in LibRaw? I guess I'll have to wait for the next public snapshot?

Thanks
Joost

Reply to: Steps for building dcraw_emu with USE_DNGSDK   1 month 1 week ago

Oh and I'm applying this patch to make it compatible with current jxl library:

--- a/dng_sdk_1_7/dng_sdk/source/dng_jxl.cpp
+++ b/dng_sdk_1_7/dng_sdk/source/dng_jxl.cpp
@@ -2283,6 +2283,7 @@ void dng_jxl_decoder::Decode (dng_host &host,
 			// result of JxlDecoderGetColorAsEncodedProfile?
 
 			JxlPixelFormat format = { 3, JXL_TYPE_FLOAT, JXL_NATIVE_ENDIAN, 0 };
+			(void)format;
 
 			#if qDNGValidate
 			if (gVerbose)
@@ -2293,7 +2294,7 @@ void dng_jxl_decoder::Decode (dng_host &host,
 
 			if (JXL_DEC_SUCCESS ==
 				JxlDecoderGetColorAsEncodedProfile (dec,
-													&format,
+													// &format,
 													JXL_COLOR_PROFILE_TARGET_ORIGINAL,
 													&color_encoding))
 				{
@@ -2442,7 +2443,7 @@ void dng_jxl_decoder::Decode (dng_host &host,
 
 				CheckResult (JxlDecoderGetICCProfileSize
 							 (dec,
-							  &format,
+							  //&format,
 							  JXL_COLOR_PROFILE_TARGET_ORIGINAL,
 							  &profile_size),
 							 "JxlDecoderGetICCProfileSize",
@@ -2469,7 +2470,7 @@ void dng_jxl_decoder::Decode (dng_host &host,
 
 				CheckResult (JxlDecoderGetColorAsICCProfile
 							 (dec,
-							  &format,
+							  // &format,
 							  JXL_COLOR_PROFILE_TARGET_ORIGINAL,
 							  profile,
 							  profile_size),
-- 
Reply to: Steps for building dcraw_emu with USE_DNGSDK   1 month 1 week ago

I'm building the DNG SDK using cmake and this CMakeLists.txt. This creates a static library, on Windows, Linux and macos.

cmake_minimum_required(VERSION 3.15)
project(dng)
 
INCLUDE_DIRECTORIES( ${JPEG_INCLUDE_DIR} )
ADD_DEFINITIONS( ${JPEG_DEFINITIONS} )
 
INCLUDE_DIRECTORIES( ${ZLIB_INCLUDE_DIR} )
ADD_DEFINITIONS( ${ZLIB_DEFINITIONS} )
INCLUDE_DIRECTORIES( ${JXL_INCLUDE_DIR} )
ADD_DEFINITIONS( ${JXL_DEFINITIONS} )
INCLUDE_DIRECTORIES( ${XMP_INCLUDE_DIR} )
ADD_DEFINITIONS( ${XMP_DEFINITIONS} )
 
FILE(GLOB SRCFILES ${CMAKE_CURRENT_SOURCE_DIR}/dng_sdk/source/*.cpp)
FILE(GLOB HFILES ${CMAKE_CURRENT_SOURCE_DIR}/dng_sdk/source/*.h)
ADD_LIBRARY(dng-sdk STATIC ${SRCFILES})
 
TARGET_INCLUDE_DIRECTORIES( dng-sdk INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/source )
SET_TARGET_PROPERTIES(dng-sdk PROPERTIES PUBLIC_HEADER "${HFILES}")
 
set_property(TARGET dng-sdk PROPERTY CXX_STANDARD 17)
 
TARGET_COMPILE_DEFINITIONS( dng-sdk PUBLIC
                            -DqDNGThreadSafe=0
                            -DqDNG64Bit=1
                            -DqDNGDebug=0                      # do not compile debug code
                            -DqDNGValidateTarget=0             # do not build dng_validate-binary
                            -DqDNGUseLibJPEG=1                 # use libjpeg
                            -DqDNGXMPFiles=0 -DqDNGXMPDocOps=0 # build minimal XMP-set
                            -DqDNGUseStdInt=1                  # Must be set to 1, else do not compile under Linux.
)
 
# Check processor endianness (todo: not sure bigEndian platforms are set correctly)
INCLUDE(TestBigEndian)
TEST_BIG_ENDIAN(IS_BIG_ENDIAN)
IF(NOT IS_BIG_ENDIAN)
    TARGET_COMPILE_DEFINITIONS( dng-sdk PUBLIC -DqDNGLittleEndian=1)
ENDIF(NOT IS_BIG_ENDIAN)
 
IF (WIN32)
    if(MSVC)
        TARGET_COMPILE_OPTIONS( dng-sdk PRIVATE /GR /EHsc)
    else()
        TARGET_COMPILE_OPTIONS( dng-sdk PRIVATE -fexceptions)
    endif()
    TARGET_COMPILE_DEFINITIONS( dng-sdk PRIVATE -DqWinOS=1 -DqMacOS=0 -DqLinux=0 -DWIN_ENV -DWIN32 -D_WINDOWS)
ELSEIF (APPLE)
    TARGET_COMPILE_OPTIONS( dng-sdk PRIVATE -fexceptions )
    TARGET_COMPILE_DEFINITIONS( dng-sdk PRIVATE -DqWinOS=0 -DqMacOS=1 -DqLinux=0 -DMAC_ENV)
ELSE()
    TARGET_COMPILE_OPTIONS( dng-sdk PRIVATE -fexceptions -fPIE)
    TARGET_COMPILE_DEFINITIONS( dng-sdk PRIVATE -DqWinOS=0 -DqMacOS=0 -DqLinux=1 -DUNIX_ENV)
ENDIF()
 
install(TARGETS dng-sdk DESTINATION lib PUBLIC_HEADER DESTINATION include)
Reply to: Sony YCbCr white balance difference seems off   1 month 1 week ago

Could you please check with RawDigger 1.4.10 beta: https://www.rawdigger.com/news/rawdigger-1-4-10-beta

Reply to: Sony YCbCr white balance difference seems off   1 month 1 week ago

I'm using the latest RawDigger, 1.4.9 Release Build 821 (ARM64).

Here are 2 screenshots from Adobe camera raw, showing identical colors when using 'As Shot':

https://drive.google.com/file/d/1GhtJUCtIGRBP4FbReq2Jdk5vvPpoKy8X/view?u...
https://drive.google.com/file/d/1skhE7-up6nEWymxM9JShH10mO4ucm3ZL/view?u...

Reply to: Sony YCbCr white balance difference seems off   1 month 1 week ago

What exact RawDigger version you use for your testing (Windows: Menu - Help - About; Mac - Menu - RawDigger - About)

Reply to: Steps for building dcraw_emu with USE_DNGSDK   1 month 2 weeks ago

We cannot provide support for components from other vendors. For all questions related to dng sdk please contact Adobe support.

As an exception for the rule above: to create Adobe DNG SDK library (shared or static) just create corresponding build target (static or shared library) in your build environment (MS VS, XCode, whatever...) with all Adobe DNG SDK sources excluding source/dng_validate.cpp

Reply to: JPXL preview in DNG, Adobe DNG SDK   1 month 3 weeks ago

Thanks, Alex!

This saves on step. I was already fiddling with the imgdata.thumbnail.
I now need to figure out how to decode the JXL data into something my software can use. Looking at the JXL official library at the moment...

Reply to: JPXL preview in DNG, Adobe DNG SDK   1 month 3 weeks ago

We managed to support JPEG-XL and Canon H265 previews in dcraw_make_mem_thumb via this patch/commit: https://github.com/LibRaw/LibRaw/commit/cc118c1c1869e2559dbd0c7639d21915...

Reply to: JPXL preview in DNG, Adobe DNG SDK   1 month 3 weeks ago

Unpacked JPEG XL thumbnail is available via imgdata.thumbnail (and .thumbs_list)

We'll improve dcraw_make_mem_thumb() to handle it too, although this is just another buffer allocation and as-is data copy for JPEG-XL case

Reply to: ~25% exposure bump in some processed images?   1 month 3 weeks ago

That was it: I set adjust_maximum_thr = 0 and now my captures are consistent. Thanks very much!

Reply to: ~25% exposure bump in some processed images?   1 month 3 weeks ago

You got hit by 'automated maximum adjustment' code implemented in LibRaw's postprocessing many years ago to avoid 'pink clouds' problem: real data range is not present in RAW metadata while real data maximum is lower than format maximum.

To turn the feature off: use
imgdata.params.adjust_maximum_thr = 0;
(corresponding dcraw_emu command line switch: -c 0)

Here are your 0018 file processed via:
dcraw_emu -w -T and dcraw_emu -w -c 0 -T respectively
https://www.dropbox.com/scl/fo/8bgts0j5m5aa8007czqkf/AC8-URS3v42QVYOD_wk...

Reply to: White balance problem   1 month 3 weeks ago

It is hard to discuss something without having files in question on hands.

Probably: your Sony (!) images are shot in Small/Medium (pseudo)RAW mode. This is YCC files (similar to lossless JPEGs), already processed and white balanced in camera.

Reply to: Link for LibRaw-0.21.3-macOS.zip not working.   2 months 1 week ago

All looks good now, thanks very much!

Reply to: Link for LibRaw-0.21.3-macOS.zip not working.   2 months 1 week ago

rebuilded, reuploaded, downloaded to another computer: should work now

Reply to: Link for LibRaw-0.21.3-macOS.zip not working.   2 months 1 week ago

Thanks for fixing that link. Source files and libraries are fine. However the /bin subfolder, normally containing executables such as dcraw_emu, is empty in LibRaw-0.21.3-macOS.zip aside from the .keep_me file.

Best Regards,
AJW

Reply to: expire Next Major Version,more Camera List   2 months 2 weeks ago

It is disclosed on this site 1st page: https://www.libraw.org/#updatepolicy

Reply to: Link for LibRaw-0.21.3-macOS.zip not working.   2 months 3 weeks ago

Thank you for your feedback

Fixed

Pages