Create line network from closest points with boundaries












0















I have a set of points and I want to create line / road network from those points. Firstly, I need to determine the closest point from each of the points. For that, I used the KD Tree and developed a code like this:



def closestPoint(source, X = None, Y = None):

df = pd.DataFrame(source).copy(deep = True) #Ensure source is a dataframe, working on a copy to keep the datasource

if(X is None and Y is None):
raise ValueError ("Please specify coordinate")
elif(not X in df.keys() and not Y in df.keys()):
raise ValueError ("X and/or Y is/are not in column names")
else:
df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate

if (df["coord"].duplicated):
uniq = df.drop_duplicates("coord")["coord"]
uniqval = list(uniq.get_values())
dupl = df[df["coord"].duplicated()]["coord"]
duplval = list(dupl.get_values())

for kq,vq in uniq.items():
clstu = spatial.KDTree(uniqval).query(vq, k = 3)[1]
df.at[kq,"coord"] = [vq,uniqval[clstu[1]]]
if([uniqval[clstu[1]],vq] in list(df["coord"]) ):
df.at[kq,"coord"] = [vq,uniqval[clstu[2]]]

for kd,vd in dupl.items():
clstd = spatial.KDTree(duplval).query(vd,k = 1)[1]
df.at[kd,"coord"] = [vd,duplval[clstd]]
else:
val = df["coord"].get_values()
for k,v in df["coord"].items():
clst = spatial.KDTree(val).query(vd, k = 3)[1]
df.at[k,"coord"] = [v,val[clst[1]]]
if([val[clst[1]],v] in list (df["coord"])):
df.at[k,"coord"] = [v,val[clst[2]]]

return df["coord"]


The code can return the the closest points around. However, I need to ensure that no double lines are created (e.g (x,y) to (x1,y1) and (x1,y1) to (x,y)) and also I need to ensure that each point can only be used as a starting point of a line and an end point of a line despite the point being the closest one to the other points.



Below is the visualization of the result:
Result of the code



What I want:
What I want



I've also tried to separate the origin and target coordinate and do it like this:



df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate
df["target"] = "" #create a column for target points

count = 2 # create a count iteration
if (df["coord"].duplicated):
uniq = df.drop_duplicates("coord")["coord"]
uniqval = list(uniq.get_values())
for kq,vq in uniq.items():
clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
while not vq in (list(df["target"]) and list(df["coord"])):
clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
df.set_value(kq, "target", uniqval[clstu[count-1]])
else:
count += 1
clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
df.set_value(kq, "target", uniqval[clstu[count-1]])


but this return an error



IndexError: list index out of range


Can anyone help me with this? Many thanks!










share|improve this question





























    0















    I have a set of points and I want to create line / road network from those points. Firstly, I need to determine the closest point from each of the points. For that, I used the KD Tree and developed a code like this:



    def closestPoint(source, X = None, Y = None):

    df = pd.DataFrame(source).copy(deep = True) #Ensure source is a dataframe, working on a copy to keep the datasource

    if(X is None and Y is None):
    raise ValueError ("Please specify coordinate")
    elif(not X in df.keys() and not Y in df.keys()):
    raise ValueError ("X and/or Y is/are not in column names")
    else:
    df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate

    if (df["coord"].duplicated):
    uniq = df.drop_duplicates("coord")["coord"]
    uniqval = list(uniq.get_values())
    dupl = df[df["coord"].duplicated()]["coord"]
    duplval = list(dupl.get_values())

    for kq,vq in uniq.items():
    clstu = spatial.KDTree(uniqval).query(vq, k = 3)[1]
    df.at[kq,"coord"] = [vq,uniqval[clstu[1]]]
    if([uniqval[clstu[1]],vq] in list(df["coord"]) ):
    df.at[kq,"coord"] = [vq,uniqval[clstu[2]]]

    for kd,vd in dupl.items():
    clstd = spatial.KDTree(duplval).query(vd,k = 1)[1]
    df.at[kd,"coord"] = [vd,duplval[clstd]]
    else:
    val = df["coord"].get_values()
    for k,v in df["coord"].items():
    clst = spatial.KDTree(val).query(vd, k = 3)[1]
    df.at[k,"coord"] = [v,val[clst[1]]]
    if([val[clst[1]],v] in list (df["coord"])):
    df.at[k,"coord"] = [v,val[clst[2]]]

    return df["coord"]


    The code can return the the closest points around. However, I need to ensure that no double lines are created (e.g (x,y) to (x1,y1) and (x1,y1) to (x,y)) and also I need to ensure that each point can only be used as a starting point of a line and an end point of a line despite the point being the closest one to the other points.



    Below is the visualization of the result:
    Result of the code



    What I want:
    What I want



    I've also tried to separate the origin and target coordinate and do it like this:



    df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate
    df["target"] = "" #create a column for target points

    count = 2 # create a count iteration
    if (df["coord"].duplicated):
    uniq = df.drop_duplicates("coord")["coord"]
    uniqval = list(uniq.get_values())
    for kq,vq in uniq.items():
    clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
    while not vq in (list(df["target"]) and list(df["coord"])):
    clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
    df.set_value(kq, "target", uniqval[clstu[count-1]])
    else:
    count += 1
    clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
    df.set_value(kq, "target", uniqval[clstu[count-1]])


    but this return an error



    IndexError: list index out of range


    Can anyone help me with this? Many thanks!










    share|improve this question



























      0












      0








      0








      I have a set of points and I want to create line / road network from those points. Firstly, I need to determine the closest point from each of the points. For that, I used the KD Tree and developed a code like this:



      def closestPoint(source, X = None, Y = None):

      df = pd.DataFrame(source).copy(deep = True) #Ensure source is a dataframe, working on a copy to keep the datasource

      if(X is None and Y is None):
      raise ValueError ("Please specify coordinate")
      elif(not X in df.keys() and not Y in df.keys()):
      raise ValueError ("X and/or Y is/are not in column names")
      else:
      df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate

      if (df["coord"].duplicated):
      uniq = df.drop_duplicates("coord")["coord"]
      uniqval = list(uniq.get_values())
      dupl = df[df["coord"].duplicated()]["coord"]
      duplval = list(dupl.get_values())

      for kq,vq in uniq.items():
      clstu = spatial.KDTree(uniqval).query(vq, k = 3)[1]
      df.at[kq,"coord"] = [vq,uniqval[clstu[1]]]
      if([uniqval[clstu[1]],vq] in list(df["coord"]) ):
      df.at[kq,"coord"] = [vq,uniqval[clstu[2]]]

      for kd,vd in dupl.items():
      clstd = spatial.KDTree(duplval).query(vd,k = 1)[1]
      df.at[kd,"coord"] = [vd,duplval[clstd]]
      else:
      val = df["coord"].get_values()
      for k,v in df["coord"].items():
      clst = spatial.KDTree(val).query(vd, k = 3)[1]
      df.at[k,"coord"] = [v,val[clst[1]]]
      if([val[clst[1]],v] in list (df["coord"])):
      df.at[k,"coord"] = [v,val[clst[2]]]

      return df["coord"]


      The code can return the the closest points around. However, I need to ensure that no double lines are created (e.g (x,y) to (x1,y1) and (x1,y1) to (x,y)) and also I need to ensure that each point can only be used as a starting point of a line and an end point of a line despite the point being the closest one to the other points.



      Below is the visualization of the result:
      Result of the code



      What I want:
      What I want



      I've also tried to separate the origin and target coordinate and do it like this:



      df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate
      df["target"] = "" #create a column for target points

      count = 2 # create a count iteration
      if (df["coord"].duplicated):
      uniq = df.drop_duplicates("coord")["coord"]
      uniqval = list(uniq.get_values())
      for kq,vq in uniq.items():
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      while not vq in (list(df["target"]) and list(df["coord"])):
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      df.set_value(kq, "target", uniqval[clstu[count-1]])
      else:
      count += 1
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      df.set_value(kq, "target", uniqval[clstu[count-1]])


      but this return an error



      IndexError: list index out of range


      Can anyone help me with this? Many thanks!










      share|improve this question
















      I have a set of points and I want to create line / road network from those points. Firstly, I need to determine the closest point from each of the points. For that, I used the KD Tree and developed a code like this:



      def closestPoint(source, X = None, Y = None):

      df = pd.DataFrame(source).copy(deep = True) #Ensure source is a dataframe, working on a copy to keep the datasource

      if(X is None and Y is None):
      raise ValueError ("Please specify coordinate")
      elif(not X in df.keys() and not Y in df.keys()):
      raise ValueError ("X and/or Y is/are not in column names")
      else:
      df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate

      if (df["coord"].duplicated):
      uniq = df.drop_duplicates("coord")["coord"]
      uniqval = list(uniq.get_values())
      dupl = df[df["coord"].duplicated()]["coord"]
      duplval = list(dupl.get_values())

      for kq,vq in uniq.items():
      clstu = spatial.KDTree(uniqval).query(vq, k = 3)[1]
      df.at[kq,"coord"] = [vq,uniqval[clstu[1]]]
      if([uniqval[clstu[1]],vq] in list(df["coord"]) ):
      df.at[kq,"coord"] = [vq,uniqval[clstu[2]]]

      for kd,vd in dupl.items():
      clstd = spatial.KDTree(duplval).query(vd,k = 1)[1]
      df.at[kd,"coord"] = [vd,duplval[clstd]]
      else:
      val = df["coord"].get_values()
      for k,v in df["coord"].items():
      clst = spatial.KDTree(val).query(vd, k = 3)[1]
      df.at[k,"coord"] = [v,val[clst[1]]]
      if([val[clst[1]],v] in list (df["coord"])):
      df.at[k,"coord"] = [v,val[clst[2]]]

      return df["coord"]


      The code can return the the closest points around. However, I need to ensure that no double lines are created (e.g (x,y) to (x1,y1) and (x1,y1) to (x,y)) and also I need to ensure that each point can only be used as a starting point of a line and an end point of a line despite the point being the closest one to the other points.



      Below is the visualization of the result:
      Result of the code



      What I want:
      What I want



      I've also tried to separate the origin and target coordinate and do it like this:



      df["coord"] = tuple(zip(df[X],df[Y])) #create a coordinate
      df["target"] = "" #create a column for target points

      count = 2 # create a count iteration
      if (df["coord"].duplicated):
      uniq = df.drop_duplicates("coord")["coord"]
      uniqval = list(uniq.get_values())
      for kq,vq in uniq.items():
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      while not vq in (list(df["target"]) and list(df["coord"])):
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      df.set_value(kq, "target", uniqval[clstu[count-1]])
      else:
      count += 1
      clstu = spatial.KDTree(uniqval).query(vq, k = count)[1]
      df.set_value(kq, "target", uniqval[clstu[count-1]])


      but this return an error



      IndexError: list index out of range


      Can anyone help me with this? Many thanks!







      while-loop kdtree closest-points






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 20 '18 at 10:32







      botibo

















      asked Nov 20 '18 at 7:48









      botibobotibo

      33




      33
























          2 Answers
          2






          active

          oldest

          votes


















          0














          Answering now about the global strategy, here is what I would do (rough pseudo-algorithm):



          current_point = one starting point in uniqval
          while (uniqval not empty)
          construct KDTree from uniqval and use it for next line
          next_point = point in uniqval closest to current_point
          record next_point as target for current_point
          remove current_point from uniqval
          current_point = next_point


          What you will obtain is a linear graph joining all your points, using closest neighbors "in some way". I don't know if it will fit your needs. You would also obtain a linear graph by taking next_point at random...






          share|improve this answer
























          • Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

            – botibo
            Nov 21 '18 at 4:06











          • When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

            – Rolvernew
            Nov 21 '18 at 8:03











          • Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

            – botibo
            Nov 21 '18 at 10:27



















          0














          It is hard to comment on your global strategy without further detail about the kind of road network your want to obtain. So let me just comment your specific code and explain why the "out of range" error happens. I hope this can help.



          First, are you aware that (list_a and list_b) will return list_a if it is empty, else list_b? Second, isn't the condition (vq in list(df["coord"]) always True? If yes, then your while loop is just always executing the else statement, and at the last iteration of the for loop, (count-1) will be greater than the total number of (unique) points. Hence your KDTree query does not return enough points and clstu[count-1] is out of range.






          share|improve this answer
























          • thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

            – botibo
            Nov 20 '18 at 13:28











          • To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

            – Rolvernew
            Nov 20 '18 at 15:07











          • Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

            – botibo
            Nov 20 '18 at 15:54











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          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
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53388403%2fcreate-line-network-from-closest-points-with-boundaries%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









          0














          Answering now about the global strategy, here is what I would do (rough pseudo-algorithm):



          current_point = one starting point in uniqval
          while (uniqval not empty)
          construct KDTree from uniqval and use it for next line
          next_point = point in uniqval closest to current_point
          record next_point as target for current_point
          remove current_point from uniqval
          current_point = next_point


          What you will obtain is a linear graph joining all your points, using closest neighbors "in some way". I don't know if it will fit your needs. You would also obtain a linear graph by taking next_point at random...






          share|improve this answer
























          • Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

            – botibo
            Nov 21 '18 at 4:06











          • When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

            – Rolvernew
            Nov 21 '18 at 8:03











          • Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

            – botibo
            Nov 21 '18 at 10:27
















          0














          Answering now about the global strategy, here is what I would do (rough pseudo-algorithm):



          current_point = one starting point in uniqval
          while (uniqval not empty)
          construct KDTree from uniqval and use it for next line
          next_point = point in uniqval closest to current_point
          record next_point as target for current_point
          remove current_point from uniqval
          current_point = next_point


          What you will obtain is a linear graph joining all your points, using closest neighbors "in some way". I don't know if it will fit your needs. You would also obtain a linear graph by taking next_point at random...






          share|improve this answer
























          • Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

            – botibo
            Nov 21 '18 at 4:06











          • When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

            – Rolvernew
            Nov 21 '18 at 8:03











          • Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

            – botibo
            Nov 21 '18 at 10:27














          0












          0








          0







          Answering now about the global strategy, here is what I would do (rough pseudo-algorithm):



          current_point = one starting point in uniqval
          while (uniqval not empty)
          construct KDTree from uniqval and use it for next line
          next_point = point in uniqval closest to current_point
          record next_point as target for current_point
          remove current_point from uniqval
          current_point = next_point


          What you will obtain is a linear graph joining all your points, using closest neighbors "in some way". I don't know if it will fit your needs. You would also obtain a linear graph by taking next_point at random...






          share|improve this answer













          Answering now about the global strategy, here is what I would do (rough pseudo-algorithm):



          current_point = one starting point in uniqval
          while (uniqval not empty)
          construct KDTree from uniqval and use it for next line
          next_point = point in uniqval closest to current_point
          record next_point as target for current_point
          remove current_point from uniqval
          current_point = next_point


          What you will obtain is a linear graph joining all your points, using closest neighbors "in some way". I don't know if it will fit your needs. You would also obtain a linear graph by taking next_point at random...







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 20 '18 at 18:21









          RolvernewRolvernew

          1817




          1817













          • Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

            – botibo
            Nov 21 '18 at 4:06











          • When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

            – Rolvernew
            Nov 21 '18 at 8:03











          • Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

            – botibo
            Nov 21 '18 at 10:27



















          • Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

            – botibo
            Nov 21 '18 at 4:06











          • When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

            – Rolvernew
            Nov 21 '18 at 8:03











          • Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

            – botibo
            Nov 21 '18 at 10:27

















          Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

          – botibo
          Nov 21 '18 at 4:06





          Hi! Thanks for the solutions! I tried to do it with len(uniqval) != 1 and if not, the last point will be connected to the first point. But I faced another problem, I want to record the target point into the main dataframe (df) with the corresponding index of the current point. But as the current point changes to the closest point, how should I append it?

          – botibo
          Nov 21 '18 at 4:06













          When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

          – Rolvernew
          Nov 21 '18 at 8:03





          When I write "record next_point as target for current_point", next_point is the target and current_point is still available (with its index). Btw, if my answers help, do not hesitate to upvote or validate them...

          – Rolvernew
          Nov 21 '18 at 8:03













          Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

          – botibo
          Nov 21 '18 at 10:27





          Ah I see what you mean, thanks for the answer! It is what I am looking for and will absolutely upvote it

          – botibo
          Nov 21 '18 at 10:27













          0














          It is hard to comment on your global strategy without further detail about the kind of road network your want to obtain. So let me just comment your specific code and explain why the "out of range" error happens. I hope this can help.



          First, are you aware that (list_a and list_b) will return list_a if it is empty, else list_b? Second, isn't the condition (vq in list(df["coord"]) always True? If yes, then your while loop is just always executing the else statement, and at the last iteration of the for loop, (count-1) will be greater than the total number of (unique) points. Hence your KDTree query does not return enough points and clstu[count-1] is out of range.






          share|improve this answer
























          • thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

            – botibo
            Nov 20 '18 at 13:28











          • To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

            – Rolvernew
            Nov 20 '18 at 15:07











          • Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

            – botibo
            Nov 20 '18 at 15:54
















          0














          It is hard to comment on your global strategy without further detail about the kind of road network your want to obtain. So let me just comment your specific code and explain why the "out of range" error happens. I hope this can help.



          First, are you aware that (list_a and list_b) will return list_a if it is empty, else list_b? Second, isn't the condition (vq in list(df["coord"]) always True? If yes, then your while loop is just always executing the else statement, and at the last iteration of the for loop, (count-1) will be greater than the total number of (unique) points. Hence your KDTree query does not return enough points and clstu[count-1] is out of range.






          share|improve this answer
























          • thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

            – botibo
            Nov 20 '18 at 13:28











          • To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

            – Rolvernew
            Nov 20 '18 at 15:07











          • Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

            – botibo
            Nov 20 '18 at 15:54














          0












          0








          0







          It is hard to comment on your global strategy without further detail about the kind of road network your want to obtain. So let me just comment your specific code and explain why the "out of range" error happens. I hope this can help.



          First, are you aware that (list_a and list_b) will return list_a if it is empty, else list_b? Second, isn't the condition (vq in list(df["coord"]) always True? If yes, then your while loop is just always executing the else statement, and at the last iteration of the for loop, (count-1) will be greater than the total number of (unique) points. Hence your KDTree query does not return enough points and clstu[count-1] is out of range.






          share|improve this answer













          It is hard to comment on your global strategy without further detail about the kind of road network your want to obtain. So let me just comment your specific code and explain why the "out of range" error happens. I hope this can help.



          First, are you aware that (list_a and list_b) will return list_a if it is empty, else list_b? Second, isn't the condition (vq in list(df["coord"]) always True? If yes, then your while loop is just always executing the else statement, and at the last iteration of the for loop, (count-1) will be greater than the total number of (unique) points. Hence your KDTree query does not return enough points and clstu[count-1] is out of range.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 20 '18 at 8:56









          RolvernewRolvernew

          1817




          1817













          • thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

            – botibo
            Nov 20 '18 at 13:28











          • To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

            – Rolvernew
            Nov 20 '18 at 15:07











          • Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

            – botibo
            Nov 20 '18 at 15:54



















          • thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

            – botibo
            Nov 20 '18 at 13:28











          • To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

            – Rolvernew
            Nov 20 '18 at 15:07











          • Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

            – botibo
            Nov 20 '18 at 15:54

















          thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

          – botibo
          Nov 20 '18 at 13:28





          thanks for the comment! I was actually able to visualize it and this is the result of the code i.stack.imgur.com/CWltU.png, whereas the result that I want is like this i.stack.imgur.com/AxxKN.png. Yes I think I am aware because I want to fill the list a first, and if the point is already existed in list a, it needs to go to list_b (CMIIW). I think you are right, by that I just wanted to say that if the point has been used twice (as a starting point and target point), then another point in the closest distance of the iterated point needs to be appended in target column

          – botibo
          Nov 20 '18 at 13:28













          To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

          – Rolvernew
          Nov 20 '18 at 15:07





          To be more specific: I think the condition vq in (list(df["target"]) and list(df["coord"])) in your code is always True, so your code is probably not doing what you think it is.

          – Rolvernew
          Nov 20 '18 at 15:07













          Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

          – botibo
          Nov 20 '18 at 15:54





          Thanks for the input! I am trying to get through it but still stuck and still it returns to out of range. Do you have any ideas how to do it?

          – botibo
          Nov 20 '18 at 15:54


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • 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.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53388403%2fcreate-line-network-from-closest-points-with-boundaries%23new-answer', 'question_page');
          }
          );

          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







          Popular posts from this blog

          Guess what letter conforming each word

          Run scheduled task as local user group (not BUILTIN)

          Port of Spain