Jax框架的性能分析——性能分析可视化
官方文档:
https://jax.readthedocs.io/en/latest/profiling.html
- 将jax代码的性能文件写入到文件夹中,并给出上传第三方网站的链接生成(https://ui.perfetto.dev/):
import jax
with jax.profiler.trace("/tmp/jax-trace", create_perfetto_link=True):
  # Run the operations to be profiled
  key = jax.random.PRNGKey(0)
  x = jax.random.normal(key, (5000, 5000))
  y = x @ x
  y.block_until_ready()
可以通过TensorFlow的tensorboard来查看指定生成的文件夹,来在本地进行显示;
也可以通过点击生成的链接将性能文件自动上传到第三方网站并查看(设置生成链接后会中断进程运行,直至手动打开该生成链接,然后进程才会继续执行):

使用TensorFlow的tensorboard进行性能文件的显示需要安装如下library:
pip install tensorflow tensorboard-plugin-profile
- 对部分jax的代码进行性能分析,并通过端口将性能文件转发给另一进程,然后再另一进程中生成上传链接,点击链接后上传第三方网站后查看,该种方式不会中断原进程的运行,也不需要等待原进程运行结束。(该种方式最大的不同就是生成第三方链接不是在原进程中,不会影响原进程的运行)
原进程运行代码(待性能分析的代码,需要设置服务端口号,这里是8877):
import jax
jax.profiler.start_server(8877)
key = jax.random.PRNGKey(0)
x = jax.random.normal(key, (1000, 1000))
for _ in range(100000):
    y = x @ x
y.block_until_ready()
jax.profiler.stop_server()
另起一个进程,检测端口号8877,接受到性能分析信息后生成上传链接:
python -m jax.collect_profile 8877 1000
这里的8877是之前的服务端口号,这里需要对此进行监听,1000是指该进程的运行时间,这个时间可以设置的大一些,这里设置为1000秒。
这里需要注意,原进程启动后才可以启动链接生成进程,否则连接不到端口会报错,也就是说在生成链接进程生成成功之前原进程不能结束,因此我们可以在原进程的最终位置加入sleep函数。
原进程:

链接生成进程:


需要注意:
进行对jax的性能信息收集的时候,需要对显卡进行独占(只能运行一个CUDA进程),否则会报错,不过可以通过修改默认设置取消该特性,不过为保证性能分析的准确性(防止同时运行其他进程,对性能分析造成影响)不建议更改默认设置:
修改默认设置,允许其他进程运行的情况下启动性能分析进程,设置环境变量:
TF_GPU_CUPTI_FORCE_CONCURRENT_KERNEL=1

Jax框架的性能分析——性能分析可视化的更多相关文章
- 转——Android应用开发性能优化完全分析
		[工匠若水 http://blog.csdn.net/yanbober 转载请注明出处.] 1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜一堆关于性能的建议,感觉 ... 
- Android 应用开发性能优化完全分析
		1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜一堆关于性能的建议,感觉大家你一总结.我一总结的都说到了很多优化注意事项,但是看过这些文章后大多数存在一个问题就是只 ... 
- 【转】Android应用开发性能优化完全分析
		http://blog.csdn.net/yanbober/article/details/48394201 1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜一堆关 ... 
- Android应用开发性能优化完全分析
		1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜一堆关于性能的建议,感觉大家你一总结.我一总结的都说到了很多优化注意事项,但是看过这些文章后大多数存在一个问题就是只 ... 
- 转:使用xhprof进行线上PHP性能追踪及分析
		原文来自于:http://avnpc.com/pages/profiler-php-performance-online-by-xhprof 原创作者:AlloVince 之前一直使用基于Xdebug ... 
- 转:Android应用开发性能优化完全分析
		转自:http://blog.csdn.net/yanbober/article/details/48394201 1 背景 其实有点不想写这篇文章的,但是又想写,有些矛盾.不想写的原因是随便上网一搜 ... 
- PHP性能追踪及分析工具xhprof的安装与使用
		对于本地开发环境来说,进行性能分析xdebug是够用了,但如果是线上环境的话,xdebug消耗较大,配置也不够灵活,因此线上环境建议使用xhprof进行PHP性能追踪及分析. 我们今天就简单介绍一下x ... 
- golang 性能调优分析工具 pprof(下)
		golang 性能调优分析工具 pprof(上)篇, 这是下篇. 四.net/http/pprof 4.1 代码例子 1 go version go1.13.9 把上面的程序例子稍微改动下,命名为 d ... 
- PHP 性能追踪及分析工具(XHPROF)
		原文:https://gold.xitu.io/post/5860d23f128fe10069e1cfbf XHPROF:Facebook 开源的轻量级PHP性能分析工具. 它报告函数级别的请求次数和 ... 
- 使用FreeRTOS进行性能和运行时分析
		在MCU on Eclipse网站上看到Erich Styger在2月25日发的博文,一篇关于使用FreeRTOS进行性能和运行分析的文章,本人觉得很有启发,特将其翻译过来以备参考.当然限于个人水平, ... 
随机推荐
- vmware 和 hyper-v不兼容,此主机不支持64位客户机操作系统
			在控制面板中关闭hyper-v功能后,仍然提示此主机不支持64位客户机操作系统. 解决方法: 需要在开始按钮 - 右键 -打开Windows PowerShell(管理员). 输入: bcdedit ... 
- 三月二十四日 安卓app打卡开发日志
			目前打卡系统基本完成 没有实现的功能有无法统计次数 和 连接本地数据库 我全程连接的远程数据库 package com.example.test_four.utils; import java.sql ... 
- 函数式表达式基本类型及固定类型 demo
			1.常见类型及使用 import java.util.function.BiConsumer; import java.util.function.BiFunction; import java.ut ... 
- 日志切面接口和方法demo,切面内重新抛出异常
			1. 定义切面 @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface Log { Stri ... 
- VMware 虚拟机下载
			VMware破解版下载地址: https://www.aliyundrive.com/s/CUr4eaMgxGa 提取码:e0c8 激活码: ZF3R0-FHED2-M80TY-8QYGC-NPKYF ... 
- STP选举规则
			STP Election Process 802.1D STP  802.1D是第一个生成树版本,不支持VLAN.选举过程如下 选择一个根桥 选择根端口 选择指定端口 选择关闭端口(剩下的最后一个端 ... 
- CLR via C# 笔记 -- 异常和状态管理(20)
			1. 异常是指成员没有完成它的名称所宣称的行动,异常类继承System.Exception. 2. .Net Framework 异常处理机制是用Microsoft windows提供的结构化异常处理 ... 
- 03-CSS初步介绍
			01 CSS编写规则 1.1 内联样式 <!DOCTYPE html> <html lang="en"> <head> <meta cha ... 
- 《DNK210使用指南 -CanMV版 V1.0》第五章 编译CanMV固件
			第五章 编译CanMV固件 1)实验平台:正点原子DNK210开发板 2) 章节摘自[正点原子]DNK210使用指南 - CanMV版 V1.0 3)购买链接:https://detail.tmall ... 
- 我不应该用JWT的!
			一.前言 大家好呀,我是summo,之前有自学过Shrio框架,网上一搜就有SpringBoot整合Shrio+ JWT的文章,我是在学习Shrio框架的时候顺带学的JWT.后来我还看见有很多博主专门 ... 
