sensor笔记(一)imx415

本文主要内容

    • [IMX415简明笔记 - 前言](#IMX415简明笔记 - 前言)
      • 一、imx415驱动框架
      • 二、imx415数据手册阅读
        • [1. imx415三种主要模式](#1. imx415三种主要模式)
        • [(1)全像素模式(All pixel)](#(1)全像素模式(All pixel))
        • [(2)水平/垂直2x2行合并模式(Horizontal/Vertical 2/2-line binning)](#(2)水平/垂直2x2行合并模式(Horizontal/Vertical 2/2-line binning))
        • [(3)窗口裁剪模式(Window cropping mode)](#(3)窗口裁剪模式(Window cropping mode))
      • 三、寄存器配置

IMX415简明笔记 - 前言

✔️本篇主要是笔者为调试imx415不同的帧率而记录的相关笔记,内容相对之前文章简要,全文均为手动整理,也不可避免有所错漏,只希望能给到需要的读者一些参考。

一、imx415驱动框架

✔️sensor驱动比较复杂,涉及的框架比较多,如果有想了解这部分内容的读者,推荐b站up@自依止-法依止《从驱动框架出发-结构化手搓IMX415驱动代码(一)》系列视频。

二、imx415数据手册阅读

1. imx415三种主要模式
(1)全像素模式(All pixel)

⚫️ 支持分辨率:3840x2160

⚫️ 支持帧率:4 lanes最高可支持90fps 此处均是数据手册提供的参数,非某一平台所支持

⚫️ 读出数据方式:全部像素逐行读出

⚫️ 一般使用场景:分辨率最高、画质完整、带宽要求高,需要高清晰度常见

⚫️ 阅读数据手册:

首先我们要了解数据手册提供的以上参数:

✔️1H period(单位:μs):读取一行的周期(像素+水平消隐)1H的计算十分关键,后面binning模式我们再聊

✔️VMAX:垂直总长度并不是指分辨率

由以上两个参数便可计算得到:

✔️DataRate(Mbps/lane):sensor输出图像数据时的传输速率,决定图像数据传输速度与帧率上限

✔️MDBIT:sensor输出的实际位宽

那么,由此就可以知道4k@60fps的DataRate为:3840×2160 ×12bit×60fps ≈ 5695Mbit/s ≈ 5.97Gbit/s

以4lanes的MIPI PHY来计算,每通道带宽为2.5Gbps,理论上可以支持4k90fps的imx415摄像头的数据量(约9Gbps;再考虑到ISP的带宽,我们可以大致计算出该平台能支持的4k帧率(以RK3588和RV1126B为例):

这里仅讨论全像素模式,也就是4k分辨率下

(2)水平/垂直2x2行合并模式(Horizontal/Vertical 2/2-line binning)

⚫️ 支持分辨率:1920x1080

⚫️ 支持帧率:4 lanes可支持90fps 笔者目前只测试到1080p90fps,此时的1H是5us

⚫️ 读出数据方式:合并水平和垂直方向各2个像素后读出也就是合并4k分辨率水平和垂直各2个像素,因此最高支持1080p

⚫️ 一般使用场景:1080分辨率以下的高帧率场景

⚫️ 阅读数据手册:

✔️可以发现,binning模式分辨率最高仅支持1080p,这里我们以1126B的ISP性能来计算,可以得到该模式下1080p分辨率下最高帧率可达182fps(360x1024x1024÷1920x1080);当然这里也是理论值,受限于其它因素,实际并无法达到,120fps都难以实现这里只讨论binning模式,不叠加window wropping

✔️回到imx415的数据手册,那么sensor的帧率如何计算?

  • 相关参数:VMAX、HMAX、1H period、1V period、Clock Frequency

  • Clock Frequency:sensor工作时钟(比如74.25MHz,不是唯一以实际为准)

    由于数据手册中时钟相关的寄存器配置不是开源的,所以此处并不需要关心太多,反而只需要关注以下参数

  • VMAX和HMAX:垂直和水平方向的时钟周期数,共同决定读取一帧图像的总时间,是时序的控制参数

    注意这两个值并不是描述sensor分辨率,在这里配置sensor时广义可以当成是一帧图像的长和宽,但是这并不准确

  • 1H period:一帧图像读取一行的时间/周期(读一行要多久)

  • 1V period:一帧图像垂直方向的周期长度(有多少行)

  • 例如,以数据手册第49页这里为例,90帧的计算过程如图

✔️如果是1080p120fps如何计算VMAX、HMAX、1H period?

取VMAX=2250,则fps=1/(2250*1H)=0.00012,计算得出1H≈3.75μs,此时HMAX≈266。这也是理论数值,实际配置到驱动里可以发现是有问题的,调整相关寄存器值均不能得到120fp。经过多次测试,笔者更倾向于该模式下无法支持1080p@120fps。

(3)窗口裁剪模式(Window cropping mode)

⚫️ Window cropping模式比较好理解,只需要配置下图里的几个寄存器(起始点、裁剪后的图像尺寸)即可。注意只是sensor很直接的裁剪方式,如果使用4k分辨率裁剪到1080,会得到一个放大的图像,比如下图就是4k@60fps cropping到1080@120fps的效果(帧率也只到100左右),类似为了提高帧率而选择牺牲分辨率,笔者也测试过该模式下获得的2k@60fps,实际效果并不是很好。如果是3568或1126B平台,不如选择imx335,理论上是可以配置到2k@60fps、1080@120fps,且图像效果不会有放大的痕迹。

三、寄存器配置

<略>

相关推荐
数据库小学妹2 小时前
MySQL并行复制原理与调优实战:LOGICAL_CLOCK到WRITESET_SESSION全链路优化
数据库·经验分享·mysql·性能优化·dba
j7~2 小时前
【C++】C&C++内存管理--之内存分布,operatenew/new,operate/delete的底层原理.
c语言·c++·delete·内存泄漏·new·operate new·动态内存分布
Hillain2 小时前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
十月的皮皮2 小时前
C语言学习笔记20260603-打印整数(32位)二进制的奇数位和偶数位(2种方法)
c语言·笔记·学习
刃神太酷啦2 小时前
MySQL 库表操作 +数据类型+ 基础概念全梳理----《Hello MySQL!》(2)
java·c语言·数据库·c++·vscode·mysql·adb
ACP广源盛1392462567313 小时前
GSV2221 显示转换芯片@ACP#赋能 RTX Spark 端侧 AI 设备,构建多屏全模态视觉交互新生态
大数据·人工智能·嵌入式硬件·gpt·spark·电脑·音视频
caimouse13 小时前
Reactos 第 4 章 对象管理 — 4.5 几个常用的内核函数
c语言·windows·架构
x1387028595714 小时前
c语言排雷游戏(基础版9*9)
c语言·算法·游戏
caimouse14 小时前
Reactos 第 4 章 对象管理 — 4.3 句柄和句柄表(Handle & Handle Table)
c语言·windows·架构