今天我们的目标是深入理解这一可视化部分的主要流程,并且对其大体的实现方式进行简要的了解和探讨。
为了帮助大家更好地掌握这一内容,我们先回顾一下上次讨论的代码内容,具体如下:
python体验AI代码助手代码解读复制代码from llama_index.utils.workflow import draw_all_possible_flows
if __name__ == "__main__":
import asyncio
asyncio.run(main())
draw_all_possible_flows(MyWorkflow, filename="multi_step_workflow.html")
实际上,后面使用了一个network封装的方式。为了更好地理解这一点,我们可以借助MarsCode AI助手来帮助我们深入了解相关的细节和原理。
可视化
底层逻辑
我们直接向MarsCode AI助手询问这段代码的整体逻辑。从目前的反馈来看,MarsCode AI助手的回答已经相当全面,经过简短的阅读后,便能够对代码的基本思路有一个清晰的了解。
我来总结一下这个过程,基本可以概括为以下几个重要步骤:
- 首先,我们需要创建一个整体的画布,作为整个流程的基础框架。
- 接下来,系统将识别所有标注了特定注解的方法,并提取出与这些注解相关的配置信息,以确保后续操作能够基于正确的上下文进行。
- 在这一步中,我们将利用之前获取的注解方法,逐一添加反映这些方法的节点,构建出一个完整的节点图。
- 随后,我们将为已经添加的所有节点之间建立连接,形成一个系统的结构,通过边的连接关系进一步明确各节点之间的关联性。
- 最后,将所有绘制的内容和结构输出到用户指定的HTML文件中,以便于用户查看和使用。
Network是啥
pyvis 是一个功能强大的 Python 库,专门用于创建动态和交互式的网络可视化图形。该库中的核心组件是 Network 类,通过这一类,用户不仅可以构建复杂的网络结构,添加各种节点和边,还可以灵活地设置网络的布局和样式,以满足不同的可视化需求。
基本用法
如果你对相关内容还不是很熟悉,完全不用担心,你可以直接请求我们的MarsCode AI助手为您生成一个入门示例,这样你就可以通过实际操作来理解和掌握。这样的方式不仅简单明了,而且非常有效。
我把它生成的代码直接拿出来。
python体验AI代码助手代码解读复制代码from pyvis.network import Network
# 创建一个 Network 对象
net = Network(directed=True, height="750px", width="100%")
# 添加节点
net.add_node("Hello", label="Hello", color="#E27AFF", shape="ellipse")
net.add_node("World", label="World", color="#90EE90", shape="ellipse")
# 添加边
net.add_edge("Hello", "World")
# 显示网络图
net.show("hello_world.html", notebook=False)
效果非常出色
既然Python已经可以实现这一功能,那么我们可以推测Java也一定具备相关的生态系统。因此,不妨尝试使用Java版本来探索是否存在更为优雅或高效的解决方案。
Java图可视化
我们对现有的方案并不十分了解,因此不妨直接向MarsCode AI助手咨询,寻求其帮助来生成一些可能的解决方案。
经过实际测试后,我发现问题的根源在于,Maven的依赖库中根本就没有这个依赖。因此,无法顺利完成编译和运行。综合来看,MarsCode AI助手在处理Python代码时表现得相当友好,生成的代码通常能够在第一次尝试时顺利运行,几乎不需要做太多修改或调试。而对于像Java这样具有严格语法规范和复杂依赖管理的语言来说,AI助手在生成代码时可能会遇到一些挑战,需要开发者在使用过程中额外投入一定的精力去调整和调试。
尽管如此,MarsCode AI助手对于初学者来说依然是一个非常不错的工具,尤其是对于快速入门编程的学习者。如果你是编程新手并且想要快速上手,建议可以先从Python这样的动态语言开始
这里我上网搜索后,改正一下:
xml体验AI代码助手代码解读复制代码<dependency>
<groupId>net.sf.jung</groupId>
<artifactId>jung-api</artifactId>
<version>2.1.1</version>
</dependency>
<dependency>
<groupId>net.sf.jung</groupId>
<artifactId>jung-graph-impl</artifactId>
<version>2.1.1</version>
</dependency>
<dependency>
<groupId>net.sf.jung</groupId>
<artifactId>jung-visualization</artifactId>
<version>2.1.1</version>
</dependency>
最后的代码如下:
java体验AI代码助手代码解读复制代码// 创建一个有向图
Graph<String, String> graph = new DirectedSparseGraph<>();
// 添加节点
graph.addVertex("Hello");
graph.addVertex("World");
// 添加边
graph.addEdge("Hello to World", "Hello", "World");
// 设置布局
Layout<String, String> layout = new CircleLayout<>(graph);
// 创建可视化组件
BasicVisualizationServer<String, String> viz = new BasicVisualizationServer<>(layout);
viz.setPreferredSize(new Dimension(750, 750));
// 设置节点标签
viz.getRenderContext().setVertexLabelTransformer(new ToStringLabeller());
// 设置节点颜色
Paint vertexPaint = new Color(226, 126, 255);
viz.getRenderContext().setVertexFillPaintTransformer(v -> vertexPaint);
// 显示窗口
JFrame frame = new JFrame("Hello, World! Network");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.getContentPane().add(viz);
frame.pack();
frame.setVisible(true);
这里其实没有太多需要讨论的内容,直接运行代码应该就能成功。关于AI助手提到的MVN仓库问题,我稍微看了一下,发现问题的根源在于虽然我的 Maven 依赖中的 groupId
是 net.sf.jung
,但是在代码引入的时候,实际上使用的是 edu.uci.ics.jung.graph.Graph
这个路径,这确实有点令人困惑。我也查了一下,这个框架的确是非常老旧了,文档资源几乎已经不存在。
接下来,我们直接看下代码的效果吧。可以类比为一张静态图片,这里鼠标是无法与节点进行交互的,主要展示的是图形结构的静态布局。
graphstream
在与一些好友交流并听取了他们的建议后,我发现了一个非常实用的工具框架——GraphStream。GraphStream 是一个专为动态图形建模和分析设计的 Java 库,它提供了丰富的功能,可以帮助我们轻松生成、导入、导出图形,进行图形的测量、布局优化,并且能够进行可视化展示。
经过深入了解后,我决定让 MarsCode AI助手继续协助我们生成相关代码。如图所示:
首先,我们需要添加一些必要的依赖。为了确保代码能够顺利运行,我在原有依赖的基础上,增加了一些额外的依赖项,因为在初次运行时会遇到一些报错,尤其是缺少某些库或版本不兼容的问题。经过一些调试和调整后,以下是解决完所有报错后的完整依赖配置:
xml体验AI代码助手代码解读复制代码<dependency>
<groupId>org.graphstream</groupId>
<artifactId>gs-core</artifactId>
<version>1.3</version>
</dependency>
<dependency>
<groupId>org.graphstream</groupId>
<artifactId>gs-algo</artifactId>
<version>1.3</version>
</dependency>
<dependency>
<groupId>org.graphstream</groupId>
<artifactId>gs-ui</artifactId>
<version>1.3</version>
</dependency>
我把代码复制出来,给大家一个参考:
java体验AI代码助手代码解读复制代码System.setProperty("org.graphstream.ui", "swing");
Graph graph = new SingleGraph("Tutorial 1");
graph.addNode("A");
graph.addNode("B");
graph.addNode("C");
graph.addEdge("AB", "A", "B");
graph.addEdge("BC", "B", "C");
graph.addEdge("CA", "C", "A");
graph.display();
最终,经过一系列的调试和优化,效果达到了预期。最终呈现的结果如图所示,所实现的功能与之前在 Python 中完成的效果几乎没有差异。
总结
在本文的最后,我们总结了LlamaIndex工作流的可视化部分的实现和细节,重点分析了如何利用Python中的pyvis
库和Java中的图形库,分别在两种语言中构建和展示网络图。通过代码示例,我们详细探讨了如何构建节点、添加边并通过布局生成交互式图形,同时也提到了在Java中使用Jung
库和GraphStream
库时可能遇到的挑战与解决方案。
在实际应用中,虽然MarsCode AI助手能够帮助我们加速开发和解决一些问题,但仍然需要开发者根据实际需求,结合语言的特性做出适当调整。
如何零基础入门 / 学习AI大模型?
大模型时代,火爆出圈的LLM大模型让程序员们开始重新评估自己的本领。 “AI会取代那些行业?
”“谁的饭碗又将不保了?
”等问题热议不断。
不如成为「掌握AI工具的技术人」
,毕竟AI时代,谁先尝试,谁就能占得先机!
想正式转到一些新兴的 AI 行业,不仅需要系统的学习AI大模型。同时也要跟已有的技能结合,辅助编程提效,或上手实操应用,增加自己的职场竞争力。
但是LLM相关的内容很多,现在网上的老课程老教材关于LLM又太少。所以现在小白入门就只能靠自学,学习成本和门槛很高
那么我作为一名热心肠的互联网老兵,我意识到有很多经验和知识值得分享给大家,希望可以帮助到更多学习大模型的人!至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
👉 福利来袭
CSDN大礼包:《2025最全AI大模型学习资源包》免费分享,安全可点 👈
全套AGI大模型学习大纲+路线
AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!
640套AI大模型报告合集
这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。
👉学会后的收获:👈
• 基于大模型全栈工程实现(前端、后端、产品经理、设计、数据分析等),通过这门课可获得不同能力;
• 能够利用大模型解决相关实际项目需求: 大数据时代,越来越多的企业和机构需要处理海量数据,利用大模型技术可以更好地处理这些数据,提高数据分析和决策的准确性。因此,掌握大模型应用开发技能,可以让程序员更好地应对实际项目需求;
• 基于大模型和企业数据AI应用开发,实现大模型理论、掌握GPU算力、硬件、LangChain开发框架和项目实战技能, 学会Fine-tuning垂直训练大模型(数据准备、数据蒸馏、大模型部署)一站式掌握;
• 能够完成时下热门大模型垂直领域模型训练能力,提高程序员的编码能力: 大模型应用开发需要掌握机器学习算法、深度学习框架等技术,这些技术的掌握可以提高程序员的编码能力和分析能力,让程序员更加熟练地编写高质量的代码。
👉 福利来袭
CSDN大礼包:《2025最全AI大模型学习资源包》免费分享,安全可点 👈
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量。