当前位置: 首页 > 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.dtcms.com/a/283831.html

相关文章:

  • ZKmall开源商城架构助力增长:多端流量聚合与用户体验
  • macOS 12.7.6部署Ollama+Dify避坑指南
  • 集群聊天服务器各个类进行详解
  • LAMP迁移LNMP Nginx多站点配置全流程
  • 大型语言模型(LLM)在网络安全中最具商业价值的应用场景(Grok3 回答 DeepSearch模式)
  • Java-75 深入浅出 RPC Dubbo Java SPI机制详解:从JDK到Dubbo的插件式扩展
  • 新版本flutter(3.32.7) android 端集成百度地图sdk
  • 网络编程7.17
  • cors跨域资源共享
  • Python 网络爬虫 —— 代理服务器
  • 阿里云-通义灵码:隐私保护机制—为数据安全筑起铜墙铁壁
  • Web3.0 实战项目、简历打造、精准投递+面试准备
  • MongoDB 与MySQL 及es的区别
  • 黑客知识-攻击
  • 数据仓库分层经典架构:ODS、DWD、DWS
  • 安卓 GoFasting(间歇性断食)v1.03.35.0708
  • python-字典、集合、序列切片、字符串操作(笔记)
  • cdh6.3.2的hive使用apache paimon格式只能创建不能写报错的问题
  • Thymeleaf 表单绑定与验证详解
  • Rabbitmq direct 模式与 finout区别
  • Apache Ignite 的 Pages Writes Throttling(页面写入节流)
  • C++ - 仿 RabbitMQ 实现消息队列--C++11 异步操作实现线程池
  • InfluxDB 3与Apache Parquet:打造高性能时序数据存储与分析解决方案
  • Apache DolphinScheduler介绍与部署
  • UE5 Nanite使用
  • 下班倒计时
  • 链路聚合实训
  • 管家婆价格折扣跟踪管理:查询、新增、修改、删除
  • JAVA中的Map集合
  • 【01背包】P1466 [USACO2.2] 集合 Subset Sums