Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding support for NLT marker segment of type 3 #154

Merged
merged 20 commits into from
Sep 22, 2024
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
0f21481
Added support for NLT marker only, but not tested.
aous72 Sep 17, 2024
5d888b5
This is for lossless compression. It removes the 1.1f factor.
aous72 Sep 17, 2024
5f29603
This should complete all code changed for the library. We need to te…
aous72 Sep 17, 2024
517e1be
Getting rid of some of the warnings
aous72 Sep 17, 2024
2626fe2
2nd attempt to get rid of warnings.
aous72 Sep 17, 2024
fcd652c
Small bug fix for wasm
aous72 Sep 17, 2024
086a5a5
A bug fix, and addressing the float to double type conversion.
aous72 Sep 17, 2024
5921b01
Added support for .pfm in ojph_compress and ojph_expand -- not happy…
aous72 Sep 18, 2024
2a36ea4
Bug fixes, pfm with different bit_depth/signedness are supported now.
aous72 Sep 20, 2024
27c9a2e
This fixes the one component case.
aous72 Sep 20, 2024
0c6dfd3
Removes compilation warnings.
aous72 Sep 20, 2024
9f8011c
This fixes a bug in the block decoder code. The bug can happen when …
aous72 Sep 20, 2024
7b0f5c8
Improvement for pfm_in, and a bug fix for handling signed pfm data.
aous72 Sep 20, 2024
b6ddad9
This should address "strict-aliasing". Cosmetic change to a wasm file…
aous72 Sep 20, 2024
1580ae7
This address one more warning.
aous72 Sep 20, 2024
9e97f99
Hopefully, this will remove warnings.
aous72 Sep 20, 2024
bcc4d3b
Added usage text for ojph_compress. Also , the end user must now spe…
aous72 Sep 20, 2024
11307b6
Change default signedness of .pfm to true.
aous72 Sep 22, 2024
57c7af3
This adds some codestream checking in ojph_expand.
aous72 Sep 22, 2024
796fb6b
Spelling mistake fix.
aous72 Sep 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 111 additions & 1 deletion src/apps/common/ojph_img_io.h
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ namespace ojph {

ui32 cur_line;
si64 start_of_data;
int planar;
bool planar;
ui32 bit_depth[3];
bool is_signed[3];
point subsampling[3];
Expand Down Expand Up @@ -446,6 +446,67 @@ namespace ojph {
size_t buffer_size;
};

////////////////////////////////////////////////////////////////////////////
//
//
//
//
//
////////////////////////////////////////////////////////////////////////////
class pfm_in : public image_in_base
{
public:
pfm_in(mem_fixed_allocator *p = NULL)
{
fh = 0;
fname = NULL;
alloc_p = p;
temp_buf = NULL;
temp_buf_byte_size = 0;
bit_depth = 32;
scale = 0.0f;
little_endian = true;
width = height = num_comps = 0;

cur_line = 0;
start_of_data = 0;
}
virtual ~pfm_in()
{
close();
if (alloc_p == NULL && temp_buf)
free(temp_buf);
}

void open(const char* filename);
void finalize_alloc();
void configure(ui32 bit_depth) {
assert(bit_depth > 0 && bit_depth <= 32);
this->bit_depth = bit_depth;
}
virtual ui32 read(const line_buf* line, ui32 comp_num);
void close() { if(fh) { fclose(fh); fh = NULL; } fname = NULL; }

size get_size() { assert(fh); return size(width, height); }
ui32 get_width() { assert(fh); return width; }
ui32 get_height() { assert(fh); return height; }
ui32 get_num_components() { assert(fh); return num_comps; }

private:
FILE *fh;
const char *fname;
mem_fixed_allocator *alloc_p;
float *temp_buf;
ui32 temp_buf_byte_size;
ui32 bit_depth; // this truncates data to bit_depth in the LSB
float scale;
bool little_endian;
ui32 width, height, num_comps;
ui32 cur_line;
si64 start_of_data;
};


////////////////////////////////////////////////////////////////////////////
// Accelerators (defined in ojph_img_io_*)
typedef void (*conversion_fun)(const line_buf *ln0, const line_buf *ln1,
Expand Down Expand Up @@ -703,6 +764,55 @@ namespace ojph {
ui8* buffer;
ui32 buffer_size;
};

////////////////////////////////////////////////////////////////////////////
//
//
//
//
//
////////////////////////////////////////////////////////////////////////////
class pfm_out : public image_out_base
{
public:
pfm_out()
{
fh = NULL;
fname = NULL;
buffer = NULL;
buffer_size = 0;
width = height = num_components = 0;
scale = -1.0f;
bit_depth = 32;
cur_line = 0;
start_of_data = 0;
}
virtual ~pfm_out()
{
close();
if (buffer)
free(buffer);
}

void open(char* filename);
void configure(ui32 width, ui32 height, ui32 num_components,
float scale, ui32 bit_depth);
virtual ui32 write(const line_buf* line, ui32 comp_num);
virtual void close() { if(fh) { fclose(fh); fh = NULL; } fname = NULL; }

private:
FILE *fh;
const char *fname;
float* buffer;
ui32 buffer_size;
ui32 width, height, num_components;
float scale;
ui32 bit_depth;
ui32 cur_line;
si64 start_of_data;
};


}

#endif // !OJPH_IMG_IO_H
69 changes: 69 additions & 0 deletions src/apps/ojph_compress/ojph_compress.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -611,6 +611,7 @@ int main(int argc, char * argv[]) {
ojph::codestream codestream;

ojph::ppm_in ppm;
ojph::pfm_in pfm;
ojph::yuv_in yuv;
ojph::raw_in raw;
ojph::dpx_in dpx;
Expand Down Expand Up @@ -736,6 +737,74 @@ int main(int argc, char * argv[]) {

base = &ppm;
}
else if (is_matching(".pfm", v))
{
pfm.open(input_filename);
ojph::param_siz siz = codestream.access_siz();
siz.set_image_extent(ojph::point(image_offset.x + pfm.get_width(),
image_offset.y + pfm.get_height()));
ojph::ui32 num_comps = pfm.get_num_components();
assert(num_comps == 1 || num_comps == 3);
siz.set_num_components(num_comps);

pfm.configure(bit_depth[0]);
for (ojph::ui32 c = 0; c < num_comps; ++c) {
ojph::ui32 bd = 32;
if (bit_depth[c] != 0)
bd = bit_depth[c];
bool is = false;
if (is_signed[c] != -1)
is = is_signed[c] != 0;
ojph::point ds(1, 1);
siz.set_component(c, ds, bd, is);
}
siz.set_image_offset(image_offset);
siz.set_tile_size(tile_size);
siz.set_tile_offset(tile_offset);

ojph::param_cod cod = codestream.access_cod();
cod.set_num_decomposition(num_decompositions);
cod.set_block_dims(block_size.w, block_size.h);
if (num_precincts != -1)
cod.set_precinct_size(num_precincts, precinct_size);
cod.set_progression_order(prog_order);
if (employ_color_transform == -1)
cod.set_color_transform(true);
else
cod.set_color_transform(employ_color_transform == 1);
cod.set_reversible(reversible);
if (!reversible && quantization_step != -1.0f)
codestream.access_qcd().set_irrev_quant(quantization_step);

ojph::param_nlt nlt = codestream.access_nlt();
if (reversible)
nlt.set_type3_transformation(ojph::param_nlt::ALL_COMPS, true);
else
OJPH_ERROR(0x01000091, "The support for pfm image is not "
"complete; I need to figure how to modify the interface "
"to better support the exchange of floating point data. "
"Feeding float point data is not supported yet, unless it "
"is for lossless compression.");

codestream.set_planar(false);
if (profile_string[0] != '\0')
codestream.set_profile(profile_string);
codestream.set_tilepart_divisions(tileparts_at_resolutions,
tileparts_at_components);
codestream.request_tlm_marker(tlm_marker);

if (dims.w != 0 || dims.h != 0)
OJPH_WARN(0x01000092,
"-dims option is not needed and was not used\n");
if (num_components != 0)
OJPH_WARN(0x01000093,
"-num_comps is not needed and was not used\n");
if (comp_downsampling[0].x != 0 || comp_downsampling[0].y != 0)
OJPH_WARN(0x01000094,
"-downsamp is not needed and was not used\n");

base = &pfm;
}
#ifdef OJPH_ENABLE_TIFF_SUPPORT
else if (is_matching(".tif", v) || is_matching(".tiff", v))
{
Expand Down
27 changes: 27 additions & 0 deletions src/apps/ojph_expand/ojph_expand.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -213,6 +213,7 @@ int main(int argc, char *argv[]) {
ojph::codestream codestream;

ojph::ppm_out ppm;
ojph::pfm_out pfm;
#ifdef OJPH_ENABLE_TIFF_SUPPORT
ojph::tif_out tif;
#endif /* OJPH_ENABLE_TIFF_SUPPORT */
Expand Down Expand Up @@ -266,6 +267,32 @@ int main(int argc, char *argv[]) {
ppm.open(output_filename);
base = &ppm;
}
else if (is_matching(".pfm", v))
{
codestream.set_planar(false);
ojph::param_siz siz = codestream.access_siz();

ojph::ui32 num_comps = siz.get_num_components();
if (num_comps != 3 && num_comps != 1)
OJPH_ERROR(0x0200000C,
"The file has %d color components; this cannot be saved to"
" a .pfm file\n", num_comps);
bool all_same = true;
ojph::point p = siz.get_downsampling(0);
for (ojph::ui32 i = 1; i < siz.get_num_components(); ++i)
{
ojph::point p1 = siz.get_downsampling(i);
all_same = all_same && (p1.x == p.x) && (p1.y == p.y);
}
if (!all_same)
OJPH_ERROR(0x0200000D,
"To save an image to ppm, all the components must have the "
"same downsampling ratio\n");
pfm.configure(siz.get_recon_width(0), siz.get_recon_height(0),
siz.get_num_components(), -1.0f, siz.get_bit_depth(0));
pfm.open(output_filename);
base = &pfm;
}
#ifdef OJPH_ENABLE_TIFF_SUPPORT
else if (is_matching(".tif", v) || is_matching(".tiff", v))
{
Expand Down
Loading
Loading