Uploaded image for project: 'TinkerPop'
  1. TinkerPop
  2. TINKERPOP-3074

The sample() step is largely unusable with large graphs

    XMLWordPrintableJSON

Details

    • Improvement
    • Status: Open
    • Major
    • Resolution: Unresolved
    • 3.6.7, 3.7.2
    • None
    • process
    • None

    Description

      While the `sample` step can be useful with smallish sized amounts of data for random walks and similar, its current implementation makes it unusable with large graphs if you are looking to sample, say, one node, from a graph with a millions or billions of nodes in it.

      // This generally works assuming the out() step yields limited numbers of nodes
      g.V(1).out().sample(1).out().sample(1) //etc
      
      // This fails for a large graph, usually with an OOM error
      g.V().sample(1)

      The current implementation of sample() is quite naive and assumes it can fetch everything into memory before computing a result. I have seen many users wanting to start a walk from a random place, and they always try to do g.V().sample(1) or g.E().sample(1) types of queries.

      Attachments

        Activity

          People

            Unassigned Unassigned
            krlawrence Kelvin Lawrence
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

            Dates

              Created:
              Updated: