PFM 图片格式
PFM 图片格式
参考: https://linux.die.net/man/5/pfm
1. 描述
本文档描述了Netpbm转换器pamtopfm(1)和pfmtopam(1)所理解的PFM图形图像文件格式。
世界上有多种称为PFM的相似格式,它们都没有权威的记录。这里描述的格式是布赖恩亨德森从一个他发现处理'PFM'格式的程序中推断出来的格式。
PFM格式受Netpbm格式的启发,您会看到很多相似之处。不过,它不是官方的Netpbm格式。其目标与Netpbm格式不一致。
2. 格式
PFM图像是一个字节流。该流包含一个标题,紧接着是一个光栅。下面介绍这两个组件。所描述的部分之前或之后没有分隔符。
(1) PFM标题 PFM header
PFM标题是ASCII文本的连续3行'行'。每行之后是一个空格字符。该字符通常是换行符,因此是“行”,但不一定是。
pamtopfm在它生成的PFM中使用换行符。
(2) Identifier Line
标识符行包含字符'PF'或'Pf'。 PF意味着它是一种彩色PFM。 Pf表示这是一个灰度PFM。
(3) 尺寸线 Dimensions Line
尺寸线包含两个正整数,用空格分隔。首先是图像的宽度;第二个是图像的高度。两者都以像素为单位。
(4) 比例因子/字节顺序 Scale Factor / Endianness
比例因子/字节顺序线是一个奇怪的线,它将字节顺序信息压缩成一个合理的尺度描述。该行由非零十进制数组成,不一定是整数。如果数字是负数,那意味着PFM栅格是小端。否则,它是大端。数字的绝对值是图像的比例因子。
比例因子告诉栅格中样本的单位。你用某种方式将它与一些单独理解的单位信息一起用来将样本值转化为有意义的值,例如每平方米的瓦数。
(5) PFM光栅 PFM raster
栅格是一系列像素,一个接一个地打包,没有任何类型的分隔符。它们采用标准的西方阅读顺序:从图像中的左到右和从上到下。
每个像素由1或3个样本组成,一个接一个地打包,没有任何类型的分隔符。 1个样本用于灰度PFM,3个用于彩色PFM(请参阅PFM标头的标识行)。
每个样本由4个连续的字节组成。这些字节表示一个32位字符串,采用大端或小端格式,由PFM标头的比例因子/字节顺序线确定。该字符串是IEEE 32位浮点数字代码。由于这与大多数CPU和编译器使用的格式相同,因此在处理字节序变化后,通常可以让程序直接将字节用作浮点数。
PFM 图片写入
参考: https://github.com/Microsoft/AirSim common_utils/Utils.hpp
static void writePfmFile(const float * const image_data, int width, int height, std::string path, float scalef=)
{
std::fstream file(path.c_str(), std::ios::out | std::ios::binary); std::string bands;
float fvalue; // scale factor and temp value to hold pixel value
bands = "Pf"; // grayscale // sign of scalefact indicates endianness, see pfm specs
if(isLittleEndian())
scalef = -scalef; // insert header information
file << bands << "\n";
file << width << " ";
file << height << "\n";
file << scalef << "\n"; if(bands == "Pf"){ // handle 1-band image
for (int i=; i < height; i++) {
for(int j=; j < width; ++j){
fvalue = image_data[i * width + j];
file.write(reinterpret_cast<char *>(&fvalue), sizeof(fvalue));
}
}
}
}
PFM 图片格式的更多相关文章
- PPM图片格式及其C读写代码
PPM图像格式介绍 PPM图像格式是由Jef Poskanzer 大叔,在我出生那一年,也就是1991年所创造的,碰巧的是PPM也是天蝎座. PPM(Portable Pixmap Format)还有 ...
- 【VC++技术杂谈007】使用GDI+进行图片格式转换
本文主要介绍如何使用GDI+对图片进行格式转换,可以转换的图片格式为bmp.jpg.png. 1.加载GDI+库 GDI+是GDI图形库的一个增强版本,提供了一系列Visual C++ API.为了使 ...
- JS验证图片格式和大小并预览
用于上传图片的js验证: <%@ page language="java" contentType="text/html; charset=UTF-8"p ...
- PNG和Gif及JPEG图片格式比较
Gif格式特点 透明性Gif是一种布尔透明类型,既它可以是全透明,也可以是全不透明,但是它并没有半透明(alpha 透明). 动画Gif这种格式支持动画. 无损耗性Gif是一种无损耗的图像格式,这也意 ...
- JavaScript校验图片格式及大小
<!DOCTYPE html> <html> <head> <title>JavaScript校验图片格式及大小</title> <s ...
- 前端工程师技能之photoshop巧用系列第四篇——图片格式
× 目录 [1]图片格式 [2]保存设置 前面的话 对于前端来说,图片格式是需要重要掌握的知识.本文是photoshop巧用系列第四篇——图片格式 图片格式 目前在前端的开发中常用的图片格式有jpg. ...
- 利用PhotoShop将Font-Awesome转为图片格式
介绍如何将Font-Awesome等字体图标转换为图片格式,使用PHOTPSHOP很简单. 网上找了很多,都比较麻烦.别问为什么要这么做,因为你还没遇到需要的时候. 下载Font-Awesome字体库 ...
- 【faster-rcnn】训练自己的数据——修改图片格式、类别
修改图片格式 matlab代码 其实内部一些代码是用了rbg的fast-rcnn代码的. \datasets\VOCdevkit2007\VOCcode\VOCinit.m里面,查找'jpg',改成' ...
- BMP图片格式
BMP图片 BMP采用位映射存储格式,除了图像深度可选以外,不采用其他任何压缩,因此,BMP文件所占用的空间很大.BMP文件的图像深度可选lbit.4bit.8bit及24bit和32bit.BMP文 ...
随机推荐
- mysql----------利用navicat查看两个数据库之间的差异
- smtplib.SMTPDataError: (554, b'DT:SPM 163……)
1.报错535: 未将POP3/SMTP服务开启.通过在163邮箱内 设置 获取授权码 打开,通过授权码可以进行第三方登录.此处的Password填写授权码. 2.报错554: 第一种情况:缺失发件 ...
- C#对象序列化成XML,以及自定义标签名
C#对象序列化操作: public class XMLHelper { /// <summary> /// 对象序列化成 XML String /// </summary> p ...
- app埋点
目前APP埋点的主流有两种方式: 第一类是预先设定好想要获取的目标数据,让程序员撰写代码把“采集器”埋到相应的页面上,用于追踪和记录的用户的行为,并把实时数据传送到后台数据库或者客户端. 第二类方法是 ...
- Generative Adversarial Nets
1. 基本思想 两个模型: 判别器:预测从生成器生成的样本的概率 生成器:生成样本时,最大化使得判别器发生错误的概率 最后得到唯一解:使得生成器生成的样本输入到判别器中,得到的概率全是1/2. ...
- CentOS安装系统安装完成
一.安装centOS操作系统的相关步骤? 1)第一步:系统安装的方式,选择全新安装,第一行表示安装系统,第三行当用户名密码无法开机或密码忘记的时候启动 2)第二步:是否检查光盘,选择Skip跳过,没事 ...
- MySql 中的<=>操作符
今天在学习数据库的索引优化时,关于memory存储引擎的的hash索引时,看到了操作符<=> ,这个操作符还是第一次见到,于是上网查了一下.我想大家应该知道 = != <> ...
- 原生JS实现简易转盘抽奖
我爱撸码,撸码使我感到快乐. 大家好,我是Counter. 本章带大家来简单的了解下原生JS实现转盘抽奖. 因为主要涉及到JS,在这里HTML和CSS起到的功能就没有那么重要, 因此,没有过多的阐述H ...
- 单元测试系列之一:如何使用JUnit、JaCoCo和EclEmma提高单元测试覆盖率
更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 原文链接:http://www.cnblogs.com/zishi/p/6726664.html -----如 ...
- UVA1328 Period
思路 KMP算法的next数组是该字符串的最长的相同的前缀和后缀的长度 所以i-next[i]是最小的循环节长度 然后如果next[i]不为0,则证明一定有循环(不一定完整) 然后如果整除,就是完整的 ...