map list to bin numbersquantilization (if that is a word)Map efficiently over duplicates in listGenerating a list of cubefree numbersIs there an equivalent to MATLAB's linspace?Convert a list of hexadecimal numbers to decimalTaking one list Mod a second listlist of items and group of alternative itemsHow find numbers in this list of inequalities?Selecting list entries with a True False index list of similar lengthReplace element in array by checking condition in another listAttempting to fill a table with the number of elements in each bin and make a table with the elements in the bins?

Is there any use for defining additional entity types in a SOQL FROM clause?

Why is my log file so massive? 22gb. I am running log backups

"listening to me about as much as you're listening to this pole here"

Copycat chess is back

Could a US political party gain complete control over the government by removing checks & balances?

Lied on resume at previous job

What to wear for invited talk in Canada

How did the USSR manage to innovate in an environment characterized by government censorship and high bureaucracy?

Can the Produce Flame cantrip be used to grapple, or as an unarmed strike, in the right circumstances?

Unbreakable Formation vs. Cry of the Carnarium

Why do we use polarized capacitors?

Ideas for 3rd eye abilities

Landlord wants to switch my lease to a "Land contract" to "get back at the city"

What do the Banks children have against barley water?

How can I add custom success page

I’m planning on buying a laser printer but concerned about the life cycle of toner in the machine

Manga about a female worker who got dragged into another world together with this high school girl and she was just told she's not needed anymore

How do I create uniquely male characters?

What is GPS' 19 year rollover and does it present a cybersecurity issue?

Symmetry in quantum mechanics

Typesetting a double Over Dot on top of a symbol

What causes the sudden spool-up sound from an F-16 when enabling afterburner?

Can a planet have a different gravitational pull depending on its location in orbit around its sun?

What is the command to reset a PC without deleting any files



map list to bin numbers


quantilization (if that is a word)Map efficiently over duplicates in listGenerating a list of cubefree numbersIs there an equivalent to MATLAB's linspace?Convert a list of hexadecimal numbers to decimalTaking one list Mod a second listlist of items and group of alternative itemsHow find numbers in this list of inequalities?Selecting list entries with a True False index list of similar lengthReplace element in array by checking condition in another listAttempting to fill a table with the number of elements in each bin and make a table with the elements in the bins?













1












$begingroup$


Does WL have the equivalent of Matlab's discretize or NumPy's digitize? I.e., a function that takes a length-N list and a list of bin edges and returns a length-N list of bin numbers, mapping each list item to its bin number?










share|improve this question











$endgroup$











  • $begingroup$
    HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
    $endgroup$
    – b3m2a1
    6 hours ago











  • $begingroup$
    I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
    $endgroup$
    – Alan
    5 hours ago











  • $begingroup$
    Related: 140577
    $endgroup$
    – Carl Woll
    1 hour ago











  • $begingroup$
    Did you try BinCounts? I guess it is what you need.
    $endgroup$
    – Rom38
    25 mins ago















1












$begingroup$


Does WL have the equivalent of Matlab's discretize or NumPy's digitize? I.e., a function that takes a length-N list and a list of bin edges and returns a length-N list of bin numbers, mapping each list item to its bin number?










share|improve this question











$endgroup$











  • $begingroup$
    HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
    $endgroup$
    – b3m2a1
    6 hours ago











  • $begingroup$
    I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
    $endgroup$
    – Alan
    5 hours ago











  • $begingroup$
    Related: 140577
    $endgroup$
    – Carl Woll
    1 hour ago











  • $begingroup$
    Did you try BinCounts? I guess it is what you need.
    $endgroup$
    – Rom38
    25 mins ago













1












1








1





$begingroup$


Does WL have the equivalent of Matlab's discretize or NumPy's digitize? I.e., a function that takes a length-N list and a list of bin edges and returns a length-N list of bin numbers, mapping each list item to its bin number?










share|improve this question











$endgroup$




Does WL have the equivalent of Matlab's discretize or NumPy's digitize? I.e., a function that takes a length-N list and a list of bin edges and returns a length-N list of bin numbers, mapping each list item to its bin number?







list-manipulation data






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 1 hour ago









Carl Woll

73k396189




73k396189










asked 6 hours ago









AlanAlan

6,6331125




6,6331125











  • $begingroup$
    HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
    $endgroup$
    – b3m2a1
    6 hours ago











  • $begingroup$
    I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
    $endgroup$
    – Alan
    5 hours ago











  • $begingroup$
    Related: 140577
    $endgroup$
    – Carl Woll
    1 hour ago











  • $begingroup$
    Did you try BinCounts? I guess it is what you need.
    $endgroup$
    – Rom38
    25 mins ago
















  • $begingroup$
    HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
    $endgroup$
    – b3m2a1
    6 hours ago











  • $begingroup$
    I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
    $endgroup$
    – Alan
    5 hours ago











  • $begingroup$
    Related: 140577
    $endgroup$
    – Carl Woll
    1 hour ago











  • $begingroup$
    Did you try BinCounts? I guess it is what you need.
    $endgroup$
    – Rom38
    25 mins ago















$begingroup$
HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
$endgroup$
– b3m2a1
6 hours ago





$begingroup$
HistogramList seems similar. This could also be done efficiently with GroupBy and some easy little Compile-d selection determiner. Or maybe hit it first with Sort then write something that only checks the next bin up. Again, can be easily Compile-d.
$endgroup$
– b3m2a1
6 hours ago













$begingroup$
I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
$endgroup$
– Alan
5 hours ago





$begingroup$
I need it to work like a map (in terms of the order of the items in the resulting list). Of course it is possible to write something ...
$endgroup$
– Alan
5 hours ago













$begingroup$
Related: 140577
$endgroup$
– Carl Woll
1 hour ago





$begingroup$
Related: 140577
$endgroup$
– Carl Woll
1 hour ago













$begingroup$
Did you try BinCounts? I guess it is what you need.
$endgroup$
– Rom38
25 mins ago




$begingroup$
Did you try BinCounts? I guess it is what you need.
$endgroup$
– Rom38
25 mins ago










2 Answers
2






active

oldest

votes


















4












$begingroup$

This is a very quick-n-dirty, but may serve as a simple example.



This creates a piecewise function following the first definition in Matlab's discretize documentation, then applies that to the data.



disc[data_, edges_] := Module[e = Partition[edges, 2, 1], p, l,
l = Length@e;
Table[Piecewise[
Append[Table[i, e[[i, 1]] <= x < e[[i, 2]], i, l - 1]
, l,e[[l, 1]] <= x <= e[[l, 2]]]
, "NaN"]
, x, data]];


From the first example in the above referenced documentation:



data=1, 1, 2, 3, 6, 5, 8, 10, 4, 4;
edges=2, 4, 6, 8, 10;

disc[data,edges]



NaN,NaN,1,1,3,2,4,4,2,2




I'm sure there are more efficient/elegant solutions, and will revisit as time permits.






share|improve this answer









$endgroup$




















    0












    $begingroup$

    Here's a version based on Nearest:



    digitize[edges_] := DigitizeFunction[edges, Nearest[edges -> "Index"]]
    digitize[data_, edges_] := digitize[edges][data]

    DigitizeFunction[edges_, nf_NearestFunction][data_] := With[init = nf[data][[All, 1]],
    init + UnitStep[data - edges[[init]]] - 1
    ]


    For example:



    SeedRandom[1]
    data = RandomReal[10, 10]
    digitize[data, 2, 4, 5, 7, 8]



    8.17389, 1.1142, 7.89526, 1.87803, 2.41361, 0.657388, 5.42247, 2.31155, 3.96006, 7.00474



    5, 0, 4, 0, 1, 0, 3, 1, 1, 4




    Note that I broke up the definition of digitize into two pieces, so that if you do this for multiple data sets with the same edges list, you only need to compute the nearest function once.






    share|improve this answer











    $endgroup$













      Your Answer





      StackExchange.ifUsing("editor", function ()
      return StackExchange.using("mathjaxEditing", function ()
      StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
      StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
      );
      );
      , "mathjax-editing");

      StackExchange.ready(function()
      var channelOptions =
      tags: "".split(" "),
      id: "387"
      ;
      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
      );



      );













      draft saved

      draft discarded


















      StackExchange.ready(
      function ()
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f194844%2fmap-list-to-bin-numbers%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









      4












      $begingroup$

      This is a very quick-n-dirty, but may serve as a simple example.



      This creates a piecewise function following the first definition in Matlab's discretize documentation, then applies that to the data.



      disc[data_, edges_] := Module[e = Partition[edges, 2, 1], p, l,
      l = Length@e;
      Table[Piecewise[
      Append[Table[i, e[[i, 1]] <= x < e[[i, 2]], i, l - 1]
      , l,e[[l, 1]] <= x <= e[[l, 2]]]
      , "NaN"]
      , x, data]];


      From the first example in the above referenced documentation:



      data=1, 1, 2, 3, 6, 5, 8, 10, 4, 4;
      edges=2, 4, 6, 8, 10;

      disc[data,edges]



      NaN,NaN,1,1,3,2,4,4,2,2




      I'm sure there are more efficient/elegant solutions, and will revisit as time permits.






      share|improve this answer









      $endgroup$

















        4












        $begingroup$

        This is a very quick-n-dirty, but may serve as a simple example.



        This creates a piecewise function following the first definition in Matlab's discretize documentation, then applies that to the data.



        disc[data_, edges_] := Module[e = Partition[edges, 2, 1], p, l,
        l = Length@e;
        Table[Piecewise[
        Append[Table[i, e[[i, 1]] <= x < e[[i, 2]], i, l - 1]
        , l,e[[l, 1]] <= x <= e[[l, 2]]]
        , "NaN"]
        , x, data]];


        From the first example in the above referenced documentation:



        data=1, 1, 2, 3, 6, 5, 8, 10, 4, 4;
        edges=2, 4, 6, 8, 10;

        disc[data,edges]



        NaN,NaN,1,1,3,2,4,4,2,2




        I'm sure there are more efficient/elegant solutions, and will revisit as time permits.






        share|improve this answer









        $endgroup$















          4












          4








          4





          $begingroup$

          This is a very quick-n-dirty, but may serve as a simple example.



          This creates a piecewise function following the first definition in Matlab's discretize documentation, then applies that to the data.



          disc[data_, edges_] := Module[e = Partition[edges, 2, 1], p, l,
          l = Length@e;
          Table[Piecewise[
          Append[Table[i, e[[i, 1]] <= x < e[[i, 2]], i, l - 1]
          , l,e[[l, 1]] <= x <= e[[l, 2]]]
          , "NaN"]
          , x, data]];


          From the first example in the above referenced documentation:



          data=1, 1, 2, 3, 6, 5, 8, 10, 4, 4;
          edges=2, 4, 6, 8, 10;

          disc[data,edges]



          NaN,NaN,1,1,3,2,4,4,2,2




          I'm sure there are more efficient/elegant solutions, and will revisit as time permits.






          share|improve this answer









          $endgroup$



          This is a very quick-n-dirty, but may serve as a simple example.



          This creates a piecewise function following the first definition in Matlab's discretize documentation, then applies that to the data.



          disc[data_, edges_] := Module[e = Partition[edges, 2, 1], p, l,
          l = Length@e;
          Table[Piecewise[
          Append[Table[i, e[[i, 1]] <= x < e[[i, 2]], i, l - 1]
          , l,e[[l, 1]] <= x <= e[[l, 2]]]
          , "NaN"]
          , x, data]];


          From the first example in the above referenced documentation:



          data=1, 1, 2, 3, 6, 5, 8, 10, 4, 4;
          edges=2, 4, 6, 8, 10;

          disc[data,edges]



          NaN,NaN,1,1,3,2,4,4,2,2




          I'm sure there are more efficient/elegant solutions, and will revisit as time permits.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 4 hours ago









          ciaociao

          17.4k138109




          17.4k138109





















              0












              $begingroup$

              Here's a version based on Nearest:



              digitize[edges_] := DigitizeFunction[edges, Nearest[edges -> "Index"]]
              digitize[data_, edges_] := digitize[edges][data]

              DigitizeFunction[edges_, nf_NearestFunction][data_] := With[init = nf[data][[All, 1]],
              init + UnitStep[data - edges[[init]]] - 1
              ]


              For example:



              SeedRandom[1]
              data = RandomReal[10, 10]
              digitize[data, 2, 4, 5, 7, 8]



              8.17389, 1.1142, 7.89526, 1.87803, 2.41361, 0.657388, 5.42247, 2.31155, 3.96006, 7.00474



              5, 0, 4, 0, 1, 0, 3, 1, 1, 4




              Note that I broke up the definition of digitize into two pieces, so that if you do this for multiple data sets with the same edges list, you only need to compute the nearest function once.






              share|improve this answer











              $endgroup$

















                0












                $begingroup$

                Here's a version based on Nearest:



                digitize[edges_] := DigitizeFunction[edges, Nearest[edges -> "Index"]]
                digitize[data_, edges_] := digitize[edges][data]

                DigitizeFunction[edges_, nf_NearestFunction][data_] := With[init = nf[data][[All, 1]],
                init + UnitStep[data - edges[[init]]] - 1
                ]


                For example:



                SeedRandom[1]
                data = RandomReal[10, 10]
                digitize[data, 2, 4, 5, 7, 8]



                8.17389, 1.1142, 7.89526, 1.87803, 2.41361, 0.657388, 5.42247, 2.31155, 3.96006, 7.00474



                5, 0, 4, 0, 1, 0, 3, 1, 1, 4




                Note that I broke up the definition of digitize into two pieces, so that if you do this for multiple data sets with the same edges list, you only need to compute the nearest function once.






                share|improve this answer











                $endgroup$















                  0












                  0








                  0





                  $begingroup$

                  Here's a version based on Nearest:



                  digitize[edges_] := DigitizeFunction[edges, Nearest[edges -> "Index"]]
                  digitize[data_, edges_] := digitize[edges][data]

                  DigitizeFunction[edges_, nf_NearestFunction][data_] := With[init = nf[data][[All, 1]],
                  init + UnitStep[data - edges[[init]]] - 1
                  ]


                  For example:



                  SeedRandom[1]
                  data = RandomReal[10, 10]
                  digitize[data, 2, 4, 5, 7, 8]



                  8.17389, 1.1142, 7.89526, 1.87803, 2.41361, 0.657388, 5.42247, 2.31155, 3.96006, 7.00474



                  5, 0, 4, 0, 1, 0, 3, 1, 1, 4




                  Note that I broke up the definition of digitize into two pieces, so that if you do this for multiple data sets with the same edges list, you only need to compute the nearest function once.






                  share|improve this answer











                  $endgroup$



                  Here's a version based on Nearest:



                  digitize[edges_] := DigitizeFunction[edges, Nearest[edges -> "Index"]]
                  digitize[data_, edges_] := digitize[edges][data]

                  DigitizeFunction[edges_, nf_NearestFunction][data_] := With[init = nf[data][[All, 1]],
                  init + UnitStep[data - edges[[init]]] - 1
                  ]


                  For example:



                  SeedRandom[1]
                  data = RandomReal[10, 10]
                  digitize[data, 2, 4, 5, 7, 8]



                  8.17389, 1.1142, 7.89526, 1.87803, 2.41361, 0.657388, 5.42247, 2.31155, 3.96006, 7.00474



                  5, 0, 4, 0, 1, 0, 3, 1, 1, 4




                  Note that I broke up the definition of digitize into two pieces, so that if you do this for multiple data sets with the same edges list, you only need to compute the nearest function once.







                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  edited 1 hour ago

























                  answered 1 hour ago









                  Carl WollCarl Woll

                  73k396189




                  73k396189



























                      draft saved

                      draft discarded
















































                      Thanks for contributing an answer to Mathematica 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%2fmathematica.stackexchange.com%2fquestions%2f194844%2fmap-list-to-bin-numbers%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

                      How should I use the fbox command correctly to avoid producing a Bad Box message?How to put a long piece of text in a box?How to specify height and width of fboxIs there an arrayrulecolor-like command to change the rule color of fbox?What is the command to highlight bad boxes in pdf?Why does fbox sometimes place the box *over* the graphic image?how to put the text in the boxHow to create command for a box where text inside the box can automatically adjust?how can I make an fbox like command with certain color, shape and width of border?how to use fbox in align modeFbox increase the spacing between the box and it content (inner margin)how to change the box height of an equationWhat is the use of the hbox in a newcommand command?

                      152 Atala Notae | Nexus externi | Tabula navigationis"Discovery Circumstances: Numbered Minor Planets"2000152Small-Body Database

                      Doxepinum Nexus interni Notae | Tabula navigationis3158DB01142WHOa682390"Structural Analysis of the Histamine H1 Receptor""Transdermal and Topical Drug Administration in the Treatment of Pain""Antidepressants as antipruritic agents: A review"