Short(er) hand for min max percentage?












0














I have a function that converts two values to a percentage within a range, in this case between 15000 and 100000. It feels very clunky. Is there a more simple way to express this which is easy/easier to understand?



price2percent = (sale) => {
let price = sale.soldPrice / sale.livingArea;
// Specifically these values
price = price > 100000 ? 100000 : price;
price = price < 15000 ? 15000 : price;

return (price - 1500) / 85000;
}









share|improve this question





























    0














    I have a function that converts two values to a percentage within a range, in this case between 15000 and 100000. It feels very clunky. Is there a more simple way to express this which is easy/easier to understand?



    price2percent = (sale) => {
    let price = sale.soldPrice / sale.livingArea;
    // Specifically these values
    price = price > 100000 ? 100000 : price;
    price = price < 15000 ? 15000 : price;

    return (price - 1500) / 85000;
    }









    share|improve this question



























      0












      0








      0


      0





      I have a function that converts two values to a percentage within a range, in this case between 15000 and 100000. It feels very clunky. Is there a more simple way to express this which is easy/easier to understand?



      price2percent = (sale) => {
      let price = sale.soldPrice / sale.livingArea;
      // Specifically these values
      price = price > 100000 ? 100000 : price;
      price = price < 15000 ? 15000 : price;

      return (price - 1500) / 85000;
      }









      share|improve this question















      I have a function that converts two values to a percentage within a range, in this case between 15000 and 100000. It feels very clunky. Is there a more simple way to express this which is easy/easier to understand?



      price2percent = (sale) => {
      let price = sale.soldPrice / sale.livingArea;
      // Specifically these values
      price = price > 100000 ? 100000 : price;
      price = price < 15000 ? 15000 : price;

      return (price - 1500) / 85000;
      }






      javascript ecmascript-6






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 20 '18 at 11:12









      Will Madden

      2,40321417




      2,40321417










      asked Nov 20 '18 at 10:55









      Himmators

      5,5702685173




      5,5702685173
























          3 Answers
          3






          active

          oldest

          votes


















          2














          You might use Math.min and Math.max to constrain the ranges:



          const adjustedPrice = Math.min(
          100000, // can be no higher than 100000
          Math.max(price, 15000) // can be no lower than 15000
          );
          return (adjustedPrice - 1500) / 85000;


          Another option is nested conditionals, which will reduce the number of unnecessary reassignments, though it doesn't exactly make the code clearer:



          const adjustedPrice =
          price > 100000 ? 100000 :
          price < 15000 ? 15000 : price





          share|improve this answer





























            1














            I usually use this utility for things like that:



            const clamp = (value, min, max) => value > min? value < max? value: max: min;

            price2percent = (sale) => {
            let price = clamp(sale.soldPrice / sale.livingArea, 15000, 100000);
            return (price - 1500) / 85000;
            }


            I find that more readable than the Math.min(max, Math.max(min, value)) construct.



            Downside, in its current version it doesn't play well with NaN.






            share|improve this answer































              0















              Is there a more simple way to express this which is easy/easier to understand?




              Easy to understand would be using if/else condition:



              price2percent = (sale) => {
              let price = sale.soldPrice / sale.livingArea;
              if(price > 100000) price = 100000
              else if(price < 15000) price = 15000
              return (price - 1500) / 85000;
              }


              Which can be expressed shorter as: (the harder way)



              price2percent = (sale) => {
              let price = sale.soldPrice / sale.livingArea;
              price = price > 100000 ? 100000 : (price < 15000 ? 15000 : price)
              return (price - 1500) / 85000;
              }





              share|improve this answer























                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%2f53391448%2fshorter-hand-for-min-max-percentage%23new-answer', 'question_page');
                }
                );

                Post as a guest















                Required, but never shown

























                3 Answers
                3






                active

                oldest

                votes








                3 Answers
                3






                active

                oldest

                votes









                active

                oldest

                votes






                active

                oldest

                votes









                2














                You might use Math.min and Math.max to constrain the ranges:



                const adjustedPrice = Math.min(
                100000, // can be no higher than 100000
                Math.max(price, 15000) // can be no lower than 15000
                );
                return (adjustedPrice - 1500) / 85000;


                Another option is nested conditionals, which will reduce the number of unnecessary reassignments, though it doesn't exactly make the code clearer:



                const adjustedPrice =
                price > 100000 ? 100000 :
                price < 15000 ? 15000 : price





                share|improve this answer


























                  2














                  You might use Math.min and Math.max to constrain the ranges:



                  const adjustedPrice = Math.min(
                  100000, // can be no higher than 100000
                  Math.max(price, 15000) // can be no lower than 15000
                  );
                  return (adjustedPrice - 1500) / 85000;


                  Another option is nested conditionals, which will reduce the number of unnecessary reassignments, though it doesn't exactly make the code clearer:



                  const adjustedPrice =
                  price > 100000 ? 100000 :
                  price < 15000 ? 15000 : price





                  share|improve this answer
























                    2












                    2








                    2






                    You might use Math.min and Math.max to constrain the ranges:



                    const adjustedPrice = Math.min(
                    100000, // can be no higher than 100000
                    Math.max(price, 15000) // can be no lower than 15000
                    );
                    return (adjustedPrice - 1500) / 85000;


                    Another option is nested conditionals, which will reduce the number of unnecessary reassignments, though it doesn't exactly make the code clearer:



                    const adjustedPrice =
                    price > 100000 ? 100000 :
                    price < 15000 ? 15000 : price





                    share|improve this answer












                    You might use Math.min and Math.max to constrain the ranges:



                    const adjustedPrice = Math.min(
                    100000, // can be no higher than 100000
                    Math.max(price, 15000) // can be no lower than 15000
                    );
                    return (adjustedPrice - 1500) / 85000;


                    Another option is nested conditionals, which will reduce the number of unnecessary reassignments, though it doesn't exactly make the code clearer:



                    const adjustedPrice =
                    price > 100000 ? 100000 :
                    price < 15000 ? 15000 : price






                    share|improve this answer












                    share|improve this answer



                    share|improve this answer










                    answered Nov 20 '18 at 10:58









                    CertainPerformance

                    76.5k143862




                    76.5k143862

























                        1














                        I usually use this utility for things like that:



                        const clamp = (value, min, max) => value > min? value < max? value: max: min;

                        price2percent = (sale) => {
                        let price = clamp(sale.soldPrice / sale.livingArea, 15000, 100000);
                        return (price - 1500) / 85000;
                        }


                        I find that more readable than the Math.min(max, Math.max(min, value)) construct.



                        Downside, in its current version it doesn't play well with NaN.






                        share|improve this answer




























                          1














                          I usually use this utility for things like that:



                          const clamp = (value, min, max) => value > min? value < max? value: max: min;

                          price2percent = (sale) => {
                          let price = clamp(sale.soldPrice / sale.livingArea, 15000, 100000);
                          return (price - 1500) / 85000;
                          }


                          I find that more readable than the Math.min(max, Math.max(min, value)) construct.



                          Downside, in its current version it doesn't play well with NaN.






                          share|improve this answer


























                            1












                            1








                            1






                            I usually use this utility for things like that:



                            const clamp = (value, min, max) => value > min? value < max? value: max: min;

                            price2percent = (sale) => {
                            let price = clamp(sale.soldPrice / sale.livingArea, 15000, 100000);
                            return (price - 1500) / 85000;
                            }


                            I find that more readable than the Math.min(max, Math.max(min, value)) construct.



                            Downside, in its current version it doesn't play well with NaN.






                            share|improve this answer














                            I usually use this utility for things like that:



                            const clamp = (value, min, max) => value > min? value < max? value: max: min;

                            price2percent = (sale) => {
                            let price = clamp(sale.soldPrice / sale.livingArea, 15000, 100000);
                            return (price - 1500) / 85000;
                            }


                            I find that more readable than the Math.min(max, Math.max(min, value)) construct.



                            Downside, in its current version it doesn't play well with NaN.







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited Nov 20 '18 at 20:05

























                            answered Nov 20 '18 at 11:13









                            Thomas

                            4,582159




                            4,582159























                                0















                                Is there a more simple way to express this which is easy/easier to understand?




                                Easy to understand would be using if/else condition:



                                price2percent = (sale) => {
                                let price = sale.soldPrice / sale.livingArea;
                                if(price > 100000) price = 100000
                                else if(price < 15000) price = 15000
                                return (price - 1500) / 85000;
                                }


                                Which can be expressed shorter as: (the harder way)



                                price2percent = (sale) => {
                                let price = sale.soldPrice / sale.livingArea;
                                price = price > 100000 ? 100000 : (price < 15000 ? 15000 : price)
                                return (price - 1500) / 85000;
                                }





                                share|improve this answer




























                                  0















                                  Is there a more simple way to express this which is easy/easier to understand?




                                  Easy to understand would be using if/else condition:



                                  price2percent = (sale) => {
                                  let price = sale.soldPrice / sale.livingArea;
                                  if(price > 100000) price = 100000
                                  else if(price < 15000) price = 15000
                                  return (price - 1500) / 85000;
                                  }


                                  Which can be expressed shorter as: (the harder way)



                                  price2percent = (sale) => {
                                  let price = sale.soldPrice / sale.livingArea;
                                  price = price > 100000 ? 100000 : (price < 15000 ? 15000 : price)
                                  return (price - 1500) / 85000;
                                  }





                                  share|improve this answer


























                                    0












                                    0








                                    0







                                    Is there a more simple way to express this which is easy/easier to understand?




                                    Easy to understand would be using if/else condition:



                                    price2percent = (sale) => {
                                    let price = sale.soldPrice / sale.livingArea;
                                    if(price > 100000) price = 100000
                                    else if(price < 15000) price = 15000
                                    return (price - 1500) / 85000;
                                    }


                                    Which can be expressed shorter as: (the harder way)



                                    price2percent = (sale) => {
                                    let price = sale.soldPrice / sale.livingArea;
                                    price = price > 100000 ? 100000 : (price < 15000 ? 15000 : price)
                                    return (price - 1500) / 85000;
                                    }





                                    share|improve this answer















                                    Is there a more simple way to express this which is easy/easier to understand?




                                    Easy to understand would be using if/else condition:



                                    price2percent = (sale) => {
                                    let price = sale.soldPrice / sale.livingArea;
                                    if(price > 100000) price = 100000
                                    else if(price < 15000) price = 15000
                                    return (price - 1500) / 85000;
                                    }


                                    Which can be expressed shorter as: (the harder way)



                                    price2percent = (sale) => {
                                    let price = sale.soldPrice / sale.livingArea;
                                    price = price > 100000 ? 100000 : (price < 15000 ? 15000 : price)
                                    return (price - 1500) / 85000;
                                    }






                                    share|improve this answer














                                    share|improve this answer



                                    share|improve this answer








                                    edited Nov 20 '18 at 12:52

























                                    answered Nov 20 '18 at 12:47









                                    Bhojendra Rauniyar

                                    50.7k2079124




                                    50.7k2079124






























                                        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.





                                        Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                                        Please pay close attention to the following guidance:


                                        • 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%2f53391448%2fshorter-hand-for-min-max-percentage%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

                                        If I really need a card on my start hand, how many mulligans make sense? [duplicate]

                                        Alcedinidae

                                        Can an atomic nucleus contain both particles and antiparticles? [duplicate]