Minimizing the sum of distances between points and a point on the plane?
$begingroup$
This seems like it should be a simple problem, so maybe I am just being silly.
Let's say that we have $n$ points, $P_1$ to $P_n$, with coordinates $(x_1,y_1, z_1)$ to $(x_n,y_n, z_n)$, floating above the $xy$ plane and we would like to find the point $Q$ on the $xy$ plane such that the sum of the Pythagorean distances between $Q$ and the points $P_1$ to $P_n$ is minimized.
What I have done so far:
Working with the sum of the squared distances instead, we could define $f$ as
$$f(x, y, z)=sum_{k=1}^n d_k^2=sum_{k=1}^nleft(x-x_kright)^2+sum_{k=1}^nleft(y-y_kright)^2+sum_{k=1}^nleft(z-z_kright)^2$$
where $x$, $y$ and $z$ are potential coordinates for $Q$.
The partial derivative with respect to $x$:
$$begin{align}
frac{partial f}{partial x}&=2sum_{k=1}^nleft(x-x_kright)\
&=2left(nx-sum_{k=1}^n x_kright)
end{align}$$
Setting this to zero and solving for $x$ gets us the result
$$x=frac1nsum_{k=1}^n x_k=bar x$$
Similarly the other coordinates are $y=bar y$ and $z=bar z$.
This gives the result, ignoring the constraint that $Q$ should lie on the $xy$ plane, that the sum of the square distances will be minimized by $Q(bar x,bar y, bar z)$.
With the constraint that $Q$ lies on the $xy$ plane, however, I thought I could still work with $f$ but just set variable $z$ to zero and replace the last term with the constant $sum_{k=1}^nz_k^2$. In this case, optimizing as above would yield $(bar x, bar y, 0)$.
It seems counter intuitive to me that the heights of the points are negligible, and when I played around with toy data sets, I could see that the result was incorrect.
(From the toy data sets, I suspect that the correct $x$ and $y$ coordinates of $Q$ are the means of the coordinates of $P_1$ to $P_n$, but weighted by the inverse of the respective $z$ coordinate...)
What is wrong with the reasoning above? I'm sure that this problem is a well known problem, so any references would also be helpful!
optimization partial-derivative
$endgroup$
add a comment |
$begingroup$
This seems like it should be a simple problem, so maybe I am just being silly.
Let's say that we have $n$ points, $P_1$ to $P_n$, with coordinates $(x_1,y_1, z_1)$ to $(x_n,y_n, z_n)$, floating above the $xy$ plane and we would like to find the point $Q$ on the $xy$ plane such that the sum of the Pythagorean distances between $Q$ and the points $P_1$ to $P_n$ is minimized.
What I have done so far:
Working with the sum of the squared distances instead, we could define $f$ as
$$f(x, y, z)=sum_{k=1}^n d_k^2=sum_{k=1}^nleft(x-x_kright)^2+sum_{k=1}^nleft(y-y_kright)^2+sum_{k=1}^nleft(z-z_kright)^2$$
where $x$, $y$ and $z$ are potential coordinates for $Q$.
The partial derivative with respect to $x$:
$$begin{align}
frac{partial f}{partial x}&=2sum_{k=1}^nleft(x-x_kright)\
&=2left(nx-sum_{k=1}^n x_kright)
end{align}$$
Setting this to zero and solving for $x$ gets us the result
$$x=frac1nsum_{k=1}^n x_k=bar x$$
Similarly the other coordinates are $y=bar y$ and $z=bar z$.
This gives the result, ignoring the constraint that $Q$ should lie on the $xy$ plane, that the sum of the square distances will be minimized by $Q(bar x,bar y, bar z)$.
With the constraint that $Q$ lies on the $xy$ plane, however, I thought I could still work with $f$ but just set variable $z$ to zero and replace the last term with the constant $sum_{k=1}^nz_k^2$. In this case, optimizing as above would yield $(bar x, bar y, 0)$.
It seems counter intuitive to me that the heights of the points are negligible, and when I played around with toy data sets, I could see that the result was incorrect.
(From the toy data sets, I suspect that the correct $x$ and $y$ coordinates of $Q$ are the means of the coordinates of $P_1$ to $P_n$, but weighted by the inverse of the respective $z$ coordinate...)
What is wrong with the reasoning above? I'm sure that this problem is a well known problem, so any references would also be helpful!
optimization partial-derivative
$endgroup$
1
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05
add a comment |
$begingroup$
This seems like it should be a simple problem, so maybe I am just being silly.
Let's say that we have $n$ points, $P_1$ to $P_n$, with coordinates $(x_1,y_1, z_1)$ to $(x_n,y_n, z_n)$, floating above the $xy$ plane and we would like to find the point $Q$ on the $xy$ plane such that the sum of the Pythagorean distances between $Q$ and the points $P_1$ to $P_n$ is minimized.
What I have done so far:
Working with the sum of the squared distances instead, we could define $f$ as
$$f(x, y, z)=sum_{k=1}^n d_k^2=sum_{k=1}^nleft(x-x_kright)^2+sum_{k=1}^nleft(y-y_kright)^2+sum_{k=1}^nleft(z-z_kright)^2$$
where $x$, $y$ and $z$ are potential coordinates for $Q$.
The partial derivative with respect to $x$:
$$begin{align}
frac{partial f}{partial x}&=2sum_{k=1}^nleft(x-x_kright)\
&=2left(nx-sum_{k=1}^n x_kright)
end{align}$$
Setting this to zero and solving for $x$ gets us the result
$$x=frac1nsum_{k=1}^n x_k=bar x$$
Similarly the other coordinates are $y=bar y$ and $z=bar z$.
This gives the result, ignoring the constraint that $Q$ should lie on the $xy$ plane, that the sum of the square distances will be minimized by $Q(bar x,bar y, bar z)$.
With the constraint that $Q$ lies on the $xy$ plane, however, I thought I could still work with $f$ but just set variable $z$ to zero and replace the last term with the constant $sum_{k=1}^nz_k^2$. In this case, optimizing as above would yield $(bar x, bar y, 0)$.
It seems counter intuitive to me that the heights of the points are negligible, and when I played around with toy data sets, I could see that the result was incorrect.
(From the toy data sets, I suspect that the correct $x$ and $y$ coordinates of $Q$ are the means of the coordinates of $P_1$ to $P_n$, but weighted by the inverse of the respective $z$ coordinate...)
What is wrong with the reasoning above? I'm sure that this problem is a well known problem, so any references would also be helpful!
optimization partial-derivative
$endgroup$
This seems like it should be a simple problem, so maybe I am just being silly.
Let's say that we have $n$ points, $P_1$ to $P_n$, with coordinates $(x_1,y_1, z_1)$ to $(x_n,y_n, z_n)$, floating above the $xy$ plane and we would like to find the point $Q$ on the $xy$ plane such that the sum of the Pythagorean distances between $Q$ and the points $P_1$ to $P_n$ is minimized.
What I have done so far:
Working with the sum of the squared distances instead, we could define $f$ as
$$f(x, y, z)=sum_{k=1}^n d_k^2=sum_{k=1}^nleft(x-x_kright)^2+sum_{k=1}^nleft(y-y_kright)^2+sum_{k=1}^nleft(z-z_kright)^2$$
where $x$, $y$ and $z$ are potential coordinates for $Q$.
The partial derivative with respect to $x$:
$$begin{align}
frac{partial f}{partial x}&=2sum_{k=1}^nleft(x-x_kright)\
&=2left(nx-sum_{k=1}^n x_kright)
end{align}$$
Setting this to zero and solving for $x$ gets us the result
$$x=frac1nsum_{k=1}^n x_k=bar x$$
Similarly the other coordinates are $y=bar y$ and $z=bar z$.
This gives the result, ignoring the constraint that $Q$ should lie on the $xy$ plane, that the sum of the square distances will be minimized by $Q(bar x,bar y, bar z)$.
With the constraint that $Q$ lies on the $xy$ plane, however, I thought I could still work with $f$ but just set variable $z$ to zero and replace the last term with the constant $sum_{k=1}^nz_k^2$. In this case, optimizing as above would yield $(bar x, bar y, 0)$.
It seems counter intuitive to me that the heights of the points are negligible, and when I played around with toy data sets, I could see that the result was incorrect.
(From the toy data sets, I suspect that the correct $x$ and $y$ coordinates of $Q$ are the means of the coordinates of $P_1$ to $P_n$, but weighted by the inverse of the respective $z$ coordinate...)
What is wrong with the reasoning above? I'm sure that this problem is a well known problem, so any references would also be helpful!
optimization partial-derivative
optimization partial-derivative
edited Dec 13 '18 at 3:50
Richard Ambler
asked Dec 13 '18 at 3:42
Richard AmblerRichard Ambler
1,298515
1,298515
1
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05
add a comment |
1
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05
1
1
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05
add a comment |
1 Answer
1
active
oldest
votes
$begingroup$
Thanks to David in the comments for pointing out the brain-fart.
Let me try again:
Let's define $f$ as as the sum of the distances:
$$f(x, y)=sum_{k=1}^nd_k=sum_{k=1}^nsqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}$$
Then:
$$begin{align}
frac{partial f}{partial x}&=sumfrac{x-x_k}{sqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}}\
&=xsumfrac{1}{d_k}-sumfrac{x_k}{d_k}
end{align}$$
Setting this to zero yields the result:
$$x=frac{sumfrac{1}{d_k}x_k}{sumfrac{1}{d_k}}$$
Similarly:
$$y=frac{sumfrac{1}{d_k}y_k}{sumfrac{1}{d_k}}$$
(It looks like I was wrong before when I thought that the point had the mean coordinates weighted by the inverse of the respective $z$ coordinates - it rather looks like the mean weighted by the inverse distances.)
Unfortunately, this is still in terms of $d_k$ which means we have to know the optimum coordinates to calculate the optimum coordinates...
We could use numerical methods to iterate improvements on an initial set of estimates, for example,
- Set the $x$ and $y$ coordinates of $Q$ to an initial guess (say $bar x, bar y$).
- Calculate the distance $d_k$ to each point $P_k$.
- Calculate the new $x$ and $y$ coordinates using the previous $x$ and $y$ values and the calculated distances for the weights.
- Repeat from step 2 until the updates to $x$ and $y$ are negligible.
It appears to work on the toy data sets I've used, but it's not really the solution I was hoping for...
Update
Just to bring a little closure to this question:
It turns out that this problem is closely related to the geometric median of a set of points, which is the point that minimizes the sum of Euclidean distances to the points. Specifically, the point in this problem has the same $x$ and $y$ coordinates as the geometric median and a zero $z$ coordinate (analogous to a shadow of the geometric median on the $xy$ plane).
It looks like the formula I was after doesn't exist. From the Wikipedia article linked to above:
Despite the geometric median's (sic) being an easy-to-understand concept, computing it poses a challenge [...] it has been shown that no explicit formula, nor an exact algorithm involving only arithmetic operations and $k$th roots, can exist in general for the geometric median.
Further, the algorithm that I outlined above turns out to have a name: Weiszfeld's algorithm, after Endre Weiszfeld.
This method converges for almost all initial positions, but may fail to converge when one of its estimates falls on one of the given points.
(Of course, since then that point would have an undefined weight. Practically we could, I think, add a negligible value to zero distances encountered along the way to get over this.)
I wasn't originally intending to answer my own question but I think that this is pretty much the answer I was looking for.
$endgroup$
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
add a 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%2f3037564%2fminimizing-the-sum-of-distances-between-points-and-a-point-on-the-plane%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
Thanks to David in the comments for pointing out the brain-fart.
Let me try again:
Let's define $f$ as as the sum of the distances:
$$f(x, y)=sum_{k=1}^nd_k=sum_{k=1}^nsqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}$$
Then:
$$begin{align}
frac{partial f}{partial x}&=sumfrac{x-x_k}{sqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}}\
&=xsumfrac{1}{d_k}-sumfrac{x_k}{d_k}
end{align}$$
Setting this to zero yields the result:
$$x=frac{sumfrac{1}{d_k}x_k}{sumfrac{1}{d_k}}$$
Similarly:
$$y=frac{sumfrac{1}{d_k}y_k}{sumfrac{1}{d_k}}$$
(It looks like I was wrong before when I thought that the point had the mean coordinates weighted by the inverse of the respective $z$ coordinates - it rather looks like the mean weighted by the inverse distances.)
Unfortunately, this is still in terms of $d_k$ which means we have to know the optimum coordinates to calculate the optimum coordinates...
We could use numerical methods to iterate improvements on an initial set of estimates, for example,
- Set the $x$ and $y$ coordinates of $Q$ to an initial guess (say $bar x, bar y$).
- Calculate the distance $d_k$ to each point $P_k$.
- Calculate the new $x$ and $y$ coordinates using the previous $x$ and $y$ values and the calculated distances for the weights.
- Repeat from step 2 until the updates to $x$ and $y$ are negligible.
It appears to work on the toy data sets I've used, but it's not really the solution I was hoping for...
Update
Just to bring a little closure to this question:
It turns out that this problem is closely related to the geometric median of a set of points, which is the point that minimizes the sum of Euclidean distances to the points. Specifically, the point in this problem has the same $x$ and $y$ coordinates as the geometric median and a zero $z$ coordinate (analogous to a shadow of the geometric median on the $xy$ plane).
It looks like the formula I was after doesn't exist. From the Wikipedia article linked to above:
Despite the geometric median's (sic) being an easy-to-understand concept, computing it poses a challenge [...] it has been shown that no explicit formula, nor an exact algorithm involving only arithmetic operations and $k$th roots, can exist in general for the geometric median.
Further, the algorithm that I outlined above turns out to have a name: Weiszfeld's algorithm, after Endre Weiszfeld.
This method converges for almost all initial positions, but may fail to converge when one of its estimates falls on one of the given points.
(Of course, since then that point would have an undefined weight. Practically we could, I think, add a negligible value to zero distances encountered along the way to get over this.)
I wasn't originally intending to answer my own question but I think that this is pretty much the answer I was looking for.
$endgroup$
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
add a comment |
$begingroup$
Thanks to David in the comments for pointing out the brain-fart.
Let me try again:
Let's define $f$ as as the sum of the distances:
$$f(x, y)=sum_{k=1}^nd_k=sum_{k=1}^nsqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}$$
Then:
$$begin{align}
frac{partial f}{partial x}&=sumfrac{x-x_k}{sqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}}\
&=xsumfrac{1}{d_k}-sumfrac{x_k}{d_k}
end{align}$$
Setting this to zero yields the result:
$$x=frac{sumfrac{1}{d_k}x_k}{sumfrac{1}{d_k}}$$
Similarly:
$$y=frac{sumfrac{1}{d_k}y_k}{sumfrac{1}{d_k}}$$
(It looks like I was wrong before when I thought that the point had the mean coordinates weighted by the inverse of the respective $z$ coordinates - it rather looks like the mean weighted by the inverse distances.)
Unfortunately, this is still in terms of $d_k$ which means we have to know the optimum coordinates to calculate the optimum coordinates...
We could use numerical methods to iterate improvements on an initial set of estimates, for example,
- Set the $x$ and $y$ coordinates of $Q$ to an initial guess (say $bar x, bar y$).
- Calculate the distance $d_k$ to each point $P_k$.
- Calculate the new $x$ and $y$ coordinates using the previous $x$ and $y$ values and the calculated distances for the weights.
- Repeat from step 2 until the updates to $x$ and $y$ are negligible.
It appears to work on the toy data sets I've used, but it's not really the solution I was hoping for...
Update
Just to bring a little closure to this question:
It turns out that this problem is closely related to the geometric median of a set of points, which is the point that minimizes the sum of Euclidean distances to the points. Specifically, the point in this problem has the same $x$ and $y$ coordinates as the geometric median and a zero $z$ coordinate (analogous to a shadow of the geometric median on the $xy$ plane).
It looks like the formula I was after doesn't exist. From the Wikipedia article linked to above:
Despite the geometric median's (sic) being an easy-to-understand concept, computing it poses a challenge [...] it has been shown that no explicit formula, nor an exact algorithm involving only arithmetic operations and $k$th roots, can exist in general for the geometric median.
Further, the algorithm that I outlined above turns out to have a name: Weiszfeld's algorithm, after Endre Weiszfeld.
This method converges for almost all initial positions, but may fail to converge when one of its estimates falls on one of the given points.
(Of course, since then that point would have an undefined weight. Practically we could, I think, add a negligible value to zero distances encountered along the way to get over this.)
I wasn't originally intending to answer my own question but I think that this is pretty much the answer I was looking for.
$endgroup$
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
add a comment |
$begingroup$
Thanks to David in the comments for pointing out the brain-fart.
Let me try again:
Let's define $f$ as as the sum of the distances:
$$f(x, y)=sum_{k=1}^nd_k=sum_{k=1}^nsqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}$$
Then:
$$begin{align}
frac{partial f}{partial x}&=sumfrac{x-x_k}{sqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}}\
&=xsumfrac{1}{d_k}-sumfrac{x_k}{d_k}
end{align}$$
Setting this to zero yields the result:
$$x=frac{sumfrac{1}{d_k}x_k}{sumfrac{1}{d_k}}$$
Similarly:
$$y=frac{sumfrac{1}{d_k}y_k}{sumfrac{1}{d_k}}$$
(It looks like I was wrong before when I thought that the point had the mean coordinates weighted by the inverse of the respective $z$ coordinates - it rather looks like the mean weighted by the inverse distances.)
Unfortunately, this is still in terms of $d_k$ which means we have to know the optimum coordinates to calculate the optimum coordinates...
We could use numerical methods to iterate improvements on an initial set of estimates, for example,
- Set the $x$ and $y$ coordinates of $Q$ to an initial guess (say $bar x, bar y$).
- Calculate the distance $d_k$ to each point $P_k$.
- Calculate the new $x$ and $y$ coordinates using the previous $x$ and $y$ values and the calculated distances for the weights.
- Repeat from step 2 until the updates to $x$ and $y$ are negligible.
It appears to work on the toy data sets I've used, but it's not really the solution I was hoping for...
Update
Just to bring a little closure to this question:
It turns out that this problem is closely related to the geometric median of a set of points, which is the point that minimizes the sum of Euclidean distances to the points. Specifically, the point in this problem has the same $x$ and $y$ coordinates as the geometric median and a zero $z$ coordinate (analogous to a shadow of the geometric median on the $xy$ plane).
It looks like the formula I was after doesn't exist. From the Wikipedia article linked to above:
Despite the geometric median's (sic) being an easy-to-understand concept, computing it poses a challenge [...] it has been shown that no explicit formula, nor an exact algorithm involving only arithmetic operations and $k$th roots, can exist in general for the geometric median.
Further, the algorithm that I outlined above turns out to have a name: Weiszfeld's algorithm, after Endre Weiszfeld.
This method converges for almost all initial positions, but may fail to converge when one of its estimates falls on one of the given points.
(Of course, since then that point would have an undefined weight. Practically we could, I think, add a negligible value to zero distances encountered along the way to get over this.)
I wasn't originally intending to answer my own question but I think that this is pretty much the answer I was looking for.
$endgroup$
Thanks to David in the comments for pointing out the brain-fart.
Let me try again:
Let's define $f$ as as the sum of the distances:
$$f(x, y)=sum_{k=1}^nd_k=sum_{k=1}^nsqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}$$
Then:
$$begin{align}
frac{partial f}{partial x}&=sumfrac{x-x_k}{sqrt{left(x-x_kright)^2+left(y-y_kright)^2+z_k^2}}\
&=xsumfrac{1}{d_k}-sumfrac{x_k}{d_k}
end{align}$$
Setting this to zero yields the result:
$$x=frac{sumfrac{1}{d_k}x_k}{sumfrac{1}{d_k}}$$
Similarly:
$$y=frac{sumfrac{1}{d_k}y_k}{sumfrac{1}{d_k}}$$
(It looks like I was wrong before when I thought that the point had the mean coordinates weighted by the inverse of the respective $z$ coordinates - it rather looks like the mean weighted by the inverse distances.)
Unfortunately, this is still in terms of $d_k$ which means we have to know the optimum coordinates to calculate the optimum coordinates...
We could use numerical methods to iterate improvements on an initial set of estimates, for example,
- Set the $x$ and $y$ coordinates of $Q$ to an initial guess (say $bar x, bar y$).
- Calculate the distance $d_k$ to each point $P_k$.
- Calculate the new $x$ and $y$ coordinates using the previous $x$ and $y$ values and the calculated distances for the weights.
- Repeat from step 2 until the updates to $x$ and $y$ are negligible.
It appears to work on the toy data sets I've used, but it's not really the solution I was hoping for...
Update
Just to bring a little closure to this question:
It turns out that this problem is closely related to the geometric median of a set of points, which is the point that minimizes the sum of Euclidean distances to the points. Specifically, the point in this problem has the same $x$ and $y$ coordinates as the geometric median and a zero $z$ coordinate (analogous to a shadow of the geometric median on the $xy$ plane).
It looks like the formula I was after doesn't exist. From the Wikipedia article linked to above:
Despite the geometric median's (sic) being an easy-to-understand concept, computing it poses a challenge [...] it has been shown that no explicit formula, nor an exact algorithm involving only arithmetic operations and $k$th roots, can exist in general for the geometric median.
Further, the algorithm that I outlined above turns out to have a name: Weiszfeld's algorithm, after Endre Weiszfeld.
This method converges for almost all initial positions, but may fail to converge when one of its estimates falls on one of the given points.
(Of course, since then that point would have an undefined weight. Practically we could, I think, add a negligible value to zero distances encountered along the way to get over this.)
I wasn't originally intending to answer my own question but I think that this is pretty much the answer I was looking for.
edited Dec 21 '18 at 1:42
answered Dec 13 '18 at 9:48
Richard AmblerRichard Ambler
1,298515
1,298515
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
add a comment |
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
$begingroup$
You are lucky that your objective function is smooth and unimodal (if I am right). Unless your data points have a weird distribution, the function should also be pretty isotropic. I would go for a gradient descent method. As it is a two-variable problem, with a little more effort you can implement Newton's method.
$endgroup$
– Yves Daoust
Dec 13 '18 at 11:03
add a 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%2f3037564%2fminimizing-the-sum-of-distances-between-points-and-a-point-on-the-plane%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
1
$begingroup$
For a start, using the squared distance works for a single distance, but not for a sum of two or more distances.
$endgroup$
– David
Dec 13 '18 at 4:05