Problem using minboundquad function to create a minimum bounding quadrilateral for a given pointset

3 vues (au cours des 30 derniers jours)
I had modified one line in the minboundquad.m function to remove the collinear edges in the pointset.
from
edges = convhull(x,y);
to
edges = convhull(x,y,'Simplify',true);
The main code is
load points2.txt
x = points2(:,1);
y = points2(:,2);
[qx,qy] = minboundquad(x,y)
Result I got is below.
This is the output
There is some error I could not find out. Can someone help me solve this?

Réponse acceptée

Gowtham HariHara
Gowtham HariHara le 26 Mai 2021
Modifying the line in minboundquad.m from
if ( A_i < quadarea)
to
if (( A_i < quadarea)&& all(abs([qxi qyi]) < 1e15))
resolves the issue.
Thanks to @Michael Sapper for this suggestion(found in comment section of this toolbox)

Plus de réponses (1)

Shiva Kalyan Diwakaruni
Shiva Kalyan Diwakaruni le 26 Mai 2021
Hi,
I did not seem to find any error while reproducing and I got the below result after changing minboundquad.m
from
edges = convhull(x,y);
to
edges = convhull(x,y,'Simplify',true);
I got the Warning: Matrix is close to singular or badly scaled. Results may be inaccurate.
Can You explain what your error was?
  2 commentaires
Gowtham HariHara
Gowtham HariHara le 26 Mai 2021
Modifié(e) : Gowtham HariHara le 26 Mai 2021
@Shiva Kalyan Diwakaruni Thank you for your time.
There is no quadrilateral formed. Outcome of this function should be four vertices of a quadrilateral.
Gowtham HariHara
Gowtham HariHara le 26 Mai 2021
@Shiva Kalyan Diwakaruni Do you want to see the expected outcome of this function ?
This function worked for one of the less complex pointset. If you would like to see the result for a working pointset, I can show a screenshot.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Sequence and Numeric Feature Data Workflows dans Help Center et File Exchange

Produits


Version

R2018b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by