मुझे पता है कि यह कई बार पूछा गया था लेकिन मुझे टिंकरपॉप (3.1) के अंतिम संस्करण के बारे में कोई संदर्भ नहीं मिला है, जिसमें कई नए उपयोगी फ़ंक्शंस शामिल हैं जिनका हम उपयोग कर सकते हैं हमारे ट्रैवर्सलटिंकरपॉप में दो नोड्स के बीच सबसे छोटा रास्ता खोजने का सबसे अच्छा तरीका 3.1
मान लें कि मुझे नोड्स 3 और 4 के बीच सबसे छोटा रास्ता मिलना है। क्या यह ट्रैवर्सल ध्वनि है?
g.V(3).repeat(out()).until(id().is(4).and().simplePath()).path().limit(1)
यहाँ मैं यह सोचते हैं रहा है कि जब मैं एक BFS खोज पाशन कर रहा हूँ निष्पादित किया जाता है it seems that this was the case with the loop()
function के रूप में (इस प्रकार, पहला परिणाम कम से कम पथ है)।
इसके अतिरिक्त, until
चरण में पहले बाध्य चर (as
चरण का उपयोग करके) शामिल करने का कोई तरीका है? दरअसल, मैं ट्रेवर्सल दौरान दो नोड्स का चयन करने के, कोशिश कर रहा हूँ, और फिर उन्हें बीच कम से कम पथ की खोज, उदाहरण के लिए
g.V().match(
__as('e0').out('Feedbacks').as('e1'),
__as('e0').repeat(out('Meets')).until(<I reach e1>).path().<get_length>.as('len')
).select('e0', 'e1', 'len')
अंत के रूप में पिछले ट्रेवर्सल से देखा जा सकता है, यह करने के लिए स्पष्ट नहीं है मैं कैसे सबसे छोटा रास्ता की लंबाई प्राप्त कर सकते हैं। जबकि
g.V(3).repeat(out()).until(id().is(4).and().simplePath()).path().by(__size())
एक त्रुटि देता है तरह
g.V(3).repeat(out()).until(id().is(4).and().simplePath()).path().size()
कुछ का उपयोग करते हुए परिणाम (पंक्तियों की संख्या लौटे) के आकार देता है,।
यहां ग्राफ है जिसके साथ मैं प्रयोग कर रहा हूं, क्या कोई भी थोड़ा खेलना चाहता है। उस दिन पहली पथ हमेशा कम से कम पथ है,
g.V(3).repeat(out().simplePath()).until(hasId(4)).path().limit(1)
आपका धारणा सही है:
graph = TinkerGraph.open()
e0 = graph.addVertex(T.id, 0, label, "User", "name", "e0")
e1 = graph.addVertex(T.id, 1, label, "User", "name", "e1")
e2 = graph.addVertex(T.id, 2, label, "User", "name", "e2")
e3 = graph.addVertex(T.id, 3, label, "User", "name", "e3")
e4 = graph.addVertex(T.id, 4, label, "User", "name", "e4")
e0.addEdge("Feedbacks", e2)
e0.addEdge("Meets", e1)
e2.addEdge("Feedbacks", e4)
e2.addEdge("Meets", e4)
e3.addEdge("Feedbacks", e0)
e3.addEdge("Meets", e2)
e4.addEdge("Feedbacks", e0)
g = graph.traversal()
धन्यवाद @ डैनियल कुपिट्स। जब आप अपना जवाब लिख रहे थे तो मैंने प्रश्न को संशोधित किया। क्या आपके पास नया अनुरोध जांचने के लिए थोडा समय होगा, यानी, मैं पहले तक एलआईएड नोड को 'कब तक) चरण में संदर्भित करता हूं? – Alberto
फिर से धन्यवाद, डैनियल – Alberto
फिर से परेशान करने के लिए खेद है लेकिन .. अब मैं 'मीट्स' * की लंबाई की गणना करके दो प्रश्नों के परिणामों को मर्ज करने की कोशिश कर रहा हूं * अप्रत्यक्ष * ('दोनों ('मीट्स')') सबसे छोटा रास्ता फीडबैक एज से जुड़े दो कोष्ठकों को जोड़ना।यह छोटा नहीं है क्योंकि मैं 'as ('e0')' -'select ('e0') 'पैटर्न के कारण' repeat() 'के अंदर 'सरलपाथ()' का उपयोग नहीं कर सकता, और मैं पहले पथ का चयन नहीं कर सकता एक 'सीमा (1)' 'के बाद()' के बाद से अन्यथा मैं समाधान खो देता हूं। क्या आपको पता है कि इससे कैसे निपटें? – Alberto