当前位置: 首页 > news >正文

Perspective:一款开源的交互式分析和数据可视化组件

Perspective 一款专为大规模和流式数据集设计的高性能交互式分析与可视化组件,可以用于创建可配置的报告、仪表盘、笔记本以及应用程序,由摩根大通开源并托管于金融开源基金会(FINOS)。

Perspective 通过结合多种前沿技术,实现了对海量数据的实时处理与动态展示,适用于金融分析、实时监控、数据科学等领域。

数据架构

Perspective 应用程序开发可以选择三种数据绑定架构:客户端、服务器、客户端/服务器复制。

其中,表数据通过序列化为 Apache Arrow 进行高效同步和复制。

客户端模式

客户端模式适用于中小型数据集、静态数据分析或离线报告。

Perspective 在客户端模式下作为浏览器 WebAssembly 代码库运行,数据一次性加载到浏览器的 Table 对象中,所有数据处理由 WebAssembly 引擎在浏览器中完成,响应速度极快。

服务器模式

服务器模式适用于超大规模数据集、高并发访问或实时流处理。

服务器模式下,数据存储在服务端(Python/Node.js/Rust),服务端执行计算后仅将结果数据返回给客户端渲染。

客户端/服务器复制

客户端/服务器复制模式适合中型数据集、实时交互以及高并发用户场景。

这种模式下,服务端存储全量数据,客户端通过增量复制获取数据子集并动态更新本地数据。同时,交互操作(例如筛选、排序)在客户端本地执行,避免频繁请求服务端。

功能特性

  • 高性能引擎:核心查询引擎用 C++ 编写,编译为 WebAssembly、Python 或者 Rust,支持高效处理亿级数据;采用 Apache Arrow 列式内存格式实现跨语言零拷贝数据共享,显著提升数据传输效率; 基于 ExprTK 表达式语言实现高性能列式计算,例如实时聚合、过滤。
  • 丰富的图形:提供表格、折线图、散点图、热力图、透视图等多种可视化组件,用户可通过拖拽交互实时调整分组、排序和筛选条件。
  • 框架无关的 UI:基于 Web 自定义组件封装,可以无缝嵌入 React、Vue 等前端框架,同时支持虚拟渲染,降低 DOM 负载。
  • 多语言支持:Perspective 提供了 JavaScript、Python 和 Rust API。Python 端深度集成 Pandas/NumPy,并且支持 JupyterLab 插件,方便在 Notebook 中进行交互分析。

快速体验

Perspective 官方网站提供了大量的示例,可以直接探索数据分析和可视化功能:

https://perspective.finos.org/

Perspective 提供了 Python、Javascript、Rust 等语言 API,可以直接安装使用,建议参考官方指南:

https://perspective.finos.org/guide/perspective.html

http://www.lryc.cn/news/590897.html

相关文章:

  • 独家|理想汽车放弃华为PBC模式,回归OKR理想汽车
  • 算法竞赛备赛——【图论】求最短路径——Dijkstra
  • 【软件开发】主流 AI 编码插件
  • 《Oracle SQL:使用 RTRIM 和 TO_CHAR 函数格式化数字并移除多余小数点》
  • AI培训学习3-AI数据分析产品
  • day56-Dockerfile自定义镜像
  • Elasticsearch MCP 服务器现已在 AWS Marketplace 上提供
  • uniapp运行鸿蒙报错整理
  • uni-app 配置华为离线推送流程
  • 在UniApp中防止页面上下拖动的方法
  • 用aws下载NOAA的MB文件
  • uniapp云打包安卓
  • uniapp问题总结
  • uniapp用webview导入本地网页,ios端打开页面空白问题
  • Python-TCP编程-UDP编程-SocketServer-IO各种概念及多路复用-asyncio-学习笔记
  • 多方案对比分析:后端数据加密策略及实践
  • 网络编程-java
  • web前端渡一大师课 CSS属性计算过程
  • 进阶向:智能图像背景移除工具
  • (自用)补充总结1
  • AI安全威胁之MCP Server投毒攻击实践
  • MyBatis之核心组件与配置详解
  • C语言:20250717笔记
  • python网络爬虫(第一步:网络爬虫库、robots.txt规则(防止犯法)、查看获取网页源代码)
  • Selenium 启动的浏览器自动退出问题分析
  • 【46】MFC入门到精通——MFC显示实时时间,获取系统当前时间GetCurrentTime()、获取本地时间GetLocalTime()
  • 结合自身,制定一套明确的 Web3 学习路线和技术栈建议
  • 保持视频二维码不变,如何更新视频内容,节省物料印刷成本
  • 板凳-------Mysql cookbook学习 (十二--------1)
  • 离散与组合数学 杂记