How to subset matrices in a list based on another list with values indicating column numbers











up vote
1
down vote

favorite












I have a list of matrices (mat_list). I want to create a new list with a selected subset of columns from each matrix. I have another list of numerics (col_list) which indicates column numbers to keep.
Example dataset:



> mat_list <- list(structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3"))),structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3")))) ; names(mat_list) <- c("mat1","mat2")
> mat_list
$mat1
V1 V2 V3
[1,] 1 5 9
[2,] 2 6 10
[3,] 3 7 11
[4,] 4 8 12

$mat2
V1 V2 V3
[1,] 1 5 9
[2,] 2 6 10
[3,] 3 7 11
[4,] 4 8 12

> col_list <- list(structure(c(1,3)),structure(c(2,3))) ; names(col_list) <- c("var1","var2")
> col_list
$var1
[1] 1 3

$var2
[1] 2 3


I would like the following output:



> my_list
$mat1
V1 V3
[1,] 1 9
[2,] 2 10
[3,] 3 11
[4,] 4 12

$mat2
V2 V3
[1,] 5 9
[2,] 6 10
[3,] 7 11
[4,] 8 12


I've tried to use lapply to subset these columns across all the matrices. The closest I've gotten is to do



> lapply(mat_list,function(x) x[,col_list$var1])
$mat1
V1 V3
[1,] 1 9
[2,] 2 10
[3,] 3 11
[4,] 4 12

$mat2
V1 V3
[1,] 1 9
[2,] 2 10
[3,] 3 11
[4,] 4 12


This uses the values from col$var1 applied over all matrices in mat_list. But I haven't been able to successfully apply this over all (both) the elements of col_list - e.g. by implementing lapply to var_list, something along



lapply(mat_list,function(x) x[,lapply(var_list)])


I'm grateful for any input.










share|improve this question


























    up vote
    1
    down vote

    favorite












    I have a list of matrices (mat_list). I want to create a new list with a selected subset of columns from each matrix. I have another list of numerics (col_list) which indicates column numbers to keep.
    Example dataset:



    > mat_list <- list(structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3"))),structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3")))) ; names(mat_list) <- c("mat1","mat2")
    > mat_list
    $mat1
    V1 V2 V3
    [1,] 1 5 9
    [2,] 2 6 10
    [3,] 3 7 11
    [4,] 4 8 12

    $mat2
    V1 V2 V3
    [1,] 1 5 9
    [2,] 2 6 10
    [3,] 3 7 11
    [4,] 4 8 12

    > col_list <- list(structure(c(1,3)),structure(c(2,3))) ; names(col_list) <- c("var1","var2")
    > col_list
    $var1
    [1] 1 3

    $var2
    [1] 2 3


    I would like the following output:



    > my_list
    $mat1
    V1 V3
    [1,] 1 9
    [2,] 2 10
    [3,] 3 11
    [4,] 4 12

    $mat2
    V2 V3
    [1,] 5 9
    [2,] 6 10
    [3,] 7 11
    [4,] 8 12


    I've tried to use lapply to subset these columns across all the matrices. The closest I've gotten is to do



    > lapply(mat_list,function(x) x[,col_list$var1])
    $mat1
    V1 V3
    [1,] 1 9
    [2,] 2 10
    [3,] 3 11
    [4,] 4 12

    $mat2
    V1 V3
    [1,] 1 9
    [2,] 2 10
    [3,] 3 11
    [4,] 4 12


    This uses the values from col$var1 applied over all matrices in mat_list. But I haven't been able to successfully apply this over all (both) the elements of col_list - e.g. by implementing lapply to var_list, something along



    lapply(mat_list,function(x) x[,lapply(var_list)])


    I'm grateful for any input.










    share|improve this question
























      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      I have a list of matrices (mat_list). I want to create a new list with a selected subset of columns from each matrix. I have another list of numerics (col_list) which indicates column numbers to keep.
      Example dataset:



      > mat_list <- list(structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3"))),structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3")))) ; names(mat_list) <- c("mat1","mat2")
      > mat_list
      $mat1
      V1 V2 V3
      [1,] 1 5 9
      [2,] 2 6 10
      [3,] 3 7 11
      [4,] 4 8 12

      $mat2
      V1 V2 V3
      [1,] 1 5 9
      [2,] 2 6 10
      [3,] 3 7 11
      [4,] 4 8 12

      > col_list <- list(structure(c(1,3)),structure(c(2,3))) ; names(col_list) <- c("var1","var2")
      > col_list
      $var1
      [1] 1 3

      $var2
      [1] 2 3


      I would like the following output:



      > my_list
      $mat1
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12

      $mat2
      V2 V3
      [1,] 5 9
      [2,] 6 10
      [3,] 7 11
      [4,] 8 12


      I've tried to use lapply to subset these columns across all the matrices. The closest I've gotten is to do



      > lapply(mat_list,function(x) x[,col_list$var1])
      $mat1
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12

      $mat2
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12


      This uses the values from col$var1 applied over all matrices in mat_list. But I haven't been able to successfully apply this over all (both) the elements of col_list - e.g. by implementing lapply to var_list, something along



      lapply(mat_list,function(x) x[,lapply(var_list)])


      I'm grateful for any input.










      share|improve this question













      I have a list of matrices (mat_list). I want to create a new list with a selected subset of columns from each matrix. I have another list of numerics (col_list) which indicates column numbers to keep.
      Example dataset:



      > mat_list <- list(structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3"))),structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L), .Dim = c(4L, 3L), .Dimnames = list(NULL, c("V1", "V2", "V3")))) ; names(mat_list) <- c("mat1","mat2")
      > mat_list
      $mat1
      V1 V2 V3
      [1,] 1 5 9
      [2,] 2 6 10
      [3,] 3 7 11
      [4,] 4 8 12

      $mat2
      V1 V2 V3
      [1,] 1 5 9
      [2,] 2 6 10
      [3,] 3 7 11
      [4,] 4 8 12

      > col_list <- list(structure(c(1,3)),structure(c(2,3))) ; names(col_list) <- c("var1","var2")
      > col_list
      $var1
      [1] 1 3

      $var2
      [1] 2 3


      I would like the following output:



      > my_list
      $mat1
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12

      $mat2
      V2 V3
      [1,] 5 9
      [2,] 6 10
      [3,] 7 11
      [4,] 8 12


      I've tried to use lapply to subset these columns across all the matrices. The closest I've gotten is to do



      > lapply(mat_list,function(x) x[,col_list$var1])
      $mat1
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12

      $mat2
      V1 V3
      [1,] 1 9
      [2,] 2 10
      [3,] 3 11
      [4,] 4 12


      This uses the values from col$var1 applied over all matrices in mat_list. But I haven't been able to successfully apply this over all (both) the elements of col_list - e.g. by implementing lapply to var_list, something along



      lapply(mat_list,function(x) x[,lapply(var_list)])


      I'm grateful for any input.







      r subset lapply






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 21 at 13:15









      Neuroguy

      447




      447
























          1 Answer
          1






          active

          oldest

          votes

















          up vote
          2
          down vote



          accepted










          Rather than lapply, in this case mapply fits perfectly:



          mapply(function(x, y) x[, y], mat_list, col_list, SIMPLIFY = FALSE)


          which is also equivalent to



          Map(function(x, y) x[, y], mat_list, col_list)


          Both approaches apply the specified function by taking corresponding arguments from mat_list and col_list at the same time.



          The reason lapply doesn't work is that it goes only over a single variable, as you noticed. To use lapply one would instead need



          lapply(seq_along(mat_list), function(i) mat_list[[i]][, col_list[[i]]])


          Bonus: if mat_list contained data frames rather than matrices, one could be even more concise with



          mapply(`[`, mat_list, col_list, SIMPLIFY = FALSE)
          # or
          Map(`[`, mat_list, col_list)





          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',
            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%2f53412888%2fhow-to-subset-matrices-in-a-list-based-on-another-list-with-values-indicating-co%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            2
            down vote



            accepted










            Rather than lapply, in this case mapply fits perfectly:



            mapply(function(x, y) x[, y], mat_list, col_list, SIMPLIFY = FALSE)


            which is also equivalent to



            Map(function(x, y) x[, y], mat_list, col_list)


            Both approaches apply the specified function by taking corresponding arguments from mat_list and col_list at the same time.



            The reason lapply doesn't work is that it goes only over a single variable, as you noticed. To use lapply one would instead need



            lapply(seq_along(mat_list), function(i) mat_list[[i]][, col_list[[i]]])


            Bonus: if mat_list contained data frames rather than matrices, one could be even more concise with



            mapply(`[`, mat_list, col_list, SIMPLIFY = FALSE)
            # or
            Map(`[`, mat_list, col_list)





            share|improve this answer



























              up vote
              2
              down vote



              accepted










              Rather than lapply, in this case mapply fits perfectly:



              mapply(function(x, y) x[, y], mat_list, col_list, SIMPLIFY = FALSE)


              which is also equivalent to



              Map(function(x, y) x[, y], mat_list, col_list)


              Both approaches apply the specified function by taking corresponding arguments from mat_list and col_list at the same time.



              The reason lapply doesn't work is that it goes only over a single variable, as you noticed. To use lapply one would instead need



              lapply(seq_along(mat_list), function(i) mat_list[[i]][, col_list[[i]]])


              Bonus: if mat_list contained data frames rather than matrices, one could be even more concise with



              mapply(`[`, mat_list, col_list, SIMPLIFY = FALSE)
              # or
              Map(`[`, mat_list, col_list)





              share|improve this answer

























                up vote
                2
                down vote



                accepted







                up vote
                2
                down vote



                accepted






                Rather than lapply, in this case mapply fits perfectly:



                mapply(function(x, y) x[, y], mat_list, col_list, SIMPLIFY = FALSE)


                which is also equivalent to



                Map(function(x, y) x[, y], mat_list, col_list)


                Both approaches apply the specified function by taking corresponding arguments from mat_list and col_list at the same time.



                The reason lapply doesn't work is that it goes only over a single variable, as you noticed. To use lapply one would instead need



                lapply(seq_along(mat_list), function(i) mat_list[[i]][, col_list[[i]]])


                Bonus: if mat_list contained data frames rather than matrices, one could be even more concise with



                mapply(`[`, mat_list, col_list, SIMPLIFY = FALSE)
                # or
                Map(`[`, mat_list, col_list)





                share|improve this answer














                Rather than lapply, in this case mapply fits perfectly:



                mapply(function(x, y) x[, y], mat_list, col_list, SIMPLIFY = FALSE)


                which is also equivalent to



                Map(function(x, y) x[, y], mat_list, col_list)


                Both approaches apply the specified function by taking corresponding arguments from mat_list and col_list at the same time.



                The reason lapply doesn't work is that it goes only over a single variable, as you noticed. To use lapply one would instead need



                lapply(seq_along(mat_list), function(i) mat_list[[i]][, col_list[[i]]])


                Bonus: if mat_list contained data frames rather than matrices, one could be even more concise with



                mapply(`[`, mat_list, col_list, SIMPLIFY = FALSE)
                # or
                Map(`[`, mat_list, col_list)






                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Nov 21 at 13:27

























                answered Nov 21 at 13:21









                Julius Vainora

                28.4k75878




                28.4k75878






























                    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%2f53412888%2fhow-to-subset-matrices-in-a-list-based-on-another-list-with-values-indicating-co%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

                    Berounka

                    Different font size/position of beamer's navigation symbols template's content depending on regular/plain...

                    Sphinx de Gizeh