Sorting with IComparable designFluent LinkedIn REST API client interface designIComparable comparisionWebAPI - Return models vs entity and partial class with meta dataExceptions or something else?Message Based Communication DesignSorting array with respect to two propertiesIComparable implementation for a class representing a versionSorting algorithmUniversal sorting function with argsRectangle Class

Creating second map without labels using QGIS?

Has Ursula Le Guin ever admitted to be influenced by Kibbutz for the Dispossessed?

Shorten or merge multiple lines of `&> /dev/null &`

Can a UK national work as a paid shop assistant in the USA?

Sorting with IComparable design

Freedom of Speech and Assembly in China

Cardio work for Muay Thai fighters

The disk image is 497GB smaller than the target device

What weight should be given to writers groups critiques?

Final exams: What is the most common protocol for scheduling?

How to let other coworkers know that I don't share my coworker's political views?

Can we assume that a hash function with high collision resistance also means highly uniform distribution?

...And they were stumped for a long time

Expected maximum number of unpaired socks

Why A=2 and B=1 in the call signs for Spirit and Opportunity?

How can I properly write this equation in Latex?

What is the use case for non-breathable waterproof pants?

First Program Tic-Tac-Toe

What did the 'turbo' button actually do?

How does the Earth's center produce heat?

How to respond to an e-mail asking me to suggest a doctoral research topic?

Co-author wants to put their current funding source in the acknowledgements section because they edited the paper

I want to know what marumaru means

Dad jokes are fun



Sorting with IComparable design


Fluent LinkedIn REST API client interface designIComparable comparisionWebAPI - Return models vs entity and partial class with meta dataExceptions or something else?Message Based Communication DesignSorting array with respect to two propertiesIComparable implementation for a class representing a versionSorting algorithmUniversal sorting function with argsRectangle Class






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








3












$begingroup$


I got a C# class:



public class Agent 

public string AgentId set; get;
public double Longitude set; get;
public double Latitude set; get;



There are several agents in several different locations. During the program's lifetime, they can receive a call to another (latitude, longitude) point which is unknown during runtime. I got an API to calculate the distance in meters between their location and the given point. What I need eventually is to find the 5 closest agents to the given point.



What I did in order to achieve this is adding another class:



public class AgentDistance : Agent, IComparable<AgentDistance>


public AgentDistance(Agent agent)

if(agent == null)

throw new Exception("Can't initalize agent with distance since agent is null");

this.AgentId = agent.AgentId;
this.Latitude = agent.Latitude;
this.Longitude = agent.Longitude;


public double Distance set; get;

public int CompareTo(AgentDistance other)

if(other == null)

return 1;

return Distance.CompareTo(other.Distance);




And the usage:



 var agents = db.GetAgents();
if(agents == null || agents.Count == 0)

Console.WriteLine("No Results");

List<AgentDistance> agentsWithDistance = new List<AgentDistance>();
foreach(Agent agent in agents)

double res = ws.GetDistanceMeters(agent.Latitude, agent.Longitude, customerLatitude, customerLongitude);
agentsWithDistance.Add(new AgentDistance(agent) Distance = res );

agentsWithDistance.Sort();
for(int i = 0; i < 5; i++)

Console.WriteLine(string.Format("agent_id: 0 distance: 1 m", agentsWithDistance[i].AgentId, agentsWithDistance[i].Distance));



It works, but is there a more elegant way to do it? I'm not sure if adding another class might be a bit redundant since all it does is just adding a property for sorting, but adding the distance property to the Agent class, doesn't make so much sense.










share|improve this question







New contributor



Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






$endgroup$


















    3












    $begingroup$


    I got a C# class:



    public class Agent 

    public string AgentId set; get;
    public double Longitude set; get;
    public double Latitude set; get;



    There are several agents in several different locations. During the program's lifetime, they can receive a call to another (latitude, longitude) point which is unknown during runtime. I got an API to calculate the distance in meters between their location and the given point. What I need eventually is to find the 5 closest agents to the given point.



    What I did in order to achieve this is adding another class:



    public class AgentDistance : Agent, IComparable<AgentDistance>


    public AgentDistance(Agent agent)

    if(agent == null)

    throw new Exception("Can't initalize agent with distance since agent is null");

    this.AgentId = agent.AgentId;
    this.Latitude = agent.Latitude;
    this.Longitude = agent.Longitude;


    public double Distance set; get;

    public int CompareTo(AgentDistance other)

    if(other == null)

    return 1;

    return Distance.CompareTo(other.Distance);




    And the usage:



     var agents = db.GetAgents();
    if(agents == null || agents.Count == 0)

    Console.WriteLine("No Results");

    List<AgentDistance> agentsWithDistance = new List<AgentDistance>();
    foreach(Agent agent in agents)

    double res = ws.GetDistanceMeters(agent.Latitude, agent.Longitude, customerLatitude, customerLongitude);
    agentsWithDistance.Add(new AgentDistance(agent) Distance = res );

    agentsWithDistance.Sort();
    for(int i = 0; i < 5; i++)

    Console.WriteLine(string.Format("agent_id: 0 distance: 1 m", agentsWithDistance[i].AgentId, agentsWithDistance[i].Distance));



    It works, but is there a more elegant way to do it? I'm not sure if adding another class might be a bit redundant since all it does is just adding a property for sorting, but adding the distance property to the Agent class, doesn't make so much sense.










    share|improve this question







    New contributor



    Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.






    $endgroup$














      3












      3








      3





      $begingroup$


      I got a C# class:



      public class Agent 

      public string AgentId set; get;
      public double Longitude set; get;
      public double Latitude set; get;



      There are several agents in several different locations. During the program's lifetime, they can receive a call to another (latitude, longitude) point which is unknown during runtime. I got an API to calculate the distance in meters between their location and the given point. What I need eventually is to find the 5 closest agents to the given point.



      What I did in order to achieve this is adding another class:



      public class AgentDistance : Agent, IComparable<AgentDistance>


      public AgentDistance(Agent agent)

      if(agent == null)

      throw new Exception("Can't initalize agent with distance since agent is null");

      this.AgentId = agent.AgentId;
      this.Latitude = agent.Latitude;
      this.Longitude = agent.Longitude;


      public double Distance set; get;

      public int CompareTo(AgentDistance other)

      if(other == null)

      return 1;

      return Distance.CompareTo(other.Distance);




      And the usage:



       var agents = db.GetAgents();
      if(agents == null || agents.Count == 0)

      Console.WriteLine("No Results");

      List<AgentDistance> agentsWithDistance = new List<AgentDistance>();
      foreach(Agent agent in agents)

      double res = ws.GetDistanceMeters(agent.Latitude, agent.Longitude, customerLatitude, customerLongitude);
      agentsWithDistance.Add(new AgentDistance(agent) Distance = res );

      agentsWithDistance.Sort();
      for(int i = 0; i < 5; i++)

      Console.WriteLine(string.Format("agent_id: 0 distance: 1 m", agentsWithDistance[i].AgentId, agentsWithDistance[i].Distance));



      It works, but is there a more elegant way to do it? I'm not sure if adding another class might be a bit redundant since all it does is just adding a property for sorting, but adding the distance property to the Agent class, doesn't make so much sense.










      share|improve this question







      New contributor



      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      $endgroup$




      I got a C# class:



      public class Agent 

      public string AgentId set; get;
      public double Longitude set; get;
      public double Latitude set; get;



      There are several agents in several different locations. During the program's lifetime, they can receive a call to another (latitude, longitude) point which is unknown during runtime. I got an API to calculate the distance in meters between their location and the given point. What I need eventually is to find the 5 closest agents to the given point.



      What I did in order to achieve this is adding another class:



      public class AgentDistance : Agent, IComparable<AgentDistance>


      public AgentDistance(Agent agent)

      if(agent == null)

      throw new Exception("Can't initalize agent with distance since agent is null");

      this.AgentId = agent.AgentId;
      this.Latitude = agent.Latitude;
      this.Longitude = agent.Longitude;


      public double Distance set; get;

      public int CompareTo(AgentDistance other)

      if(other == null)

      return 1;

      return Distance.CompareTo(other.Distance);




      And the usage:



       var agents = db.GetAgents();
      if(agents == null || agents.Count == 0)

      Console.WriteLine("No Results");

      List<AgentDistance> agentsWithDistance = new List<AgentDistance>();
      foreach(Agent agent in agents)

      double res = ws.GetDistanceMeters(agent.Latitude, agent.Longitude, customerLatitude, customerLongitude);
      agentsWithDistance.Add(new AgentDistance(agent) Distance = res );

      agentsWithDistance.Sort();
      for(int i = 0; i < 5; i++)

      Console.WriteLine(string.Format("agent_id: 0 distance: 1 m", agentsWithDistance[i].AgentId, agentsWithDistance[i].Distance));



      It works, but is there a more elegant way to do it? I'm not sure if adding another class might be a bit redundant since all it does is just adding a property for sorting, but adding the distance property to the Agent class, doesn't make so much sense.







      c# sorting






      share|improve this question







      New contributor



      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.










      share|improve this question







      New contributor



      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.








      share|improve this question




      share|improve this question






      New contributor



      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.








      asked 9 hours ago









      Yonatan NirYonatan Nir

      1184




      1184




      New contributor



      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




      New contributor




      Yonatan Nir is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          2 Answers
          2






          active

          oldest

          votes


















          5












          $begingroup$


          var agents = db.GetAgents();
          if(agents == null || agents.Count == 0)

          Console.WriteLine("No Results");




          You should exit your application/code block when you detect an invalid state. Here even if "No Results" is printed, the app will still run into a NullReferenceException or IndexOutOfRangeException in the next few steps. Also, talking of IndexOutOfRangeException, there is no check against if there is at least 5 agents in your db.



          Instead of creating an IComparable, you can just use linq to sort directly. But, since in your case, you also need to print out the distance (the value used for sorting), we will need to create an anonymous class to hold it:



          var agents = db.GetAgents();
          if(agents == null || agents.Count == 0)

          Console.WriteLine("No Results");
          return;


          var nearestAgents = agents
          .Select(x => new

          x.AgentId,
          x.Latitude, x.Longitude,
          DistanceToCustomer = ws.GetDistanceMeters(x.Latitude, x.Longitude, customerLatitude, customerLongitude)
          )
          .OrderBy(x => x.DistanceToCustomer);
          foreach (var agent in nearestAgents.Take(5))

          Console.WriteLine($"agent_id: agent.AgentId distance: agent.DistanceToCustomer m");



          The .Take(5) ensures that only 5 agent will be printed out, or less.






          share|improve this answer











          $endgroup$




















            4












            $begingroup$

            I'd say you have the following options:




            1. Keep that new class if you think it's relevant in your business. Here, it should be important to know if the logic of calculate the distance should be on that web service (I assume that 'ws' variable means that) or within your model (i.e., the 'Agent' class).


            2. Use an anonymous class if you think you won't pass that info to another method.


            3. Use a dictionary if you think it's not relevant in your business but will pass that info to another method.

            Personally, I'd go for the first one since it's the most natural to me. By the way, I'd use LINQ's OrderBy instead of implementing the IComparable interface; again, for expressiveness.






            share|improve this answer









            $endgroup$













              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: "196"
              ;
              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: false,
              noModals: true,
              showLowRepImageUploadWarning: true,
              reputationToPostImages: null,
              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
              );



              );






              Yonatan Nir is a new contributor. Be nice, and check out our Code of Conduct.









              draft saved

              draft discarded


















              StackExchange.ready(
              function ()
              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f220650%2fsorting-with-icomparable-design%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









              5












              $begingroup$


              var agents = db.GetAgents();
              if(agents == null || agents.Count == 0)

              Console.WriteLine("No Results");




              You should exit your application/code block when you detect an invalid state. Here even if "No Results" is printed, the app will still run into a NullReferenceException or IndexOutOfRangeException in the next few steps. Also, talking of IndexOutOfRangeException, there is no check against if there is at least 5 agents in your db.



              Instead of creating an IComparable, you can just use linq to sort directly. But, since in your case, you also need to print out the distance (the value used for sorting), we will need to create an anonymous class to hold it:



              var agents = db.GetAgents();
              if(agents == null || agents.Count == 0)

              Console.WriteLine("No Results");
              return;


              var nearestAgents = agents
              .Select(x => new

              x.AgentId,
              x.Latitude, x.Longitude,
              DistanceToCustomer = ws.GetDistanceMeters(x.Latitude, x.Longitude, customerLatitude, customerLongitude)
              )
              .OrderBy(x => x.DistanceToCustomer);
              foreach (var agent in nearestAgents.Take(5))

              Console.WriteLine($"agent_id: agent.AgentId distance: agent.DistanceToCustomer m");



              The .Take(5) ensures that only 5 agent will be printed out, or less.






              share|improve this answer











              $endgroup$

















                5












                $begingroup$


                var agents = db.GetAgents();
                if(agents == null || agents.Count == 0)

                Console.WriteLine("No Results");




                You should exit your application/code block when you detect an invalid state. Here even if "No Results" is printed, the app will still run into a NullReferenceException or IndexOutOfRangeException in the next few steps. Also, talking of IndexOutOfRangeException, there is no check against if there is at least 5 agents in your db.



                Instead of creating an IComparable, you can just use linq to sort directly. But, since in your case, you also need to print out the distance (the value used for sorting), we will need to create an anonymous class to hold it:



                var agents = db.GetAgents();
                if(agents == null || agents.Count == 0)

                Console.WriteLine("No Results");
                return;


                var nearestAgents = agents
                .Select(x => new

                x.AgentId,
                x.Latitude, x.Longitude,
                DistanceToCustomer = ws.GetDistanceMeters(x.Latitude, x.Longitude, customerLatitude, customerLongitude)
                )
                .OrderBy(x => x.DistanceToCustomer);
                foreach (var agent in nearestAgents.Take(5))

                Console.WriteLine($"agent_id: agent.AgentId distance: agent.DistanceToCustomer m");



                The .Take(5) ensures that only 5 agent will be printed out, or less.






                share|improve this answer











                $endgroup$















                  5












                  5








                  5





                  $begingroup$


                  var agents = db.GetAgents();
                  if(agents == null || agents.Count == 0)

                  Console.WriteLine("No Results");




                  You should exit your application/code block when you detect an invalid state. Here even if "No Results" is printed, the app will still run into a NullReferenceException or IndexOutOfRangeException in the next few steps. Also, talking of IndexOutOfRangeException, there is no check against if there is at least 5 agents in your db.



                  Instead of creating an IComparable, you can just use linq to sort directly. But, since in your case, you also need to print out the distance (the value used for sorting), we will need to create an anonymous class to hold it:



                  var agents = db.GetAgents();
                  if(agents == null || agents.Count == 0)

                  Console.WriteLine("No Results");
                  return;


                  var nearestAgents = agents
                  .Select(x => new

                  x.AgentId,
                  x.Latitude, x.Longitude,
                  DistanceToCustomer = ws.GetDistanceMeters(x.Latitude, x.Longitude, customerLatitude, customerLongitude)
                  )
                  .OrderBy(x => x.DistanceToCustomer);
                  foreach (var agent in nearestAgents.Take(5))

                  Console.WriteLine($"agent_id: agent.AgentId distance: agent.DistanceToCustomer m");



                  The .Take(5) ensures that only 5 agent will be printed out, or less.






                  share|improve this answer











                  $endgroup$




                  var agents = db.GetAgents();
                  if(agents == null || agents.Count == 0)

                  Console.WriteLine("No Results");




                  You should exit your application/code block when you detect an invalid state. Here even if "No Results" is printed, the app will still run into a NullReferenceException or IndexOutOfRangeException in the next few steps. Also, talking of IndexOutOfRangeException, there is no check against if there is at least 5 agents in your db.



                  Instead of creating an IComparable, you can just use linq to sort directly. But, since in your case, you also need to print out the distance (the value used for sorting), we will need to create an anonymous class to hold it:



                  var agents = db.GetAgents();
                  if(agents == null || agents.Count == 0)

                  Console.WriteLine("No Results");
                  return;


                  var nearestAgents = agents
                  .Select(x => new

                  x.AgentId,
                  x.Latitude, x.Longitude,
                  DistanceToCustomer = ws.GetDistanceMeters(x.Latitude, x.Longitude, customerLatitude, customerLongitude)
                  )
                  .OrderBy(x => x.DistanceToCustomer);
                  foreach (var agent in nearestAgents.Take(5))

                  Console.WriteLine($"agent_id: agent.AgentId distance: agent.DistanceToCustomer m");



                  The .Take(5) ensures that only 5 agent will be printed out, or less.







                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  edited 7 hours ago

























                  answered 8 hours ago









                  Xiaoy312Xiaoy312

                  2,9761016




                  2,9761016























                      4












                      $begingroup$

                      I'd say you have the following options:




                      1. Keep that new class if you think it's relevant in your business. Here, it should be important to know if the logic of calculate the distance should be on that web service (I assume that 'ws' variable means that) or within your model (i.e., the 'Agent' class).


                      2. Use an anonymous class if you think you won't pass that info to another method.


                      3. Use a dictionary if you think it's not relevant in your business but will pass that info to another method.

                      Personally, I'd go for the first one since it's the most natural to me. By the way, I'd use LINQ's OrderBy instead of implementing the IComparable interface; again, for expressiveness.






                      share|improve this answer









                      $endgroup$

















                        4












                        $begingroup$

                        I'd say you have the following options:




                        1. Keep that new class if you think it's relevant in your business. Here, it should be important to know if the logic of calculate the distance should be on that web service (I assume that 'ws' variable means that) or within your model (i.e., the 'Agent' class).


                        2. Use an anonymous class if you think you won't pass that info to another method.


                        3. Use a dictionary if you think it's not relevant in your business but will pass that info to another method.

                        Personally, I'd go for the first one since it's the most natural to me. By the way, I'd use LINQ's OrderBy instead of implementing the IComparable interface; again, for expressiveness.






                        share|improve this answer









                        $endgroup$















                          4












                          4








                          4





                          $begingroup$

                          I'd say you have the following options:




                          1. Keep that new class if you think it's relevant in your business. Here, it should be important to know if the logic of calculate the distance should be on that web service (I assume that 'ws' variable means that) or within your model (i.e., the 'Agent' class).


                          2. Use an anonymous class if you think you won't pass that info to another method.


                          3. Use a dictionary if you think it's not relevant in your business but will pass that info to another method.

                          Personally, I'd go for the first one since it's the most natural to me. By the way, I'd use LINQ's OrderBy instead of implementing the IComparable interface; again, for expressiveness.






                          share|improve this answer









                          $endgroup$



                          I'd say you have the following options:




                          1. Keep that new class if you think it's relevant in your business. Here, it should be important to know if the logic of calculate the distance should be on that web service (I assume that 'ws' variable means that) or within your model (i.e., the 'Agent' class).


                          2. Use an anonymous class if you think you won't pass that info to another method.


                          3. Use a dictionary if you think it's not relevant in your business but will pass that info to another method.

                          Personally, I'd go for the first one since it's the most natural to me. By the way, I'd use LINQ's OrderBy instead of implementing the IComparable interface; again, for expressiveness.







                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered 8 hours ago









                          A Bravo DevA Bravo Dev

                          579210




                          579210




















                              Yonatan Nir is a new contributor. Be nice, and check out our Code of Conduct.









                              draft saved

                              draft discarded


















                              Yonatan Nir is a new contributor. Be nice, and check out our Code of Conduct.












                              Yonatan Nir is a new contributor. Be nice, and check out our Code of Conduct.











                              Yonatan Nir is a new contributor. Be nice, and check out our Code of Conduct.














                              Thanks for contributing an answer to Code Review 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.




                              draft saved


                              draft discarded














                              StackExchange.ready(
                              function ()
                              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f220650%2fsorting-with-icomparable-design%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

                              ParseJSON using SSJSUsing AMPscript with SSJS ActivitiesHow to resubscribe a user in Marketing cloud using SSJS?Pulling Subscriber Status from Lists using SSJSRetrieving Emails using SSJSProblem in updating DE using SSJSUsing SSJS to send single email in Marketing CloudError adding EmailSendDefinition using SSJS

                              Кампала Садржај Географија Географија Историја Становништво Привреда Партнерски градови Референце Спољашње везе Мени за навигацију0°11′ СГШ; 32°20′ ИГД / 0.18° СГШ; 32.34° ИГД / 0.18; 32.340°11′ СГШ; 32°20′ ИГД / 0.18° СГШ; 32.34° ИГД / 0.18; 32.34МедијиПодациЗванични веб-сајту

                              Кастелфранко ди Сопра Становништво Референце Спољашње везе Мени за навигацију43°37′18″ СГШ; 11°33′32″ ИГД / 43.62156° СГШ; 11.55885° ИГД / 43.62156; 11.5588543°37′18″ СГШ; 11°33′32″ ИГД / 43.62156° СГШ; 11.55885° ИГД / 43.62156; 11.558853179688„The GeoNames geographical database”„Istituto Nazionale di Statistica”проширитиууWorldCat156923403n850174324558639-1cb14643287r(подаци)