How to scale a polygon such that all the points lie within the original polygon?
$begingroup$
With a convex shape, like a circle, we can create a set of similar shapes, all contained within one another, by centering the shape at the origin and scaling it.
So we can get the following:
With a concave shape however, cetnering it at its centroid and scaling won't keep the points inside the original polygon, we would get something like this:
(Diagram was made by hand so this may not be the mathematical result, but it illustrates the point)
My goal is to be able to deform the original polygon such that the result converges to a single point contained in the original polygon, and every new ring is fully contained in the previous ring, as in this image:
How can this be done?
EDIT:
Maintaining the topology in new rings isn't necessary as long as the number of points doesn't change, so if the shape passes from being concave to being convex, that;s fine as well.
Example:
linear-algebra geometry vectors polygons
$endgroup$
|
show 3 more comments
$begingroup$
With a convex shape, like a circle, we can create a set of similar shapes, all contained within one another, by centering the shape at the origin and scaling it.
So we can get the following:
With a concave shape however, cetnering it at its centroid and scaling won't keep the points inside the original polygon, we would get something like this:
(Diagram was made by hand so this may not be the mathematical result, but it illustrates the point)
My goal is to be able to deform the original polygon such that the result converges to a single point contained in the original polygon, and every new ring is fully contained in the previous ring, as in this image:
How can this be done?
EDIT:
Maintaining the topology in new rings isn't necessary as long as the number of points doesn't change, so if the shape passes from being concave to being convex, that;s fine as well.
Example:
linear-algebra geometry vectors polygons
$endgroup$
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11
|
show 3 more comments
$begingroup$
With a convex shape, like a circle, we can create a set of similar shapes, all contained within one another, by centering the shape at the origin and scaling it.
So we can get the following:
With a concave shape however, cetnering it at its centroid and scaling won't keep the points inside the original polygon, we would get something like this:
(Diagram was made by hand so this may not be the mathematical result, but it illustrates the point)
My goal is to be able to deform the original polygon such that the result converges to a single point contained in the original polygon, and every new ring is fully contained in the previous ring, as in this image:
How can this be done?
EDIT:
Maintaining the topology in new rings isn't necessary as long as the number of points doesn't change, so if the shape passes from being concave to being convex, that;s fine as well.
Example:
linear-algebra geometry vectors polygons
$endgroup$
With a convex shape, like a circle, we can create a set of similar shapes, all contained within one another, by centering the shape at the origin and scaling it.
So we can get the following:
With a concave shape however, cetnering it at its centroid and scaling won't keep the points inside the original polygon, we would get something like this:
(Diagram was made by hand so this may not be the mathematical result, but it illustrates the point)
My goal is to be able to deform the original polygon such that the result converges to a single point contained in the original polygon, and every new ring is fully contained in the previous ring, as in this image:
How can this be done?
EDIT:
Maintaining the topology in new rings isn't necessary as long as the number of points doesn't change, so if the shape passes from being concave to being convex, that;s fine as well.
Example:
linear-algebra geometry vectors polygons
linear-algebra geometry vectors polygons
edited Jan 31 at 15:33
Makogan
asked Jan 31 at 15:15


MakoganMakogan
786218
786218
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11
|
show 3 more comments
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11
|
show 3 more comments
2 Answers
2
active
oldest
votes
$begingroup$
You can achieve your goal by choosing a point $O$ inside your shape and constructing then the other shapes via a homothetic transformation of center $O$ and ratio $<1$.
EDIT.
This works only if the shape is a star domain and $O$ one of its centers.
$endgroup$
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
add a comment |
$begingroup$
- Choose the point you want the polygon to converge into, let's call it $C$
- For each vertex $V_i$ of the original polygon choose a curve $gamma_i$ (staying inside the polygon) from that vertex to $C$, parametrised from $0$ to $1$
- Now for each $xin [0,1]$, the polygon with vertices at $gamma_i(x)$ represent a polygon, and when $x$ moves from $0$ to $1$ those polygons converge from the original to the $C$.
$endgroup$
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
|
show 1 more comment
Your Answer
StackExchange.ifUsing("editor", function () {
return StackExchange.using("mathjaxEditing", function () {
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
});
});
}, "mathjax-editing");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "69"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
noCode: true, onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f3094996%2fhow-to-scale-a-polygon-such-that-all-the-points-lie-within-the-original-polygon%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
You can achieve your goal by choosing a point $O$ inside your shape and constructing then the other shapes via a homothetic transformation of center $O$ and ratio $<1$.
EDIT.
This works only if the shape is a star domain and $O$ one of its centers.
$endgroup$
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
add a comment |
$begingroup$
You can achieve your goal by choosing a point $O$ inside your shape and constructing then the other shapes via a homothetic transformation of center $O$ and ratio $<1$.
EDIT.
This works only if the shape is a star domain and $O$ one of its centers.
$endgroup$
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
add a comment |
$begingroup$
You can achieve your goal by choosing a point $O$ inside your shape and constructing then the other shapes via a homothetic transformation of center $O$ and ratio $<1$.
EDIT.
This works only if the shape is a star domain and $O$ one of its centers.
$endgroup$
You can achieve your goal by choosing a point $O$ inside your shape and constructing then the other shapes via a homothetic transformation of center $O$ and ratio $<1$.
EDIT.
This works only if the shape is a star domain and $O$ one of its centers.
edited Jan 31 at 16:10
answered Jan 31 at 16:02


AretinoAretino
25.8k31545
25.8k31545
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
add a comment |
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
This is brilliant, can't believe I didn't think of that. Any suggestion on how to chose the center point? A good heuristic at least? I realized it
$endgroup$
– Makogan
Jan 31 at 16:06
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
$begingroup$
Unfortunately this works only if you have a star domain (see my edit). You can choose any center $x_0$ of the domain.
$endgroup$
– Aretino
Jan 31 at 16:11
add a comment |
$begingroup$
- Choose the point you want the polygon to converge into, let's call it $C$
- For each vertex $V_i$ of the original polygon choose a curve $gamma_i$ (staying inside the polygon) from that vertex to $C$, parametrised from $0$ to $1$
- Now for each $xin [0,1]$, the polygon with vertices at $gamma_i(x)$ represent a polygon, and when $x$ moves from $0$ to $1$ those polygons converge from the original to the $C$.
$endgroup$
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
|
show 1 more comment
$begingroup$
- Choose the point you want the polygon to converge into, let's call it $C$
- For each vertex $V_i$ of the original polygon choose a curve $gamma_i$ (staying inside the polygon) from that vertex to $C$, parametrised from $0$ to $1$
- Now for each $xin [0,1]$, the polygon with vertices at $gamma_i(x)$ represent a polygon, and when $x$ moves from $0$ to $1$ those polygons converge from the original to the $C$.
$endgroup$
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
|
show 1 more comment
$begingroup$
- Choose the point you want the polygon to converge into, let's call it $C$
- For each vertex $V_i$ of the original polygon choose a curve $gamma_i$ (staying inside the polygon) from that vertex to $C$, parametrised from $0$ to $1$
- Now for each $xin [0,1]$, the polygon with vertices at $gamma_i(x)$ represent a polygon, and when $x$ moves from $0$ to $1$ those polygons converge from the original to the $C$.
$endgroup$
- Choose the point you want the polygon to converge into, let's call it $C$
- For each vertex $V_i$ of the original polygon choose a curve $gamma_i$ (staying inside the polygon) from that vertex to $C$, parametrised from $0$ to $1$
- Now for each $xin [0,1]$, the polygon with vertices at $gamma_i(x)$ represent a polygon, and when $x$ moves from $0$ to $1$ those polygons converge from the original to the $C$.
answered Jan 31 at 16:13


HenrikHenrik
6,04592030
6,04592030
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
|
show 1 more comment
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
$begingroup$
Isn't this answer identical to the homothetic one above?
$endgroup$
– Makogan
Jan 31 at 16:16
2
2
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
$begingroup$
This answer is more general than mine, as it isn't restricted to straight lines and works for any simply-connected domain. +1.
$endgroup$
– Aretino
Jan 31 at 16:18
1
1
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
@Aretino Then I guess I will select this as the answer for the sake of generality. But this is a bit too theoretical. "choose a curve $gamma_i$ (staying inside the polygon)". Deciding which $gamma_i$ to pick is an entire problem of it's own. As is picking $C$
$endgroup$
– Makogan
Jan 31 at 16:22
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
$begingroup$
There is no guarantee that the resulting polygon will be contained in the original polygon.
$endgroup$
– TonyK
Jan 31 at 16:29
2
2
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
$begingroup$
@Makogan I think this could also be of help: en.wikipedia.org/wiki/Straight_skeleton
$endgroup$
– Aretino
Jan 31 at 16:31
|
show 1 more comment
Thanks for contributing an answer to Mathematics Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f3094996%2fhow-to-scale-a-polygon-such-that-all-the-points-lie-within-the-original-polygon%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
$begingroup$
What point do you want it to converge to? In your example you could have moved the smaller polygons a bit upward and still have a construction matching your criteria. I would think any point from which you can draw a straight line to any point inside the starting polygon could be a possible target.
$endgroup$
– Henrik
Jan 31 at 15:25
$begingroup$
Any point inside the polygon works. I guess ideally something close to the center of mass is better, but ANYWHERE inside the polygon that satisfies the properties above is good enough.
$endgroup$
– Makogan
Jan 31 at 15:27
$begingroup$
I'm no completely sure of how it works, but if you use any point outside the set I described, I think that would limit what smaller versions you can go through. But if you don't even have to maintain the shape, that's not a major concern.
$endgroup$
– Henrik
Jan 31 at 16:08
$begingroup$
It seems to me that what you want is rather difficult! Neither of the current answers solves your problem.
$endgroup$
– TonyK
Jan 31 at 17:08
$begingroup$
The curve one (accepted one) definitely answers the problem. At leas tin theory. But finding the curve to follow is rather difficult. Using the straight skeleton as suggested is one way to generate those curves but that's complicated and costly... i.e the solutions provided do solve the problem, albeit they are not copy pastable.
$endgroup$
– Makogan
Jan 31 at 17:11