Skip to content

Commit

Permalink
support empty flash enumeration
Browse files Browse the repository at this point in the history
  • Loading branch information
Nir-Az committed Nov 13, 2024
1 parent 31f3252 commit 40a90a8
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 11 deletions.
14 changes: 12 additions & 2 deletions src/ds/d500/d500-device.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -286,8 +286,18 @@ namespace librealsense
float d500_device::get_stereo_baseline_mm() const // to be d500 adapted
{
using namespace ds;
auto table = check_calib<d500_coefficients_table>(*_coefficients_table_raw);
return fabs(table->baseline);
float baseline = 100.0f; // so we will have a non zero value if cannot read from table
try
{
auto table = check_calib<d500_coefficients_table>(*_coefficients_table_raw);
baseline = fabs(table->baseline);
}
catch( const std::exception &e )
{
LOG_ERROR("Failed reading stereo baseline, using a default value --> " << e.what() );
}

return baseline;
}

std::vector<uint8_t> d500_device::get_d500_raw_calibration_table(ds::d500_calibration_table_id table_id) const // to be d500 adapted
Expand Down
32 changes: 23 additions & 9 deletions src/ds/d500/d500-private.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,18 +43,32 @@ namespace librealsense
rs2_intrinsics get_d500_intrinsic_by_resolution(const vector<uint8_t>& raw_data, d500_calibration_table_id table_id,
uint32_t width, uint32_t height, bool is_symmetrization_enabled)
{
switch (table_id)
{
case d500_calibration_table_id::depth_calibration_id:

if (!raw_data.empty())
{
return get_d500_depth_intrinsic_by_resolution(raw_data, width, height, is_symmetrization_enabled);
switch (table_id)
{
case d500_calibration_table_id::depth_calibration_id:
{
return get_d500_depth_intrinsic_by_resolution(raw_data, width, height, is_symmetrization_enabled);
}
case d500_calibration_table_id::rgb_calibration_id:
{
return get_d500_color_intrinsic_by_resolution(raw_data, width, height);
}
default:
throw invalid_value_exception(rsutils::string::from() << "Parsing Calibration table type " << static_cast<int>(table_id) << " is not supported");
}
}
case d500_calibration_table_id::rgb_calibration_id:
else // In case we got an empty table we will run with default values
{
return get_d500_color_intrinsic_by_resolution(raw_data, width, height);
}
default:
throw invalid_value_exception(rsutils::string::from() << "Parsing Calibration table type " << static_cast<int>(table_id) << " is not supported");
LOG_ERROR("cannot read intrinsic values, setting defaults");
rs2_intrinsics intrinsics = {0};
intrinsics.height = height;
intrinsics.width = width;
intrinsics.ppx = intrinsics.fx = width / 2.f;
intrinsics.ppy = intrinsics.fy = height / 2.f;
return intrinsics;
}
}

Expand Down

0 comments on commit 40a90a8

Please sign in to comment.