how to filter out small subgraphs in R












1















suppose I have a network like this with multiple subgraphs.



How can I only keep the subgraph with the most number of vertices while removing the rest? In this case I want to keep the subgraph on the left and remove the 3-vertices one the lower right. Thanks!



enter image description here










share|improve this question


















  • 1





    Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

    – r2evans
    Nov 20 '18 at 3:33


















1















suppose I have a network like this with multiple subgraphs.



How can I only keep the subgraph with the most number of vertices while removing the rest? In this case I want to keep the subgraph on the left and remove the 3-vertices one the lower right. Thanks!



enter image description here










share|improve this question


















  • 1





    Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

    – r2evans
    Nov 20 '18 at 3:33
















1












1








1








suppose I have a network like this with multiple subgraphs.



How can I only keep the subgraph with the most number of vertices while removing the rest? In this case I want to keep the subgraph on the left and remove the 3-vertices one the lower right. Thanks!



enter image description here










share|improve this question














suppose I have a network like this with multiple subgraphs.



How can I only keep the subgraph with the most number of vertices while removing the rest? In this case I want to keep the subgraph on the left and remove the 3-vertices one the lower right. Thanks!



enter image description here







r graph igraph






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 20 '18 at 3:12









santokusantoku

98011529




98011529








  • 1





    Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

    – r2evans
    Nov 20 '18 at 3:33
















  • 1





    Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

    – r2evans
    Nov 20 '18 at 3:33










1




1





Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

– r2evans
Nov 20 '18 at 3:33







Photoshop or Gimp would be my first attempt. Or perhaps magick convert 5IABB.png -crop 800x830-0-0 out.png :-)

– r2evans
Nov 20 '18 at 3:33














1 Answer
1






active

oldest

votes


















4














Given



set.seed(1)
g <- sample_gnp(20, 1 / 20)
plot(g)


enter image description here



we wish to keep the subgraph with 6 vertices. Using



(clu <- components(g))
# $membership
# [1] 1 2 3 4 5 4 5 5 6 7 8 9 10 3 5 11 5 3 12 5

# $csize
# [1] 1 1 3 2 6 1 1 1 1 1 1 1

# $no
# [1] 12
gMax <- induced_subgraph(g, V(g)[clu$membership == which.max(clu$csize)])


we then get



plot(gMax)


enter image description here



This assumes that there is a single largest connected subgraph. Otherwise the "first" one will be chosen.






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%2f53385668%2fhow-to-filter-out-small-subgraphs-in-r%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









    4














    Given



    set.seed(1)
    g <- sample_gnp(20, 1 / 20)
    plot(g)


    enter image description here



    we wish to keep the subgraph with 6 vertices. Using



    (clu <- components(g))
    # $membership
    # [1] 1 2 3 4 5 4 5 5 6 7 8 9 10 3 5 11 5 3 12 5

    # $csize
    # [1] 1 1 3 2 6 1 1 1 1 1 1 1

    # $no
    # [1] 12
    gMax <- induced_subgraph(g, V(g)[clu$membership == which.max(clu$csize)])


    we then get



    plot(gMax)


    enter image description here



    This assumes that there is a single largest connected subgraph. Otherwise the "first" one will be chosen.






    share|improve this answer




























      4














      Given



      set.seed(1)
      g <- sample_gnp(20, 1 / 20)
      plot(g)


      enter image description here



      we wish to keep the subgraph with 6 vertices. Using



      (clu <- components(g))
      # $membership
      # [1] 1 2 3 4 5 4 5 5 6 7 8 9 10 3 5 11 5 3 12 5

      # $csize
      # [1] 1 1 3 2 6 1 1 1 1 1 1 1

      # $no
      # [1] 12
      gMax <- induced_subgraph(g, V(g)[clu$membership == which.max(clu$csize)])


      we then get



      plot(gMax)


      enter image description here



      This assumes that there is a single largest connected subgraph. Otherwise the "first" one will be chosen.






      share|improve this answer


























        4












        4








        4







        Given



        set.seed(1)
        g <- sample_gnp(20, 1 / 20)
        plot(g)


        enter image description here



        we wish to keep the subgraph with 6 vertices. Using



        (clu <- components(g))
        # $membership
        # [1] 1 2 3 4 5 4 5 5 6 7 8 9 10 3 5 11 5 3 12 5

        # $csize
        # [1] 1 1 3 2 6 1 1 1 1 1 1 1

        # $no
        # [1] 12
        gMax <- induced_subgraph(g, V(g)[clu$membership == which.max(clu$csize)])


        we then get



        plot(gMax)


        enter image description here



        This assumes that there is a single largest connected subgraph. Otherwise the "first" one will be chosen.






        share|improve this answer













        Given



        set.seed(1)
        g <- sample_gnp(20, 1 / 20)
        plot(g)


        enter image description here



        we wish to keep the subgraph with 6 vertices. Using



        (clu <- components(g))
        # $membership
        # [1] 1 2 3 4 5 4 5 5 6 7 8 9 10 3 5 11 5 3 12 5

        # $csize
        # [1] 1 1 3 2 6 1 1 1 1 1 1 1

        # $no
        # [1] 12
        gMax <- induced_subgraph(g, V(g)[clu$membership == which.max(clu$csize)])


        we then get



        plot(gMax)


        enter image description here



        This assumes that there is a single largest connected subgraph. Otherwise the "first" one will be chosen.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 20 '18 at 3:29









        Julius VainoraJulius Vainora

        34.2k76079




        34.2k76079






























            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.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53385668%2fhow-to-filter-out-small-subgraphs-in-r%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

            MongoDB - Not Authorized To Execute Command

            How to fix TextFormField cause rebuild widget in Flutter

            Npm cannot find a required file even through it is in the searched directory