38#define _USE_MATH_DEFINES
61 state->set_image_extent(dims);
67 state->set_tile_size(s);
73 state->set_image_offset(offset);
79 state->set_tile_offset(offset);
85 state->set_num_components(num_comps);
92 state->set_comp_info(comp_num, downsampling, bit_depth,
is_signed);
128 return state->get_bit_depth(comp_num);
134 return state->is_signed(comp_num);
140 return state->get_downsampling(comp_num);
146 return state->get_recon_width(comp_num);
152 return state->get_recon_height(comp_num);
166 if (num_decompositions > 32)
168 "maximum number of decompositions cannot exceed 32");
169 state->SPcod.num_decomp = (
ui8)num_decompositions;
177 if (width == 0 || width != (1u << log_width)
178 || height == 0 || height != (1u << log_height)
179 || log_width < 2 || log_height < 2
180 || log_width + log_height > 12)
181 OJPH_ERROR(0x00050011,
"incorrect code block dimensions");
182 state->SPcod.block_width = (
ui8)(log_width - 2);
183 state->SPcod.block_height = (
ui8)(log_height - 2);
189 if (num_levels == 0 || precinct_size == NULL)
194 for (
int i = 0; i <=
state->SPcod.num_decomp; ++i)
196 size t = precinct_size[i < num_levels ? i : num_levels - 1];
200 if (t.
w == 0 || t.
h == 0)
201 OJPH_ERROR(0x00050021,
"precinct width or height cannot be 0");
202 if (t.
w != (1u<<PPx) || t.
h != (1u<<PPy))
204 "precinct width and height should be a power of 2");
205 if (PPx > 15 || PPy > 15)
206 OJPH_ERROR(0x00050023,
"precinct size is too large");
207 if (i > 0 && (PPx == 0 || PPy == 0))
208 OJPH_ERROR(0x00050024,
"precinct size is too small");
209 state->SPcod.precinct_size[i] = (
ui8)(PPx | (PPy << 4));
218 size_t len = strlen(name);
232 OJPH_ERROR(0x00050031,
"unknown progression order");
235 OJPH_ERROR(0x00050032,
"improper progression order");
238 state->SGCod.prog_order = (
ui8)prog_order;
244 state->employ_color_transform(color_transform ? 1 : 0);
250 state->set_reversible(reversible);
258 p =
state->add_coc_object(component_idx);
265 return state->get_num_decompositions();
271 return state->get_block_dims();
277 return state->get_log_block_dims();
283 return state->is_reversible();
289 return state->get_precinct_size(level_num);
295 return state->get_log_precinct_size(level_num);
301 return state->SGCod.prog_order;
325 return state->SGCod.num_layers;
331 return state->is_employing_color_transform();
337 return state->packets_may_use_sop();
343 return state->packets_use_eph();
349 return state->get_block_vertical_causality();
416 state->set_delta(delta);
422 state->set_delta(comp_idx, delta);
436 state->set_nonlinear_transform(comp_num, nl_type);
441 bool& is_signed,
ui8& nl_type)
const
443 return state->get_nonlinear_transform(comp_num, bit_depth, is_signed,
458 size_t t = strlen(str);
461 "COM marker string length cannot be larger than 65531");
472 "COM marker string length cannot be larger than 65531");
492 return (
ui16)((t << 8) | (t >> 8));
542 1.4021e+00f, 2.0304e+00f, 2.9012e+00f, 4.1153e+00f, 5.8245e+00f,
543 8.2388e+00f, 1.1652e+01f, 1.6479e+01f, 2.3304e+01f, 3.2957e+01f,
544 4.6609e+01f, 6.5915e+01f, 9.3217e+01f, 1.3183e+02f, 1.8643e+02f,
545 2.6366e+02f, 3.7287e+02f, 5.2732e+02f, 7.4574e+02f, 1.0546e+03f,
546 1.4915e+03f, 2.1093e+03f, 2.9830e+03f, 4.2185e+03f, 5.9659e+03f,
547 8.4371e+03f, 1.1932e+04f, 1.6874e+04f, 2.3864e+04f, 3.3748e+04f,
548 4.7727e+04f, 6.7496e+04f, 9.5454e+04f };
550 1.9669e+00f, 2.8839e+00f, 4.1475e+00f, 5.8946e+00f, 8.3472e+00f,
551 1.1809e+01f, 1.6701e+01f, 2.3620e+01f, 3.3403e+01f, 4.7240e+01f,
552 6.6807e+01f, 9.4479e+01f, 1.3361e+02f, 1.8896e+02f, 2.6723e+02f,
553 3.7792e+02f, 5.3446e+02f, 7.5583e+02f, 1.0689e+03f, 1.5117e+03f,
554 2.1378e+03f, 3.0233e+03f, 4.2756e+03f, 6.0467e+03f, 8.5513e+03f,
555 1.2093e+04f, 1.7103e+04f, 2.4187e+04f, 3.4205e+04f, 4.8373e+04f,
556 6.8410e+04f, 9.6747e+04f, 1.3682e+05f };
558 1.2247e+00f, 1.3229e+00f, 1.5411e+00f, 1.7139e+00f, 1.9605e+00f,
559 2.2044e+00f, 2.5047e+00f, 2.8277e+00f, 3.2049e+00f, 3.6238e+00f,
560 4.1033e+00f, 4.6423e+00f, 5.2548e+00f, 5.9462e+00f, 6.7299e+00f,
561 7.6159e+00f, 8.6193e+00f, 9.7544e+00f, 1.1039e+01f, 1.2493e+01f,
562 1.4139e+01f, 1.6001e+01f, 1.8108e+01f, 2.0493e+01f, 2.3192e+01f,
563 2.6246e+01f, 2.9702e+01f, 3.3614e+01f, 3.8041e+01f, 4.3051e+01f,
564 4.8721e+01f, 5.5138e+01f, 6.2399e+01f };
566 1.3975e+00f, 1.4389e+00f, 1.7287e+00f, 1.8880e+00f, 2.1841e+00f,
567 2.4392e+00f, 2.7830e+00f, 3.1341e+00f, 3.5576e+00f, 4.0188e+00f,
568 4.5532e+00f, 5.1494e+00f, 5.8301e+00f, 6.5963e+00f, 7.4663e+00f,
569 8.4489e+00f, 9.5623e+00f, 1.0821e+01f, 1.2247e+01f, 1.3860e+01f,
570 1.5685e+01f, 1.7751e+01f, 2.0089e+01f, 2.2735e+01f, 2.5729e+01f,
571 2.9117e+01f, 3.2952e+01f, 3.7292e+01f, 4.2203e+01f, 4.7761e+01f,
572 5.4051e+01f, 6.1170e+01f, 6.9226e+01f };
593 1.3328e+00f, 1.3067e+00f, 1.3028e+00f, 1.3001e+00f, 1.2993e+00f,
594 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f,
595 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f,
596 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f,
597 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f,
598 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f, 1.2992e+00f,
599 1.2992e+00f, 1.2992e+00f };
601 1.2757e+00f, 1.2352e+00f, 1.2312e+00f, 1.2285e+00f, 1.2280e+00f,
602 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f,
603 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f,
604 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f,
605 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f,
606 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f, 1.2278e+00f,
607 1.2278e+00f, 1.2278e+00f };
609 1.6250e+00f, 1.6875e+00f, 1.6963e+00f, 1.7067e+00f, 1.7116e+00f,
610 1.7129e+00f, 1.7141e+00f, 1.7145e+00f, 1.7151e+00f, 1.7152e+00f,
611 1.7155e+00f, 1.7155e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f,
612 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f,
613 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f,
614 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f, 1.7156e+00f,
615 1.7156e+00f, 1.7156e+00f };
617 2.7500e+00f, 2.8047e+00f, 2.8198e+00f, 2.8410e+00f, 2.8558e+00f,
618 2.8601e+00f, 2.8628e+00f, 2.8656e+00f, 2.8662e+00f, 2.8667e+00f,
619 2.8669e+00f, 2.8670e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f,
620 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f,
621 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f,
622 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f, 2.8671e+00f,
623 2.8671e+00f, 2.8671e+00f };
645 result &= file->
write(&buf, 2) == 2;
647 result &= file->
write(&buf, 2) == 2;
649 result &= file->
write(&buf, 2) == 2;
651 result &= file->
write(&buf, 4) == 4;
653 result &= file->
write(&buf, 4) == 4;
655 result &= file->
write(&buf, 4) == 4;
657 result &= file->
write(&buf, 4) == 4;
659 result &= file->
write(&buf, 4) == 4;
661 result &= file->
write(&buf, 4) == 4;
663 result &= file->
write(&buf, 4) == 4;
665 result &= file->
write(&buf, 4) == 4;
667 result &= file->
write(&buf, 2) == 2;
668 for (
int c = 0; c <
Csiz; ++c)
670 buf[0] =
cptr[c].SSiz;
671 buf[1] =
cptr[c].XRsiz;
672 buf[2] =
cptr[c].YRsiz;
673 result &= file->
write(&buf, 3) == 3;
683 OJPH_ERROR(0x00050041,
"error reading SIZ marker");
685 int num_comps = (
Lsiz - 38) / 3;
686 if (
Lsiz != 38 + 3 * num_comps)
687 OJPH_ERROR(0x00050042,
"error in SIZ marker length");
689 OJPH_ERROR(0x00050043,
"error reading SIZ marker");
691 if ((
Rsiz & 0x4000) == 0)
693 "Rsiz bit 14 is not set (this is not a JPH file)");
694 if ((
Rsiz & 0x8000) != 0 && (
Rsiz & 0xD5F) != 0)
695 OJPH_WARN(0x00050001,
"Rsiz in SIZ has unimplemented fields");
697 OJPH_ERROR(0x00050045,
"error reading SIZ marker");
700 OJPH_ERROR(0x00050046,
"error reading SIZ marker");
702 ui32 t_XOsiz, t_YOsiz;
703 if (file->
read(&t_XOsiz, 4) != 4)
704 OJPH_ERROR(0x00050047,
"error reading SIZ marker");
705 if (file->
read(&t_YOsiz, 4) != 4)
706 OJPH_ERROR(0x00050048,
"error reading SIZ marker");
708 ui32 t_XTsiz, t_YTsiz;
709 if (file->
read(&t_XTsiz, 4) != 4)
710 OJPH_ERROR(0x00050049,
"error reading SIZ marker");
711 if (file->
read(&t_YTsiz, 4) != 4)
712 OJPH_ERROR(0x0005004A,
"error reading SIZ marker");
714 ui32 t_XTOsiz, t_YTOsiz;
715 if (file->
read(&t_XTOsiz, 4) != 4)
716 OJPH_ERROR(0x0005004B,
"error reading SIZ marker");
717 if (file->
read(&t_YTOsiz, 4) != 4)
718 OJPH_ERROR(0x0005004C,
"error reading SIZ marker");
721 OJPH_ERROR(0x0005004D,
"error reading SIZ marker");
723 if (
Csiz != num_comps)
724 OJPH_ERROR(0x0005004E,
"Csiz does not match the SIZ marker size");
726 for (
int c = 0; c <
Csiz; ++c)
728 if (file->
read(&
cptr[c].SSiz, 1) != 1)
729 OJPH_ERROR(0x00050051,
"error reading SIZ marker");
730 if (file->
read(&
cptr[c].XRsiz, 1) != 1)
731 OJPH_ERROR(0x00050052,
"error reading SIZ marker");
732 if (file->
read(&
cptr[c].YRsiz, 1) != 1)
733 OJPH_ERROR(0x00050053,
"error reading SIZ marker");
734 if ((
cptr[c].SSiz & 0x7F) > 37)
735 OJPH_ERROR(0x00050054,
"Wrong SIZ-SSiz value of %d",
cptr[c].SSiz);
736 if (
cptr[c].XRsiz == 0)
737 OJPH_ERROR(0x00050055,
"Wrong SIZ-XRsiz value of %d",
cptr[c].XRsiz);
738 if (
cptr[c].YRsiz == 0)
739 OJPH_ERROR(0x00050056,
"Wrong SIZ-YRsiz value of %d",
cptr[c].YRsiz);
796 result &= file->
write(&buf, 2) == 2;
798 result &= file->
write(&buf, 2) == 2;
800 result &= file->
write(&buf, 4) == 4;
803 result &= file->
write(&buf, 2) == 2;
812 OJPH_ERROR(0x00050061,
"error reading CAP marker");
815 OJPH_ERROR(0x00050062,
"error reading CAP marker");
818 if (
Pcap & 0xFFFDFFFF)
820 "error Pcap in CAP has options that are not supported");
821 if ((
Pcap & 0x00020000) == 0)
823 "error Pcap should have its 15th MSB set, Pcap^15. "
824 " This is not a JPH file");
825 for (
ui32 i = 0; i < count; ++i)
827 OJPH_ERROR(0x00050065,
"error reading CAP marker");
828 if (
Lcap != 6 + 2 * count)
829 OJPH_ERROR(0x00050066,
"error in CAP marker length");
843 if (
SPcod.wavelet_trans <= 1)
847 return atk->is_reversible();
865 result &= file->
write(&buf, 2) == 2;
867 result &= file->
write(&buf, 2) == 2;
869 result &= file->
write(&buf, 1) == 1;
871 result &= file->
write(&buf, 1) == 1;
873 result &= file->
write(&buf, 2) == 2;
875 result &= file->
write(&buf, 1) == 1;
876 buf[0] =
SPcod.num_decomp;
877 buf[1] =
SPcod.block_width;
878 buf[2] =
SPcod.block_height;
879 buf[3] =
SPcod.block_style;
880 result &= file->
write(&buf, 4) == 4;
882 result &= file->
write(&buf, 1) == 1;
884 for (
int i = 0; i <=
SPcod.num_decomp; ++i)
886 *(
ui8*)buf =
SPcod.precinct_size[i];
887 result &= file->
write(&buf, 1) == 1;
914 Lcod = num_comps < 257 ? 9 : 10;
922 result &= file->
write(&buf, 2) == 2;
924 result &= file->
write(&buf, 2) == 2;
928 result &= file->
write(&buf, 1) == 1;
933 result &= file->
write(&buf, 2) == 2;
936 result &= file->
write(&buf, 1) == 1;
937 buf[0] =
SPcod.num_decomp;
938 buf[1] =
SPcod.block_width;
939 buf[2] =
SPcod.block_height;
940 buf[3] =
SPcod.block_style;
941 result &= file->
write(&buf, 4) == 4;
943 result &= file->
write(&buf, 1) == 1;
945 for (
int i = 0; i <=
SPcod.num_decomp; ++i)
947 *(
ui8*)buf =
SPcod.precinct_size[i];
948 result &= file->
write(&buf, 1) == 1;
960 OJPH_ERROR(0x00050071,
"error reading COD segment");
963 OJPH_ERROR(0x00050072,
"error reading COD segment");
964 if (file->
read(&
SGCod.prog_order, 1) != 1)
965 OJPH_ERROR(0x00050073,
"error reading COD segment");
966 if (file->
read(&
SGCod.num_layers, 2) != 2)
967 {
OJPH_ERROR(0x00050074,
"error reading COD segment"); }
971 OJPH_ERROR(0x00050075,
"error reading COD segment");
972 if (file->
read(&
SPcod.num_decomp, 1) != 1)
973 OJPH_ERROR(0x00050076,
"error reading COD segment");
974 if (file->
read(&
SPcod.block_width, 1) != 1)
975 OJPH_ERROR(0x00050077,
"error reading COD segment");
976 if (file->
read(&
SPcod.block_height, 1) != 1)
977 OJPH_ERROR(0x00050078,
"error reading COD segment");
978 if (file->
read(&
SPcod.block_style, 1) != 1)
979 OJPH_ERROR(0x00050079,
"error reading COD segment");
980 if (file->
read(&
SPcod.wavelet_trans, 1) != 1)
981 OJPH_ERROR(0x0005007A,
"error reading COD segment");
984 ||
SPcod.block_width > 8
985 ||
SPcod.block_height > 8
987 || (
SPcod.block_style & 0x40) != 0x40
988 || (
SPcod.block_style & 0xB7) != 0x00)
989 OJPH_ERROR(0x0005007D,
"wrong settings in a COD-SPcod parameter");
990 if ((
SPcod.block_style & 0x40) != 0x40
991 || (
SPcod.block_style & 0xB7) != 0x00)
992 OJPH_ERROR(0x0005007E,
"unsupported settings in a COD-SPcod parameter");
996 for (
int i = 0; i <= num_decompositions; ++i) {
997 if (file->
read(&
SPcod.precinct_size[i], 1) != 1)
998 OJPH_ERROR(0x0005007B,
"error reading COD segment");
1000 if ((
SPcod.precinct_size[i] & 0x0F) == 0 ||
1001 (
SPcod.precinct_size[i] >> 4) == 0)
1003 "Precinct width or height for resolutions other than the"
1004 " coarsest must be larger than 1; here, they are %d and %d,"
1006 1 << (
SPcod.precinct_size[i] & 0x0F),
1007 1 << (
SPcod.precinct_size[i] >> 4));
1011 OJPH_ERROR(0x0005007C,
"error in COD segment length");
1024 OJPH_ERROR(0x00050121,
"error reading COC segment");
1026 if (num_comps < 257) {
1028 if (file->
read(&t, 1) != 1)
1029 OJPH_ERROR(0x00050122,
"error reading COC segment");
1034 OJPH_ERROR(0x00050123,
"error reading COC segment");
1038 OJPH_ERROR(0x00050124,
"error reading COC segment");
1041 "Unsupported options in Scoc field of the COC segment");
1042 if (file->
read(&
SPcod.num_decomp, 1) != 1)
1043 OJPH_ERROR(0x00050125,
"error reading COC segment");
1044 if (file->
read(&
SPcod.block_width, 1) != 1)
1045 OJPH_ERROR(0x00050126,
"error reading COC segment");
1046 if (file->
read(&
SPcod.block_height, 1) != 1)
1047 OJPH_ERROR(0x00050127,
"error reading COC segment");
1048 if (file->
read(&
SPcod.block_style, 1) != 1)
1049 OJPH_ERROR(0x00050128,
"error reading COC segment");
1050 if (file->
read(&
SPcod.wavelet_trans, 1) != 1)
1051 OJPH_ERROR(0x00050129,
"error reading COC segment");
1054 ||
SPcod.block_width > 8
1055 ||
SPcod.block_height > 8
1056 ||
SPcod.block_width +
SPcod.block_height > 8
1057 || (
SPcod.block_style & 0x40) != 0x40
1058 || (
SPcod.block_style & 0xB7) != 0x00)
1059 OJPH_ERROR(0x0005012C,
"wrong settings in a COC-SPcoc parameter");
1060 if ((
SPcod.block_style & 0x40) != 0x40
1061 || (
SPcod.block_style & 0xB7) != 0x00)
1062 OJPH_ERROR(0x0005012D,
"unsupported settings in a COC-SPcoc parameter");
1066 for (
int i = 0; i <= num_decompositions; ++i) {
1067 if (file->
read(&
SPcod.precinct_size[i], 1) != 1)
1068 OJPH_ERROR(0x0005012A,
"error reading COC segment");
1070 if ((
SPcod.precinct_size[i] & 0x0F) == 0 ||
1071 (
SPcod.precinct_size[i] >> 4) == 0)
1073 "Precinct width or height for resolutions other than the"
1074 " coarsest must be larger than 1; here, they are %d and %d,"
1076 1 << (
SPcod.precinct_size[i] & 0x0F),
1077 1 << (
SPcod.precinct_size[i] >> 4));
1081 t += num_comps < 257 ? 0 : 1;
1082 t += (
Scod & 1) ? 1 + num_decompositions : 0;
1084 OJPH_ERROR(0x0005012B,
"error in COC segment length");
1091 this->atk =
atk->get_atk(
SPcod.wavelet_trans);
1092 if (this->atk == NULL)
1093 OJPH_ERROR(0x00050131,
"A COD segment employs the DWT kernel "
1094 "atk = %d, but a corresponding ATK segment cannot be found.",
1095 SPcod.wavelet_trans);
1101 OJPH_ERROR(0x00050132,
"A COC segment employs the DWT kernel "
1102 "atk = %d, but a corresponding ATK segment cannot be found",
1103 SPcod.wavelet_trans);
1136 while (p->
next != NULL)
1165 bool all_same =
true;
1166 bool other_comps_exist =
false;
1167 ui32 first_comp = 0xFFFF;
1169 ui32 num_decompositions = 0;
1171 bool is_signed =
false;
1174 for (
ui32 c = 0; c < num_comps; ++c)
1197 other_comps_exist =
true;
1202 ui32 qcd_num_decompositions;
1205 ui32 qcd_wavelet_kern;
1207 ui32 qcd_component = first_comp != 0xFFFF ? first_comp : 0;
1211 qcd_is_signed = siz.
is_signed(qcd_component);
1216 qcd_component < 3 ? employing_color_transform :
false);
1220 this->
base_delta = 1.0f / (float)(1 << qcd_bit_depth);
1231 for (
ui32 c = 0; c < num_comps; ++c)
1250 c < 3 ? employing_color_transform :
false);
1254 qp->
base_delta = 1.0f / (float)(1 << bit_depth);
1261 else if (other_comps_exist)
1264 for (
ui32 c = 0; c < num_comps; ++c)
1275 c < 3 ? employing_color_transform :
false);
1279 qp->
base_delta = 1.0f / (float)(1 << bit_depth);
1300 bool is_employing_color_transform)
1303 B += is_employing_color_transform ? 1 : 0;
1306 ui32 X = (
ui32) ceil(log(bibo_l * bibo_l) / M_LN2);
1309 for (
ui32 d = num_decomps; d > 0; --d)
1313 X = (
ui32) ceil(log(bibo_h * bibo_l) / M_LN2);
1315 max_B_plus_X =
ojph_max(max_B_plus_X, B + X);
1317 max_B_plus_X =
ojph_max(max_B_plus_X, B + X);
1318 X = (
ui32) ceil(log(bibo_h * bibo_h) / M_LN2);
1320 max_B_plus_X =
ojph_max(max_B_plus_X, B + X);
1323 if (max_B_plus_X > 38)
1324 OJPH_ERROR(0x00050151,
"The specified combination of bit_depth, "
1325 "colour transform, and type of wavelet transform requires more than "
1326 "38 bits; it requires %d bits. This is beyond what is allowed in "
1327 "the JPEG2000 image coding format.", max_B_plus_X);
1330 Sqcd = (
ui8)(guard_bits << 5);
1334 for (
ui32 d = num_decomps; d > 0; --d)
1349 Sqcd = (
ui8)((guard_bits<<5)|0x2);
1352 float delta_b =
base_delta / (gain_l * gain_l);
1353 int exp = 0, mantissa;
1354 while (delta_b < 1.0f)
1355 { exp++; delta_b *= 2.0f; }
1358 mantissa = (int)round(delta_b * (
float)(1<<11)) - (1<<11);
1359 mantissa = mantissa < (1<<11) ? mantissa : 0x7FF;
1360 SPqcd.u16[s++] = (
ui16)((exp << 11) | mantissa);
1361 for (
ui32 d = num_decomps; d > 0; --d)
1368 int exp = 0, mantissa;
1369 while (delta_b < 1.0f)
1370 { exp++; delta_b *= 2.0f; }
1371 mantissa = (int)round(delta_b * (
float)(1<<11)) - (1<<11);
1372 mantissa = mantissa < (1<<11) ? mantissa : 0x7FF;
1373 SPqcd.u16[s++] = (
ui16)((exp << 11) | mantissa);
1374 SPqcd.u16[s++] = (
ui16)((exp << 11) | mantissa);
1380 { exp++; delta_b *= 2.0f; }
1381 mantissa = (int)round(delta_b * (
float)(1<<11)) - (1<<11);
1382 mantissa = mantissa < (1<<11) ? mantissa : 0x7FF;
1383 SPqcd.u16[s++] = (
ui16)((exp << 11) | mantissa);
1399 int irrev = p->
Sqcd & 0x1F;
1406 else if (irrev == 2)
1409 ui32 nb = num_decomps - (i ? (i - 1) / 3 : 0);
1424 ui32 num_decompositions,
ui32 comp_num,
1427 float arr[] = { 1.0f, 2.0f, 2.0f, 4.0f };
1428 if ((
Sqcd & 0x1F) != 2)
1429 OJPH_ERROR(0x00050101,
"There is something wrong in the configuration "
1430 "of the codestream; for component %d, the codestream defines an "
1431 "irreversible transform, for which the codestream provides a "
1432 "reversible (no quantization) step sizes in Sqcd/Sqcc.", comp_num);
1435 if (dfs != NULL && dfs->
exists())
1440 OJPH_INFO(0x00050101,
"Trying to access quantization step size for "
1441 "subband %d when the QCD/QCC marker segment specifies "
1442 "quantization step sizes for %d subbands only. To continue "
1443 "decoding, we are using the step size for subband %d, which can "
1444 "produce incorrect results",
1448 int eps =
SPqcd.u16[idx] >> 11;
1450 mantissa = (float)((
SPqcd.u16[idx] & 0x7FF) | 0x800) * arr[
subband];
1451 mantissa /= (float)(1 << 11);
1452 mantissa /= (float)(1u << eps);
1463 if (
main->is_employing_color_transform() &&
comp_idx < 3)
1465 for (
ui32 i = 0; i < 3; ++i) {
1478 return precision + 1 + 1;
1492 if (dfs != NULL && dfs->
exists())
1497 OJPH_INFO(0x00050111,
"Trying to access quantization step size for "
1498 "subband %d when the QCD/QCC marker segment specifies "
1499 "quantization step sizes for %d subbands only. To continue "
1500 "decoding, we are using the step size for subband %d, which can "
1501 "produce incorrect results",
1506 int irrev =
Sqcd & 0x1F;
1511 num_bits = num_bits == 0 ? 0 : num_bits - 1;
1513 else if (irrev == 1)
1515 else if (irrev == 2)
1516 num_bits = (
SPqcd.u16[idx] >> 11) - 1;
1526 int irrev =
Sqcd & 0x1F;
1532 num_bits =
ojph_max(num_bits, t == 0 ? 0 : t - 1);
1535 else if (irrev == 1)
1537 else if (irrev == 2)
1553 int irrev =
Sqcd & 0x1F;
1559 else if (irrev == 2)
1569 result &= file->
write(&buf, 2) == 2;
1571 result &= file->
write(&buf, 2) == 2;
1573 result &= file->
write(&buf, 1) == 1;
1579 result &= file->
write(&buf, 1) == 1;
1581 else if (irrev == 2)
1585 result &= file->
write(&buf, 2) == 2;
1611 int irrev =
Sqcd & 0x1F;
1614 Lqcd = (
ui16)(4 + (num_comps < 257 ? 0 : 1));
1617 else if (irrev == 2)
1627 result &= file->
write(&buf, 2) == 2;
1629 result &= file->
write(&buf, 2) == 2;
1630 if (num_comps < 257)
1633 result &= file->
write(&buf, 1) == 1;
1638 result &= file->
write(&buf, 2) == 2;
1641 result &= file->
write(&buf, 1) == 1;
1646 result &= file->
write(&buf, 1) == 1;
1648 else if (irrev == 2)
1652 result &= file->
write(&buf, 2) == 2;
1677 OJPH_ERROR(0x00050081,
"error reading QCD marker");
1680 OJPH_ERROR(0x00050082,
"error reading QCD marker");
1681 if ((
Sqcd & 0x1F) == 0)
1685 OJPH_ERROR(0x0005008A,
"QCD marker segment that specifies no "
1686 "quantization informtion");
1688 OJPH_ERROR(0x00050083,
"wrong Lqcd value of %d in QCD marker",
Lqcd);
1691 OJPH_ERROR(0x00050084,
"error reading QCD marker");
1693 else if ((
Sqcd & 0x1F) == 1)
1697 "Scalar derived quantization is not supported yet in QCD marker");
1699 OJPH_ERROR(0x00050085,
"wrong Lqcd value in QCD marker");
1701 else if ((
Sqcd & 0x1F) == 2)
1705 OJPH_ERROR(0x0005008B,
"QCD marker segment that specifies no "
1706 "quantization informtion");
1708 OJPH_ERROR(0x00050086,
"wrong Lqcd value of %d in QCD marker",
Lqcd);
1712 OJPH_ERROR(0x00050087,
"error reading QCD marker");
1717 OJPH_ERROR(0x00050088,
"wrong Sqcd value in QCD marker");
1724 OJPH_ERROR(0x000500A1,
"error reading QCC marker");
1726 if (num_comps < 257)
1729 if (file->
read(&v, 1) != 1)
1730 OJPH_ERROR(0x000500A2,
"error reading QCC marker");
1736 OJPH_ERROR(0x000500A3,
"error reading QCC marker");
1740 OJPH_ERROR(0x000500A4,
"error reading QCC marker");
1741 ui32 offset = num_comps < 257 ? 4 : 5;
1742 if ((
Sqcd & 0x1F) == 0)
1746 OJPH_ERROR(0x000500AC,
"QCC marker segment that specifies no "
1747 "quantization informtion");
1749 OJPH_ERROR(0x000500A5,
"wrong Lqcd value of %d in QCC marker",
Lqcd);
1752 OJPH_ERROR(0x000500A6,
"error reading QCC marker");
1754 else if ((
Sqcd & 0x1F) == 1)
1758 "Scalar derived quantization is not supported yet in QCC marker");
1760 OJPH_ERROR(0x000500A7,
"wrong Lqcc value in QCC marker");
1762 else if ((
Sqcd & 0x1F) == 2)
1766 OJPH_ERROR(0x000500AD,
"QCC marker segment that specifies no "
1767 "quantization informtion");
1769 OJPH_ERROR(0x000500A8,
"wrong Lqcc value of %d in QCC marker",
Lqcd);
1773 OJPH_ERROR(0x000500A9,
"error reading QCC marker");
1778 OJPH_ERROR(0x000500AA,
"wrong Sqcc value in QCC marker");
1809 while (p->
next != NULL)
1836 if (this->
enabled && this->
Tnlt == nonlinearity::OJPH_NLT_NO_NLT)
1840 this->
Tnlt == nonlinearity::OJPH_NLT_BINARY_COMPLEMENT_NLT)
1842 bool all_same =
true;
1850 bool is_signed =
false;
1851 for (
ui32 c = 0; c < num_comps; ++c)
1860 all_same = all_same && (is_signed == siz.
is_signed(c));
1876 if (all_same && bit_depth != 0)
1878 this->
BDnlt = (
ui8)(bit_depth - 1);
1884 for (
ui32 c = 0; c < num_comps; ++c)
1892 p->
Tnlt = nonlinearity::OJPH_NLT_BINARY_COMPLEMENT_NLT;
1902 for (
ui32 c = 0; c < num_comps; ++c)
1924 OJPH_ERROR(0x00050171,
"Nonliearities other than type 0 "
1925 "(No Nonlinearity) or type 3 (Binary Binary Complement to Sign "
1926 "Magnitude Conversion) are not supported yet");
1937 bool& is_signed,
ui8& nl_type)
const
1939 assert(
Cnlt == special_comp_num::ALL_COMPS);
1941 p = (p && p->
enabled) ? p :
this;
1944 bit_depth = (
ui8)((p->
BDnlt & 0x7F) + 1);
1945 bit_depth = bit_depth <= 38 ? bit_depth : 38;
1946 is_signed = (p->
BDnlt & 0x80) == 0x80;
1968 result &= file->
write(&buf, 2) == 2;
1970 result &= file->
write(&buf, 2) == 2;
1972 result &= file->
write(&buf, 2) == 2;
1974 result &= file->
write(&p->
Tnlt, 1) == 1;
1986 if (file->
read(buf, 6) != 6)
1987 OJPH_ERROR(0x00050141,
"error reading NLT marker segment");
1990 if (length != 6 || (buf[5] != 3 && buf[5] != 0))
1991 OJPH_ERROR(0x00050142,
"Unsupported NLT type %d\n", buf[5]);
2016 while (p && p->
Cnlt != comp_num)
2024 assert(comp_num != special_comp_num::ALL_COMPS);
2025 assert(
Cnlt == special_comp_num::ALL_COMPS);
2027 while (p->
next != NULL) {
2028 assert(p->
Cnlt != comp_num);
2049 while (p && p->
enabled ==
false)
2061 OJPH_INFO(0x00050161,
"The NLT marker segment for the "
2062 "non-existing component %d has been removed.", p->
Cnlt);
2083 this->
Psot = payload_len + 14;
2087 result &= file->
write(&buf, 2) == 2;
2089 result &= file->
write(&buf, 2) == 2;
2091 result &= file->
write(&buf, 2) == 2;
2093 result &= file->
write(&buf, 4) == 4;
2109 result &= file->
write(&buf, 2) == 2;
2111 result &= file->
write(&buf, 2) == 2;
2113 result &= file->
write(&buf, 2) == 2;
2115 result &= file->
write(&buf, 4) == 4;
2129 OJPH_INFO(0x00050091,
"error reading SOT marker");
2136 OJPH_INFO(0x00050092,
"error in SOT length");
2142 OJPH_INFO(0x00050093,
"error reading tile index");
2149 OJPH_INFO(0x00050094,
"tile index in SOT marker cannot be 0xFFFF");
2155 OJPH_INFO(0x00050095,
"error reading SOT marker");
2162 OJPH_INFO(0x00050096,
"error reading SOT marker");
2168 OJPH_INFO(0x00050097,
"error reading SOT marker");
2176 OJPH_ERROR(0x00050091,
"error reading SOT marker");
2179 OJPH_ERROR(0x00050092,
"error in SOT length");
2181 OJPH_ERROR(0x00050093,
"error reading SOT tile index");
2184 OJPH_ERROR(0x00050094,
"tile index in SOT marker cannot be 0xFFFF");
2186 OJPH_ERROR(0x00050095,
"error reading SOT marker");
2189 OJPH_ERROR(0x00050096,
"error reading SOT marker");
2191 OJPH_ERROR(0x00050097,
"error reading SOT marker");
2208 OJPH_ERROR(0x000500B1,
"Trying to allocate more than 65535 bytes for "
2209 "a TLM marker; this can be resolved by having more than "
2210 "one TLM marker, but the code does not support this. "
2211 "In any case, this limit means that we have 10922 "
2212 "tileparts or more, which is a huge number.");
2238 result &= file->
write(&buf, 2) == 2;
2240 result &= file->
write(&buf, 2) == 2;
2246 result &= file->
write(&buf, 2) == 2;
2248 result &= file->
write(&buf, 4) == 4;
2265 while (p && p->
Sdfs != index)
2274 ui32 d = decomp_level - 1;
2276 ui32 bits = d & 0x3;
2277 ui32 val = (
Ddfs[idx] >> (6 - 2 * bits)) & 0x3;
2288 ui32 ns[4] = { 0, 3, 1, 1 };
2310 ui32 decomp_level = 1;
2311 while (skipped_resolutions > 0)
2315 { factor.
x *= 2; factor.
y *= 2; }
2322 --skipped_resolutions;
2332 while (p->
next != NULL)
2343 return p->
read(file);
2347 OJPH_ERROR(0x000500D1,
"error reading DFS-Ldfs parameter");
2350 OJPH_ERROR(0x000500D2,
"error reading DFS-Sdfs parameter");
2353 OJPH_ERROR(0x000500D3,
"The DFS-Sdfs parameter is %d, which is "
2354 "larger than the permissible 15",
Sdfs);
2356 if (file->
read(&l_Ids, 1) != 1)
2357 OJPH_ERROR(0x000500D4,
"error reading DFS-Ids parameter");
2358 constexpr int max_Ddfs =
sizeof(
Ddfs) * 4;
2359 if (l_Ids > max_Ddfs)
2360 OJPH_INFO(0x000500D5,
"The DFS-Ids parameter is %d; while this is "
2361 "valid, the number is unnessarily large -- you do not need more "
2362 "than %d. Please contact me regarding this issue.",
2364 Ids = l_Ids < max_Ddfs ? l_Ids : max_Ddfs;
2365 for (
int i = 0; i <
Ids; i += 4)
2366 if (file->
read(&
Ddfs[i / 4], 1) != 1)
2367 OJPH_ERROR(0x000500D6,
"error reading DFS-Ddfs parameters");
2368 for (
int i =
Ids; i < l_Ids; i += 4)
2369 if (file->
read(&t, 1) != 1)
2370 OJPH_ERROR(0x000500D7,
"error reading DFS-Ddfs parameters");
2393 if (index == 0) { this->
init_irv97();
return this; }
2394 else if (index == 1) { this->
init_rev53();
return this; }
2401 if (p == NULL && (index == 0 || index == 1))
2408 else if (index == 1)
2419 if (coeff_type == 0) {
2421 if (file->
read(&v, 1) != 1)
return false;
2425 else if (coeff_type == 1) {
2427 if (file->
read(&v, 2) != 2)
return false;
2431 else if (coeff_type == 2) {
2436 if (file->
read(&v.i, 4) != 4)
return false;
2441 else if (coeff_type == 3) {
2446 if (file->
read(&v.i, 8) != 8)
return false;
2451 else if (coeff_type == 4) {
2453 if (file->
read(&v, 8) != 8)
return false;
2455 if (file->
read(&v1, 8) != 8)
return false;
2466 si32 e = (
si32)((v >> 48) & 0x7FFF);
2472 s.i |= ((
ui32)(v >> 32) & 0x80000000);
2474 s.i |= (
ui32)((v >> 25) & 0x007FFFFF);
2485 if (coeff_type == 0) {
2487 if (file->
read(&v, 1) != 1)
return false;
2491 else if (coeff_type == 1) {
2493 if (file->
read(&v, 2) != 2)
return false;
2509 OJPH_ERROR(0x000500E1,
"error reading ATK-Latk parameter");
2513 if (file->
read(&temp_Satk, 2) != 2)
2514 OJPH_ERROR(0x000500E2,
"error reading ATK-Satk parameter");
2517 int tmp_idx = temp_Satk & 0xFF;
2519 || tmp_idx == 0 || tmp_idx == 1)
2520 OJPH_ERROR(0x000500F3,
"ATK-Satk parameter sets ATK marker index to "
2521 "the illegal value of %d. ATK-Satk should be in (2-255) and, I "
2522 "believe, must not be repeated; otherwise, it would be unclear "
2523 "what marker segment must be employed when an index is repeated.",
2527 OJPH_ERROR(0x000500E3,
"ATK-Satk parameter sets m_init to 1, "
2528 "requiring odd-indexed subsequence in first reconstruction step, "
2529 "which is not supported yet.");
2531 OJPH_ERROR(0x000500E4,
"ATK-Satk parameter specified ARB filter, "
2532 "which is not supported yet.");
2534 OJPH_ERROR(0x000500E5,
"ATK-Satk parameter does not make sense. "
2535 "It employs floats with reversible filtering.");
2537 OJPH_ERROR(0x000500E6,
"ATK-Satk parameter requires constant "
2538 "boundary extension, which is not supported yet.");
2541 OJPH_ERROR(0x000500E7,
"error reading ATK-Katk parameter");
2543 OJPH_ERROR(0x000500E8,
"error reading ATK-Natk parameter");
2554 for (
int s = 0; s <
Natk; ++s)
2556 if (file->
read(&
d[s].rev.Eatk, 1) != 1)
2557 OJPH_ERROR(0x000500E9,
"error reading ATK-Eatk parameter");
2559 if (file->
read(&
d[s].rev.Batk, 2) != 2)
2560 OJPH_ERROR(0x000500EA,
"error reading ATK-Batk parameter");
2564 if (file->
read(&LCatk, 1) != 1)
2565 OJPH_ERROR(0x000500EB,
"error reading ATK-LCatk parameter");
2568 OJPH_ERROR(0x000500EC,
"Encountered a ATK-LCatk value of zero; "
2569 "something is wrong.");
2571 OJPH_ERROR(0x000500ED,
"ATK-LCatk value greater than 1; "
2572 "that is, a multitap filter is not supported");
2574 OJPH_ERROR(0x000500EE,
"Error reding ATK-Aatk parameter");
2579 for (
int s = 0; s <
Natk; ++s)
2582 if (file->
read(&LCatk, 1) != 1)
2583 OJPH_ERROR(0x000500EF,
"error reading ATK-LCatk parameter");
2586 OJPH_ERROR(0x000500F0,
"Encountered a ATK-LCatk value of zero; "
2587 "something is wrong.");
2589 OJPH_ERROR(0x000500F1,
"ATK-LCatk value greater than 1; "
2590 "that is, a multitap filter is not supported.");
2592 OJPH_ERROR(0x000500F2,
"Error reding ATK-Aatk parameter");
2596 OJPH_ERROR(0x000500F3,
"The length of an ATK marker segment "
2597 "(ATK-Latk) is not correct");
2606 Katk = (float)1.230174104914001;
2610 d[0].irv.Aatk = (float)0.443506852043971;
2611 d[1].irv.Aatk = (float)0.882911075530934;
2612 d[2].irv.Aatk = (float)-0.052980118572961;
2613 d[3].irv.Aatk = (float)-1.586134342059924;
2636 while (p->
next != NULL)
virtual size_t read(void *ptr, size_t size)=0
static const float gain_5x3_l[34]
static float get_bibo_gain_l(ui32 num_decomp, bool reversible)
static const float gain_5x3_h[34]
static float get_bibo_gain_h(ui32 num_decomp, bool reversible)
static const float gain_9x7_h[34]
static const float gain_9x7_l[34]
static const float gain_5x3_l[34]
static const float gain_5x3_h[34]
static float get_gain_l(ui32 num_decomp, bool reversible)
static const float gain_9x7_l[34]
static float get_gain_h(ui32 num_decomp, bool reversible)
static const float gain_9x7_h[34]
virtual size_t write(const void *ptr, size_t size)=0
bool is_reversible() const
void set_precinct_size(int num_levels, size *precinct_size)
size get_block_dims() const
void set_reversible(bool reversible)
size get_precinct_size(ui32 level_num) const
ui32 get_num_decompositions() const
size get_log_block_dims() const
size get_log_precinct_size(ui32 level_num) const
void set_num_decomposition(ui32 num_decompositions)
bool get_block_vertical_causality() const
void set_block_dims(ui32 width, ui32 height)
size get_block_dims() const
int get_progression_order() const
bool is_using_color_transform() const
param_coc get_coc(ui32 component_idx)
void set_num_decomposition(ui32 num_decompositions)
ui32 get_num_decompositions() const
size get_log_block_dims() const
bool packets_may_use_sop() const
size get_precinct_size(ui32 level_num) const
const char * get_progression_order_as_string() const
void set_precinct_size(int num_levels, size *precinct_size)
bool packets_use_eph() const
bool is_reversible() const
void set_progression_order(const char *name)
bool get_block_vertical_causality() const
void set_block_dims(ui32 width, ui32 height)
size get_log_precinct_size(ui32 level_num) const
int get_num_layers() const
void set_color_transform(bool color_transform)
void set_reversible(bool reversible)
@ OJPH_NLT_BINARY_COMPLEMENT_NLT
bool get_nonlinear_transform(ui32 comp_num, ui8 &bit_depth, bool &is_signed, ui8 &nl_type) const
get the nonlinearity type associated with comp_num, which should be one from enum nonlinearity
void set_nonlinear_transform(ui32 comp_num, ui8 nl_type)
enables or disables type 3 nonlinearity for a component or the default setting
void set_irrev_quant(float delta)
Set the irreversible quantization base delta.
void set_tile_size(size s)
point get_image_extent() const
void set_component(ui32 comp_num, const point &downsampling, ui32 bit_depth, bool is_signed)
void set_num_components(ui32 num_comps)
ui32 get_bit_depth(ui32 comp_num) const
void set_tile_offset(point offset)
point get_image_offset() const
void set_image_offset(point offset)
size get_tile_size() const
ui32 get_recon_height(ui32 comp_num) const
point get_downsampling(ui32 comp_num) const
void set_image_extent(point extent)
point get_tile_offset() const
ui32 get_recon_width(ui32 comp_num) const
bool is_signed(ui32 comp_num) const
ui32 get_num_components() const
static ui16 swap_byte(ui16 t)
const char OJPH_PO_STRING_PCRL[]
static ui32 population_count(ui32 val)
const char OJPH_PO_STRING_RLCP[]
const char OJPH_PO_STRING_RPCL[]
const char OJPH_PO_STRING_CPRL[]
static ui32 count_leading_zeros(ui32 val)
const char OJPH_PO_STRING_LRCP[]
int main(int argc, char *argv[])
#define ojph_div_ceil(a, b)
#define OJPH_INFO(t,...)
MACROs to insert file and line number for info, warning, and error.
#define OJPH_ERROR(t,...)
bool read_coefficient(infile_base *file, float &K, si32 &bytes)
void init(param_atk *top_atk)
bool is_reversible() const
bool read(infile_base *file)
int get_coeff_type() const
param_atk * get_atk(int index)
bool is_whole_sample() const
bool is_using_ws_extension() const
void read(infile_base *file)
bool write(outfile_base *file)
bool write(outfile_base *file)
const param_cod * get_coc(ui32 comp_idx) const
bool internal_write_coc(outfile_base *file, ui32 num_comps)
ui16 get_dfs_index() const
bool write_coc(outfile_base *file, ui32 num_comps)
bool is_employing_color_transform() const
ui32 get_comp_idx() const
void read(infile_base *file)
void init(param_cod *top_cod, ui16 comp_idx)
void read_coc(infile_base *file, ui32 num_comps, param_cod *top_cod)
void update_atk(param_atk *atk)
bool is_dfs_defined() const
ui8 get_num_decompositions() const
bool is_reversible() const
param_cod(param_cod *top_cod=NULL, ui16 comp_idx=OJPH_COD_DEFAULT)
ui8 get_wavelet_kern() const
param_cod * add_coc_object(ui32 comp_idx)
bool read(infile_base *file)
dfs_dwt_type get_dwt_type(ui32 decomp_level) const
point get_res_downsamp(ui32 skipped_resolutions) const
ui32 get_subband_idx(ui32 num_decompositions, ui32 resolution, ui32 subband) const
const param_dfs * get_dfs(int index) const
bool write(outfile_base *file) const
param_nlt * add_object(ui32 comp_num)
void trim_non_existing_components(ui32 num_comps)
void read(infile_base *file)
ojph::param_nlt::nonlinearity nonlinearity
bool get_nonlinear_transform(ui32 comp_num, ui8 &bit_depth, bool &is_signed, ui8 &nl_type) const
const param_nlt * get_nlt_object(ui32 comp_num) const
void check_validity(param_siz &siz)
bool is_any_enabled() const
void set_nonlinear_transform(ui32 comp_num, ui8 nl_type)
ui8 encode_SPqcd(ui8 v) const
bool write_qcc(outfile_base *file, ui32 num_comps)
float get_irrev_delta(const param_dfs *dfs, ui32 num_decompositions, ui32 comp_num, ui32 resolution, ui32 subband) const
void set_rev_quant(ui32 num_decomps, ui32 bit_depth, bool is_employing_color_transform)
void set_irrev_quant(ui32 num_decomps)
ui32 get_largest_Kmax() const
ui32 get_num_guard_bits() const
void set_delta(float delta)
void read_qcc(infile_base *file, ui32 num_comps)
void check_validity(const param_siz &siz, const param_cod &cod)
bool write(outfile_base *file)
ui32 propose_precision(const param_cod *cod) const
void read(infile_base *file)
void init(param_qcd *top_qcd, ui16 comp_idx)
param_qcd * add_qcc_object(ui32 comp_idx)
ui32 get_Kmax(const param_dfs *dfs, ui32 num_decompositions, ui32 resolution, ui32 subband) const
ui8 decode_SPqcd(ui8 v) const
param_qcd * get_qcc(ui32 comp_idx)
param_qcd(param_qcd *top_qcd=NULL, ui16 comp_idx=OJPH_QCD_DEFAULT)
void trim_non_existing_components(ui32 num_comps)
bool internal_write_qcc(outfile_base *file, ui32 num_comps)
union ojph::local::param_qcd::@140013103227173134364232343330020031205064137337 SPqcd
ui32 get_bit_depth(ui32 comp_num) const
bool ws_kern_support_needed
bool is_signed(ui32 comp_num) const
void set_image_offset(point offset)
bool write(outfile_base *file)
ui16 get_num_components() const
void set_tile_size(size s)
point get_recon_downsampling(ui32 comp_num) const
void set_Rsiz_flag(ui16 flag)
point get_recon_size(ui32 comp_num) const
void set_tile_offset(point offset)
void read(infile_base *file)
void set_num_components(ui32 num_comps)
bool read(infile_base *file, bool resilient)
bool write(outfile_base *file, ui32 payload_len)
void set_next_pair(ui16 Ttlm, ui32 Ptlm)
bool write(outfile_base *file)
void init(ui32 num_pairs, Ttlm_Ptlm_pair *store)