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

[pcl::io::loadPCDFile] The issue of thread stopping #6209

Open
sharknow opened this issue Jan 2, 2025 · 7 comments
Open

[pcl::io::loadPCDFile] The issue of thread stopping #6209

sharknow opened this issue Jan 2, 2025 · 7 comments
Labels

Comments

@sharknow
Copy link

sharknow commented Jan 2, 2025

Occasionally, there may be thread jamming issues when reading a PCD file.

The following is the stack information when the thread stops:
#0 0x0000ffff98218b44 in std::istream::sentry::sentry(std::istream&, bool) () from /lib/aarch64-linux-gnu/libstdc++.so.6
#1 0x0000ffff981c4420 in std::basic_istream<char, std::char_traits >& std::getline<char, std::char_traits, std::allocator >(std::basic_istream<char, std::char_traits >&, std::__cxx11::basic_string<char, std::char_traits, std::allocator >&, char) () from /lib/aarch64-linux-gnu/libstdc++.so.6
#2 0x0000ffff742e1798 in pcl::PCDReader::readHeader(std::istream&, pcl::PCLPointCloud2&, Eigen::Matrix<float, 4, 1, 0, 4, 1>&, Eigen::Quaternion<float, 0>&, int&, int&, unsigned int&) () from /lib/aarch64-linux-gnu/libpcl_io.so.1.10
#3 0x0000ffff742e31a4 in pcl::PCDReader::readHeader(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const&, pcl::PCLPointCloud2&, Eigen::Matrix<float, 4, 1, 0, 4, 1>&, Eigen::Quaternion<float, 0>&, int&, int&, unsigned int&, int) () from /lib/aarch64-linux-gnu/libpcl_io.so.1.10
#4 0x0000ffff742e0ea8 in pcl::PCDReader::read(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const&, pcl::PCLPointCloud2&, Eigen::Matrix<float, 4, 1, 0, 4, 1>&, Eigen::Quaternion<float, 0>&, int&, int) () from /lib/aarch64-linux-gnu/libpcl_io.so.1.10
#7 0x0000ffff981d7f9c in ?? () from /lib/aarch64-linux-gnu/libstdc++.so.6
#8 0x0000ffff98c51624 in start_thread () from /lib/aarch64-linux-gnu/libpthread.so.0
#9 0x0000ffff9804562c in ?? () from /lib/aarch64-linux-gnu/libc.so.6

@sharknow sharknow added kind: bug Type of issue status: triage Labels incomplete labels Jan 2, 2025
@mvieth mvieth added module: io and removed status: triage Labels incomplete labels Jan 2, 2025
@mvieth
Copy link
Member

mvieth commented Jan 2, 2025

@sharknow Does this always happen when you try to load a specific PCD file? If yes, please upload that file (zipped). In addition to the stack information you posted, is there anything else printed? An error message, or an exception? Do you try to load PCD files in parallel? Please show the relevant part of your code (where the error happens).

@sharknow
Copy link
Author

sharknow commented Jan 2, 2025

@sharknow Does this always happen when you try to load a specific PCD file? If yes, please upload that file (zipped). In addition to the stack information you posted, is there anything else printed? An error message, or an exception? Do you try to load PCD files in parallel? Please show the relevant part of your code (where the error happens).

It doesn't always happen, using the same PCD file, the next load will be normal.

There is no other stack information, the phenomenon is that this thread is stuck, and its CPU usage is 99%, which has been like this all along.

I did not attempt to load the PCD file in parallel, but I can give it a try next.

The relevant code is shown below:

pcl::PointCloud<pcl::PointXYZ>::Ptr load_points(new pcl::PointCloud<pcl::PointXYZ>());

for (const auto& pcd_path : pcd_file_list) {
  pcl::PointCloud<pcl::PointXYZ>::Ptr points_in(new pcl::PointCloud<pcl::PointXYZ>());

  if (pcl::io::loadPCDFile<pcl::PointXYZ>(pcd_path, *points_in) != 0) {
    break;
  }
  *load_points = (*load_points) + (*points_in);
}

@sharknow
Copy link
Author

sharknow commented Jan 2, 2025

@sharknow Does this always happen when you try to load a specific PCD file? If yes, please upload that file (zipped). In addition to the stack information you posted, is there anything else printed? An error message, or an exception? Do you try to load PCD files in parallel? Please show the relevant part of your code (where the error happens).

It doesn't always happen, using the same PCD file, the next load will be normal.

There is no other stack information, the phenomenon is that this thread is stuck, and its CPU usage is 99%, which has been like this all along.

I did not attempt to load the PCD file in parallel, but I can give it a try next.

The relevant code is shown below:

pcl::PointCloud<pcl::PointXYZ>::Ptr load_points(new pcl::PointCloud<pcl::PointXYZ>());

for (const auto& pcd_path : pcd_file_list) {
  pcl::PointCloud<pcl::PointXYZ>::Ptr points_in(new pcl::PointCloud<pcl::PointXYZ>());

  if (pcl::io::loadPCDFile<pcl::PointXYZ>(pcd_path, *points_in) != 0) {
    break;
  }
  *load_points = (*load_points) + (*points_in);
}

At that time, the computer's memory usage was also at a normal level

@sharknow sharknow closed this as completed Jan 2, 2025
@sharknow sharknow reopened this Jan 2, 2025
@mvieth
Copy link
Member

mvieth commented Jan 2, 2025

It doesn't always happen, using the same PCD file, the next load will be normal.

Still, please upload a PCD file (zipped) where the error has happened so that I can inspect it and try to reproduce the problem on my computer.
Which OS do you use, and which compiler (version)? Which PCL version exactly?
What I did not understand yet: does the program end/crash on its own, or do you terminate it (e.g. with Ctrl+C) because it is stuck in an endless loop?

@sharknow
Copy link
Author

sharknow commented Jan 3, 2025

pcd_file.zip

I am using a Linux system.

pcl: 1.10.

compiler (version): gcc 9.4.0

The program was terminated by me, and if I don't terminate it, it will keep getting stuck. The CPU usage rate has always been around 98%.

@mvieth
Copy link
Member

mvieth commented Jan 3, 2025

I am using a Linux system.

Which kind? Ubuntu, or Debian, or something else? Which version?

pcl: 1.10.

PCL 1.10.0 or PCL 1.10.1?
I assume you installed PCL via a package manager? Can you instead build the same version from source, in debug mode (CMAKE_BUILD_TYPE=Debug), and post another stack print? I am hoping to see in which lines in sentry the program is stuck.

Can you say how many PCD files are successfully loaded, before the program gets stuck?

I did not attempt to load the PCD file in parallel, but I can give it a try next.

No need to try that if the program did not do that before. But are you using multiple threads in your program? I am asking because I saw start_thread in the stack information, and I am wondering if that could be related to the problem.

Also, what kind of computer do you use? Is it a Raspberry Pi by chance? If yes, which model? I found this which might be related: https://forums.raspberrypi.com/viewtopic.php?t=281333

@sharknow
Copy link
Author

sharknow commented Jan 6, 2025

I am using a Linux system.

Which kind? Ubuntu, or Debian, or something else? Which version?

pcl: 1.10.

PCL 1.10.0 or PCL 1.10.1? I assume you installed PCL via a package manager? Can you instead build the same version from source, in debug mode (CMAKE_BUILD_TYPE=Debug), and post another stack print? I am hoping to see in which lines in sentry the program is stuck.

Can you say how many PCD files are successfully loaded, before the program gets stuck?

I did not attempt to load the PCD file in parallel, but I can give it a try next.

No need to try that if the program did not do that before. But are you using multiple threads in your program? I am asking because I saw start_thread in the stack information, and I am wondering if that could be related to the problem.

Also, what kind of computer do you use? Is it a Raspberry Pi by chance? If yes, which model? I found this which might be related: https://forums.raspberrypi.com/viewtopic.php?t=281333

Thank you very much for your reply!

Linux Ubuntu system.

pcl: 1.10.0

I have created a separate thread to load the map, which is executed approximately every minute. Approximately 40 pcd files are loaded each time. Sometimes it gets stuck when loading to the 10th file, and sometimes it gets stuck when loading to the 7th file. But what I can confirm is that these PCD files are normal, and when I restart the program, I can successfully load these map files. The frequency of these issues is not high, and the program runs every day, with one or two blocking problems occurring every day. When the program starts running in the morning, it usually doesn't have any problems. After running for about 3 or 5 hours, it will have problems, which makes me feel very strange.

Computer: NVIDIA Orin NX Developer Kit

Operating System: Ubuntu 20.04.5 LTS
Kernel: Linux 5.10.104-tegra
Architecture: arm64

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants