『壹』 視頻編碼-CRF模式
Constant Rate Factor(CRF)是一種碼率控制模式,最早是X264提出來的,後面的X265和libvpx也都有類似的模式。這種碼控模式可以達到基本恆定的質量,不過碼率會隨著內容的不同而波動。如果使用ffmpeg,可以通過下面的命令來設置crf:
x264和x265裡面crf的設置范圍是0-51,crf越高, 質量越差。CRF越低,質量越好。一般CRF低於18的時候,人眼感知不到明顯的質量差異。
CQP也就是Constant QP,也就是對於同樣的幀類型(I幀,P幀,B幀),使用相同的QP進行量化。編碼器的失真是由量化引起的,相同的量化參數可以保證對於同樣的殘差信號可以實現大概相同的損失。
而CRF則是Constant Quality,這里的Quality是感知到的quality。CRF會對不同復雜度的幀使用不同的QP進行編碼,從而達到一個恆定的感知到的質量。那麼感知到的質量和信號層面的質量有什麼差異?信號層面的質量可以使用PSNR來衡量,而感知到的質量和人眼的特性有關。一般來說,對於高復雜度(草地)或者劇烈運動的場景,細節的損失人眼是很難感知到的,而對於平坦區域的細節損失人眼很容易感知到(如平坦區域的馬賽克或者banding)。
舉一個例子,Constant QP在QP=18的時候編碼,會把每幀的QP都設置為18(實際中不同類型的幀可能會有不同,暫時忽略);而CRF則可能對於復雜的幀,使用QP=20來編碼,對於簡單的幀,使用QP=18來編碼。
CRF是保證質量的碼控模式,對於最終的碼率大小沒有保證,在實際應用場景裡面,很多時候需要一個最大碼率的限制,此時就可以使用CRF+VBV的模式。這種模式一般需要設置三個參數,對應的參數名和意義如下:
crf : 期望的質量,越低越好
bufsize : 一個slide window的bit buffer,編碼器需要保證這個buffer沒有overflow。
maxrate : 最大的local bitrate 。
舉個例子:
怎麼設置bufsize的大小?bufsize一般是和maxrate的成一定的比例關系,譬如2x, 1x, 5x等。bufsize越大,對碼控的約束越小,允許的碼率波動越大。bufsize越小,對碼控的約束越大,允許的碼率波動就越小。所有這個值的設定取決於應用對於碼率波動大小的要求。
『貳』 如何用psnr模型計算相關系數
1、相關系數就用命令corrcoef
min(min(corrcoef(x1, x2))) 就是x1,x2之間的相關系數。
比如
t = (1:0.1:100)';
w = 2*pi;
x1=sin(w*t)+randn(size(t));
x2=cos(w*t)+randn(size(t));
x3=sin(w*t)+randn(size(t));
x1_x2 = min(min(corrcoef(x1, x2)))
x1_x3 = min(min(corrcoef(x1, x3)))
2、用corrcoef函數
設a1,b1,c1,d1 ,a2,b2,c2,d2 分別為f(x)和g(x)的系數
x=[a1,b1,c1,d1];
y=[a2,b2,c2,d2];
z=corrcoef(x,y)
『叄』 RC522讀卡晶元怎麼用
什麼意思?#include
#define RST 1 << 8 // P0.7控制RC522復位,低電平復位/*
*********************************************************************************************************
** 函數名稱 :RC522_RST()
** 函數功能 :復位RC522
** 調試說明 :需將跳線JP5和RST連接。
*********************************************************************************************************
*/int RC522_RST (void)
{ //PINSEL0 = 0x00000000; // 設置管腳連接GPIO
IO0DIR = RST; // 設置RST控制口為輸出
IO0SET = RST; // P0.7置高
DelayNS(10); // 延時
IO0CLR = RST; // P0.7置低
DelayNS(3);
IO0SET = RST;
return 0;
}/*
********************************************************************************************************
** 函數名稱:ReadRawRC()
** 函數功能:讀MF522寄存器
** 參數說明:Address[IN]:寄存器地址
** 返 回 值:讀出的值
********************************************************************************************************
*/unsigned char ReadRawRC(unsigned char Address)
{
unsigned char ucAddr;
unsigned char ucResult = 0;
ucAddr = ((Address<<1)&0x7E)|0x80;
ucResult = MSPI_SendData (ucAddr);
return ucResult;
}
/*
*******************************************************************************************************
** 函數名稱:WriteRawRC()
** 函數功能:寫MF522寄存器
** 參數說明:Address[IN]:寄存器地址
** value[IN]:寫入的值
** 返 回 值:無
*******************************************************************************************************
*/void WriteRawRC(unsigned char Address,unsigned char value)
{
unsigned char ucAddr;
ucAddr = ((Address<<1)&0x7E);
MSPI_SendData(ucAddr);
MSPI_SendData(value);
return 0;}/*
*******************************************************************************************************
** 函數名稱:SetBitMask()
** 函數功能:置MF522寄存器位
** 參數說明:reg[IN]:寄存器地址
** mask[IN]:置位值
** 返 回 值:無
*******************************************************************************************************
*/void SetBitMask(unsigned char reg,unsigned char mask)
{
char tmp = 0x0;
tmp = ReadRawRC(reg);
WriteRawRC(reg,tmp | mask);
return 0;
}/*
*******************************************************************************************************
** 函數名稱:ClearBitMask()
** 函數功能:清MF522寄存器位
** 參數說明:reg[IN]:寄存器地址
** mask[IN]:清位值
** 返 回 值:無
*******************************************************************************************************
*/void ClearBitMask(unsigned char reg,unsigned char mask)
{
char tmp = 0x0;
tmp ReadRawRC(reg);
WriteRawRC(reg,tmp & ~mask);
return 0;
}/*
*******************************************************************************************************
** 函數名稱:PcdAntennaOn()
** 函數功能:開啟天線
** 函數說明:每次開啟或關閉天線發射之間至少有1ms的間隔
** 返 回 值:無
*******************************************************************************************************
*/void PcdAntennaOn()
{
unsigned char i;
i = ReadRawRC(TxControlReg);
if (!(i & 0x03))
{
SetBitMask(TxControlReg,0x03);
}return 0;
}/*
*******************************************************************************************************
** 函數名稱:PcdAntennaOff()
** 函數功能:關閉天線
** 函數說明:每次開啟或關閉天線發射之間至少有1ms的間隔
** 返 回 值:無
*******************************************************************************************************
*/void PcdAntennaOff()
{
ClearBitMask(TxControlReg,0x03);
}/*
*******************************************************************************************************
** 函數名稱:PcdComMF522()
** 函數功能:通過RC522和ISO14443卡通訊
** 函數說明:Command[IN]:RC522命令字
** pIndata[IN]:通過RC522發送到卡片的數據
** InLenByte[IN]:發送數據的位元組長度
** pOutData[OUT]:接收到的卡片返回數據
** *pOutLenBit[OUT]:返回數據的位長度
** 返 回 值:成功返回 MI_OK
*******************************************************************************************************
*/char PcdComMF522(unsigned char Command,
unsigned char *pInData,
unsigned char InLenByte,
unsigned char *pOutData,
unsigned int *pOutLenBit)
{
char status = MI_ERR;
unsigned char irqEn = 0x00;
unsigned char waitFor = 0x00;
unsigned char lastBits;
unsigned char n;
unsigned int i;
switch (Command)
{
case PCD_AUTHENT:
irqEn = 0x12;
waitFor = 0x10;
break;
case PCD_TRANSCEIVE:
irqEn = 0x77;
waitFor = 0x30;
break;
default:
break;
}
WriteRawRC(ComIEnReg,irqEn|0x80);
ClearBitMask(ComIrqReg,0x80);
WriteRawRC(CommandReg,PCD_IDLE);
SetBitMask(FIFOLevelReg,0x80);
for (i=0; i<InLenByte; i++)
{ WriteRawRC(FIFODataReg, pInData[i]); }
WriteRawRC(CommandReg, Command);
if (Command == PCD_TRANSCEIVE)
{ SetBitMask(BitFramingReg,0x80); }
i = 600;//根據時鍾頻率調整,操作M1卡最大等待時間25ms
do
{
n = ReadRawRC(ComIrqReg);
i--;
}
while ((i!=0) && !(n&0x01) && !(n&waitFor));
ClearBitMask(BitFramingReg,0x80);
if (i!=0)
{
if(!(ReadRawRC(ErrorReg)&0x1B))
{
status = MI_OK;
if (n & irqEn & 0x01)
{ status = MI_NOTAGERR; }
if (Command == PCD_TRANSCEIVE)
{
n = ReadRawRC(FIFOLevelReg);
lastBits = ReadRawRC(ControlReg) & 0x07;
if (lastBits)
{ *pOutLenBit = (n-1)*8 + lastBits; }
else
{ *pOutLenBit = n*8; }
if (n == 0)
{ n = 1; }
if (n > MAXRLEN)
{ n = MAXRLEN; }
for (i=0; i<n; i++)
{ pOutData[i] = ReadRawRC(FIFODataReg); }
}
}
else
{ status = MI_ERR; }
}
SetBitMask(ControlReg,0x80); // stop timer now
WriteRawRC(CommandReg,PCD_IDLE);
return status;
}2007-8-11 22:33:00 jianjian1981
等級:初中二年級
文章:51
積分:1461
門派:無門無派
注冊:2006年4月19日第 2 樓 --------------------------------------------------------------------------------
/*
*******************************************************************************************************
** 函數名稱:PcdRequest()
** 函數功能:尋卡
** 函數說明:req_code[IN]:尋卡方式
** 0x52 = 尋感應區內所有符合14443A標準的卡
** 0x26 = 尋未進入休眠狀態的卡
** pTagType[OUT]:卡片類型代碼
** 0x4400 = Mifare_UltraLight
** 0x0400 = Mifare_One(S50)
** 0x0200 = Mifare_One(S70)
** 0x0800 = Mifare_Pro(X)
** 0x4403 = Mifare_DESFire
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdRequest(unsigned char req_code,unsigned char *pTagType)
{
char status;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN]; ClearBitMask(Status2Reg,0x08);
WriteRawRC(BitFramingReg,0x07);
SetBitMask(TxControlReg,0x03);
ucComMF522Buf[0] = req_code; status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,1,ucComMF522Buf,&unLen);
if ((status == MI_OK) && (unLen == 0x10))
{
*pTagType = ucComMF522Buf[0];
*(pTagType+1) = ucComMF522Buf[1];
}
else
{ status = MI_ERR; }
return status;
}/*
*******************************************************************************************************
** 函數名稱:PcdAnticoll()
** 函數功能:防沖撞
** 函數說明:pSnr[OUT]:卡片序列號,4位元組
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdAnticoll(unsigned char *pSnr)
{
char status;
unsigned char i,snr_check=0;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN];
ClearBitMask(Status2Reg,0x08);
WriteRawRC(BitFramingReg,0x00);
ClearBitMask(CollReg,0x80);
ucComMF522Buf[0] = PICC_ANTICOLL1;
ucComMF522Buf[1] = 0x20; status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,2,ucComMF522Buf,&unLen); if (status == MI_OK)
{
for (i=0; i<4; i++)
{
*(pSnr+i) = ucComMF522Buf[i];
snr_check ^= ucComMF522Buf[i];
}
if (snr_check != ucComMF522Buf[i])
{ status = MI_ERR; }
}
SetBitMask(CollReg,0x80);
return status;
}/*
*******************************************************************************************************
** 函數名稱:PcdSelect()
** 函數功能:選定卡片
** 函數說明:pSnr[IN]:卡片序列號,4位元組
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdSelect(unsigned char *pSnr)
{
char status;
unsigned char i;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN];
ucComMF522Buf[0] = PICC_ANTICOLL1;
ucComMF522Buf[1] = 0x70;
ucComMF522Buf[6] = 0;
for (i=0; i<4; i++)
{
ucComMF522Buf[i+2] = *(pSnr+i);
ucComMF522Buf[6] ^= *(pSnr+i);
}
CalulateCRC(ucComMF522Buf,7,&ucComMF522Buf[7]);
ClearBitMask(Status2Reg,0x08); status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,9,ucComMF522Buf,&unLen);
if ((status == MI_OK) && (unLen == 0x18))
{ status = MI_OK; }
else
{ status = MI_ERR; } return status;
}
『肆』 我想用ffmpeg命令行轉換一個視頻文件,視、音頻編碼格式不變,只是將畫面旋轉90度,請問命令行該如何寫
在你的轉碼命令裡面添加上-vf rotate=PI/2或者-vf rotate=3*PI/2,例如
ffmpeg -i E:\ffmpeg\test.mp4 -y -vf rotate=PI/2 E:\ffmpeg\dest1.mp4