Appendix D. Known issues#
Overall known issues#
Warnings during the compilation of user code that utilizes the SDK libraries#
For example:
warning: 'fsdk::IQualityEstimator' has virtual functions but non-virtual destructor [-Wnon-virtual-dtor]
struct IQualityEstimator : IRefCounted {
This is a normal and expected behavior. For details, see Core Concepts - Reference Counted Interface.
Premature end of JPEG file#
Sometimes you can meet such a log:
[Error] [Image] FreeImage error: format=1, msg=Premature end of JPEG file.
This issue occurs if your JPEG file was not previously recorded or saved properly. You can find more information on this error on the Internet. Fortunately, this error is not fatal and you can continue working with the image and get valid detection, landmarks and warped image. You can also try to re-save this image.
SDK stuck when run sdk algorithm in separate process after root FaceEngine object initialized#
For example:
void simpleDetect(const fsdk::Image& image, const fsdk::IDetectorPtr& faceDetector) {
fsdk::ResultValue<fsdk::FSDKError, fsdk::Face> result = faceDetector->detectOne(
image,
image.getRect(),
fsdk::DetectionType::DT_BBOX
);
}
int main()
{
auto resFaceEngine = fsdk::createFaceEngine("./data");
fsdk::IFaceEnginePtr faceEngine = resFaceEngine.getValue();
fsdk::ILicense* license = faceEngine->getLicense();
fsdk::activateLicense(license, "./data/license.conf");
fsdk::Image image;
const string imagePath {"image_720.jpg"};
image.load(imagePath.c_str(), fsdk::Format::R8G8B8);
auto detRes = faceEngine->createDetector(fsdk::FACE_DET_V3);
fsdk::IDetectorPtr faceDetector = detRes.getValue();
// Run detection in separate process
pid_t ch_pid = fork();
if (ch_pid == -1) {
perror("fork");
exit(EXIT_FAILURE);
} else if (ch_pid > 0) {
cout << "spawn child with pid - " << ch_pid << endl;
} else {
simpleDetect(image, faceDetector);
}
pid_t child_pid;
while ((child_pid = wait(nullptr)) > 0)
cout << "child " << child_pid << " terminated" << endl;
return 0;
}
Undefined behaviour with multithreaded usage of the FaceEngine and algorithms#
Creation and destroying Luna SDK algorithms from the different threads is prohibited due to internal implementation restrictions. In such case undefined behaviour is possible - segmentation faults or invalid results. More reading in Best practices
Floating point exceptions when working with images that have GPU memory residence#
If you're getting floating point exceptions when using images with GPU memory residence please make sure that Luna SDK runtime has been initialised with at least 2 worker threads. For more info about runtime configuration please refer to Runtime settings chapter in ConfigurationGuide handbook.
Coordinate differences for batched detections#
It is possible to obtain some small differences in detected image boxes and landmarks for different placement of images within batches, when the sizes of different images are close to each other. This note is correct for all detector types, including face detectors, human detectors, face+human detectors etc.
CentOS 8 known issues#
Archive unpacking#
We have detected such behavior on CentOS 8.
unzip *.zip;
error: invalid zip file with overlapped components (possible zip bomb)
while unpacking archives.
The bug is caused by unzip-6.0-45.el8
package. We recommend to downgrade it:
rpm -q unzip-6.0-45.el8 && yum remove unzip && yum install unzip-6.0-44.el8
Possible content of test.xcent
:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.security.get-task-allow</key>
<true/>
</dict>
</plist>