Reduced memory fragmentation (#464)

* Update README.md (#2)

Proposed changes for #431

* Added support for setting number of processes for opensfm.

* Where possible allocate vectors of the correct size to prevent memory fragmentation.

* Reset README.md to master

* Reset README.md to master

* Removed un-needed for loop


Former-commit-id: 7162bb3606
pull/1161/head
pulquero 2017-02-21 16:14:16 +00:00 zatwierdzone przez Dakota Benjamin
rodzic 675a84ac9f
commit d8abe65d29
2 zmienionych plików z 9 dodań i 3 usunięć

Wyświetl plik

@ -1500,6 +1500,7 @@ bool Georef::loadObjFile(std::string inputFile, pcl::TextureMesh &mesh)
if (vt_idx != v_idx) if (vt_idx != v_idx)
{ {
std::vector<Eigen::Vector2f> texcoordinates = std::vector<Eigen::Vector2f>(0); std::vector<Eigen::Vector2f> texcoordinates = std::vector<Eigen::Vector2f>(0);
texcoordinates.reserve(3*f_idx);
for (size_t faceIndex = 0; faceIndex < f_idx; ++faceIndex) for (size_t faceIndex = 0; faceIndex < f_idx; ++faceIndex)
{ {

Wyświetl plik

@ -395,6 +395,12 @@ void OdmOrthoPhoto::createOrthoPhoto()
std::vector<Eigen::Vector2f> textureCoordinates = std::vector<Eigen::Vector2f>(0); std::vector<Eigen::Vector2f> textureCoordinates = std::vector<Eigen::Vector2f>(0);
size_t vertexIndexCount = 0; size_t vertexIndexCount = 0;
for(size_t t = 0; t < mesh.tex_polygons.size(); ++t)
{
vertexIndexCount += 3 * mesh.tex_polygons[t].size();
}
textureCoordinates.reserve(vertexIndexCount);
for(size_t t = 0; t < mesh.tex_polygons.size(); ++t) for(size_t t = 0; t < mesh.tex_polygons.size(); ++t)
{ {
@ -419,17 +425,14 @@ void OdmOrthoPhoto::createOrthoPhoto()
meshCloudSplit->points.push_back(v1); meshCloudSplit->points.push_back(v1);
textureCoordinates.push_back(vt1); textureCoordinates.push_back(vt1);
mesh.tex_polygons[t][faceIndex].vertices[0] = vertexIndexCount; mesh.tex_polygons[t][faceIndex].vertices[0] = vertexIndexCount;
++vertexIndexCount;
meshCloudSplit->points.push_back(v2); meshCloudSplit->points.push_back(v2);
textureCoordinates.push_back(vt2); textureCoordinates.push_back(vt2);
mesh.tex_polygons[t][faceIndex].vertices[1] = vertexIndexCount; mesh.tex_polygons[t][faceIndex].vertices[1] = vertexIndexCount;
++vertexIndexCount;
meshCloudSplit->points.push_back(v3); meshCloudSplit->points.push_back(v3);
textureCoordinates.push_back(vt3); textureCoordinates.push_back(vt3);
mesh.tex_polygons[t][faceIndex].vertices[2] = vertexIndexCount; mesh.tex_polygons[t][faceIndex].vertices[2] = vertexIndexCount;
++vertexIndexCount;
} }
} }
@ -450,6 +453,7 @@ void OdmOrthoPhoto::createOrthoPhoto()
// Flatten texture coordinates. // Flatten texture coordinates.
std::vector<Eigen::Vector2f> uvs; std::vector<Eigen::Vector2f> uvs;
uvs.reserve(mesh.tex_coordinates.size());
for(size_t t = 0; t < mesh.tex_coordinates.size(); ++t) for(size_t t = 0; t < mesh.tex_coordinates.size(); ++t)
{ {
uvs.insert(uvs.end(), mesh.tex_coordinates[t].begin(), mesh.tex_coordinates[t].end()); uvs.insert(uvs.end(), mesh.tex_coordinates[t].begin(), mesh.tex_coordinates[t].end());
@ -1240,6 +1244,7 @@ bool OdmOrthoPhoto::loadObjFile(std::string inputFile, pcl::TextureMesh &mesh)
if (vt_idx != v_idx) if (vt_idx != v_idx)
{ {
std::vector<Eigen::Vector2f> texcoordinates = std::vector<Eigen::Vector2f>(0); std::vector<Eigen::Vector2f> texcoordinates = std::vector<Eigen::Vector2f>(0);
texcoordinates.reserve(3*f_idx);
for (size_t faceIndex = 0; faceIndex < f_idx; ++faceIndex) for (size_t faceIndex = 0; faceIndex < f_idx; ++faceIndex)
{ {