How to find second,third,etc maximum peak of list











up vote
2
down vote

favorite












I need to find all values of peaks.
I have Table with 10000 elements in it and I plot a graphic using ListPlot.
enter image description here



Then I tried to find peaks:



tbl1 = Table[tbl[[i, 2]], {i, 1, Length[tbl]}];
gA = Max[tbl1]
gAm = Part[tbl, Position[tbl1 , gA ][[1, 1]], 1]


Here tbl my Table with Data
And get:



0.15
8.751


So I find the last peak starting. How I can find other?
enter image description here
I upload a .txt file with data to my google drive
here .



I also tried to use FindPeaks but it's wrong:



peakpositions = FindPeaks[tbl[[All, 2]]]



{{116, 0.}, {1441, 0.}}




peakwavelengths = tbl[[#1, 1]] & @@@ peakpositions



{0.115, 1.44}




ListPlot[tbl, PlotRange -> All, GridLines -> {peakwavelengths, None}, 
GridLinesStyle -> Directive[Red, Thick]]


enter image description here










share|improve this question




















  • 1




    Did you try FindPeaks?
    – J42161217
    5 hours ago










  • Yes, I did. I added the result above.
    – John
    5 hours ago















up vote
2
down vote

favorite












I need to find all values of peaks.
I have Table with 10000 elements in it and I plot a graphic using ListPlot.
enter image description here



Then I tried to find peaks:



tbl1 = Table[tbl[[i, 2]], {i, 1, Length[tbl]}];
gA = Max[tbl1]
gAm = Part[tbl, Position[tbl1 , gA ][[1, 1]], 1]


Here tbl my Table with Data
And get:



0.15
8.751


So I find the last peak starting. How I can find other?
enter image description here
I upload a .txt file with data to my google drive
here .



I also tried to use FindPeaks but it's wrong:



peakpositions = FindPeaks[tbl[[All, 2]]]



{{116, 0.}, {1441, 0.}}




peakwavelengths = tbl[[#1, 1]] & @@@ peakpositions



{0.115, 1.44}




ListPlot[tbl, PlotRange -> All, GridLines -> {peakwavelengths, None}, 
GridLinesStyle -> Directive[Red, Thick]]


enter image description here










share|improve this question




















  • 1




    Did you try FindPeaks?
    – J42161217
    5 hours ago










  • Yes, I did. I added the result above.
    – John
    5 hours ago













up vote
2
down vote

favorite









up vote
2
down vote

favorite











I need to find all values of peaks.
I have Table with 10000 elements in it and I plot a graphic using ListPlot.
enter image description here



Then I tried to find peaks:



tbl1 = Table[tbl[[i, 2]], {i, 1, Length[tbl]}];
gA = Max[tbl1]
gAm = Part[tbl, Position[tbl1 , gA ][[1, 1]], 1]


Here tbl my Table with Data
And get:



0.15
8.751


So I find the last peak starting. How I can find other?
enter image description here
I upload a .txt file with data to my google drive
here .



I also tried to use FindPeaks but it's wrong:



peakpositions = FindPeaks[tbl[[All, 2]]]



{{116, 0.}, {1441, 0.}}




peakwavelengths = tbl[[#1, 1]] & @@@ peakpositions



{0.115, 1.44}




ListPlot[tbl, PlotRange -> All, GridLines -> {peakwavelengths, None}, 
GridLinesStyle -> Directive[Red, Thick]]


enter image description here










share|improve this question















I need to find all values of peaks.
I have Table with 10000 elements in it and I plot a graphic using ListPlot.
enter image description here



Then I tried to find peaks:



tbl1 = Table[tbl[[i, 2]], {i, 1, Length[tbl]}];
gA = Max[tbl1]
gAm = Part[tbl, Position[tbl1 , gA ][[1, 1]], 1]


Here tbl my Table with Data
And get:



0.15
8.751


So I find the last peak starting. How I can find other?
enter image description here
I upload a .txt file with data to my google drive
here .



I also tried to use FindPeaks but it's wrong:



peakpositions = FindPeaks[tbl[[All, 2]]]



{{116, 0.}, {1441, 0.}}




peakwavelengths = tbl[[#1, 1]] & @@@ peakpositions



{0.115, 1.44}




ListPlot[tbl, PlotRange -> All, GridLines -> {peakwavelengths, None}, 
GridLinesStyle -> Directive[Red, Thick]]


enter image description here







plotting list-manipulation mathematical-optimization peak-detection






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 5 hours ago

























asked 5 hours ago









John

1996




1996








  • 1




    Did you try FindPeaks?
    – J42161217
    5 hours ago










  • Yes, I did. I added the result above.
    – John
    5 hours ago














  • 1




    Did you try FindPeaks?
    – J42161217
    5 hours ago










  • Yes, I did. I added the result above.
    – John
    5 hours ago








1




1




Did you try FindPeaks?
– J42161217
5 hours ago




Did you try FindPeaks?
– J42161217
5 hours ago












Yes, I did. I added the result above.
– John
5 hours ago




Yes, I did. I added the result above.
– John
5 hours ago










2 Answers
2






active

oldest

votes

















up vote
3
down vote



accepted










jumps = tbl[[1 + Flatten@Position[Sign@Differences[tbl[[All, 2]]], 1]]]



{{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}




ListStepPlot[tbl,  Epilog -> {Red, PointSize[Large], Point[jumps]}, 
GridLines -> Transpose[jumps]]


enter image description here






share|improve this answer




























    up vote
    2
    down vote













    Pick[tbl,Join[{0},Sign@Differences[Last/@tbl]],1]     



    {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}







    share|improve this answer





















      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',
      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%2f186752%2fhow-to-find-second-third-etc-maximum-peak-of-list%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








      up vote
      3
      down vote



      accepted










      jumps = tbl[[1 + Flatten@Position[Sign@Differences[tbl[[All, 2]]], 1]]]



      {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}




      ListStepPlot[tbl,  Epilog -> {Red, PointSize[Large], Point[jumps]}, 
      GridLines -> Transpose[jumps]]


      enter image description here






      share|improve this answer

























        up vote
        3
        down vote



        accepted










        jumps = tbl[[1 + Flatten@Position[Sign@Differences[tbl[[All, 2]]], 1]]]



        {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}




        ListStepPlot[tbl,  Epilog -> {Red, PointSize[Large], Point[jumps]}, 
        GridLines -> Transpose[jumps]]


        enter image description here






        share|improve this answer























          up vote
          3
          down vote



          accepted







          up vote
          3
          down vote



          accepted






          jumps = tbl[[1 + Flatten@Position[Sign@Differences[tbl[[All, 2]]], 1]]]



          {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}




          ListStepPlot[tbl,  Epilog -> {Red, PointSize[Large], Point[jumps]}, 
          GridLines -> Transpose[jumps]]


          enter image description here






          share|improve this answer












          jumps = tbl[[1 + Flatten@Position[Sign@Differences[tbl[[All, 2]]], 1]]]



          {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}




          ListStepPlot[tbl,  Epilog -> {Red, PointSize[Large], Point[jumps]}, 
          GridLines -> Transpose[jumps]]


          enter image description here







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 5 hours ago









          kglr

          173k8194400




          173k8194400






















              up vote
              2
              down vote













              Pick[tbl,Join[{0},Sign@Differences[Last/@tbl]],1]     



              {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}







              share|improve this answer

























                up vote
                2
                down vote













                Pick[tbl,Join[{0},Sign@Differences[Last/@tbl]],1]     



                {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}







                share|improve this answer























                  up vote
                  2
                  down vote










                  up vote
                  2
                  down vote









                  Pick[tbl,Join[{0},Sign@Differences[Last/@tbl]],1]     



                  {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}







                  share|improve this answer












                  Pick[tbl,Join[{0},Sign@Differences[Last/@tbl]],1]     



                  {{0.232, 0.05}, {2.411, 0.05}, {5.449, 0.1}, {8.751, 0.15}}








                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered 4 hours ago









                  J42161217

                  3,177219




                  3,177219






























                       

                      draft saved


                      draft discarded



















































                       


                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function () {
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f186752%2fhow-to-find-second-third-etc-maximum-peak-of-list%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

                      Bundesstraße 106

                      Verónica Boquete

                      Ida-Boy-Ed-Garten