亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? t264.c

?? T264是中國的視頻編碼自由組織合力開發(fā)的264編解碼程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*****************************************************************************
*
*  T264 AVC CODEC
*
*  Copyright(C) 2004-2005 llcc <lcgate1@yahoo.com.cn>
*               2004-2005 visionany <visionany@yahoo.com.cn>
*
*  This program is free software ; you can redistribute it and/or modify
*  it under the terms of the GNU General Public License as published by
*  the Free Software Foundation ; either version 2 of the License, or
*  (at your option) any later version.
*
*  This program is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY ; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU General Public License for more details.
*
*  You should have received a copy of the GNU General Public License
*  along with this program ; if not, write to the Free Software
*  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
*
****************************************************************************/

// T264.cpp : Defines the entry point for the console application.
//

#define USE_DISPLAY
#include "config.h"

#ifdef USE_DISPLAY
#ifndef __GCC__
#include "win.h"
#else
#include "display.h"
#endif
#endif

//Ti_DSP Platform ported by YouXiaoquan,HFUT-Ti United Lab,China
//YouXiaoquan@126.com
#include "stdio.h"
#ifndef CHIP_DM642
#include "sys/timeb.h"
#endif
#include "time.h"

#include "stdlib.h"
#ifndef CHIP_DM642
#include "memory.h"
#endif
#include "math.h"
#include "T264.h"
#include "utility.h"
#include "string.h"


// parameters begin
int32_t total_no = 300;
char src_path[256];
char out_path[256];
char rec_path[256];
// for decoder PSNR
char ref_path[256];
static int  ref_skip;

// parameters end

#ifdef USE_DISPLAY

void
winDisplay(T264_t* t, T264_frame_t* f)
{
    uint8_t* p;
    unsigned char* buffer1, *buffer2, *buffer3, *Y, *U, *V;
    unsigned char *src[3];
    int32_t i;

    src[0] = Y = buffer1 = malloc(t->width*t->height*sizeof(char));
    p = f->Y[0];
    for (i = 0 ; i < t->height ; i++)
    {
        memcpy(buffer1, p, t->width);
        buffer1 += t->width;
        p += t->edged_stride;
    }

    src[2] = V = buffer2 = malloc((t->width*t->height*sizeof(char))>>2);
    p = f->V;
    for (i = 0 ; i < (t->height >> 1); i++)
    {
        memcpy(buffer2, p, t->width >> 1);
        buffer2 += (t->width >> 1);
        p += t->edged_stride_uv;
    }

    src[1] = U = buffer3 = malloc((t->width*t->height*sizeof(char))>>2);
    p = f->U;
    for (i = 0 ; i < (t->height >> 1); i++)
    {
        memcpy(buffer3, p, t->width >> 1);
        buffer3 += (t->width >> 1);
        p += t->edged_stride_uv;
    }
#ifndef __GCC__
    displayImage(Y,V,U);
#else
    dither(src);
    free(src[1]);
    free(src[2]);
    free(src[0]);
#endif
}

void
uninit_display()
{
#ifndef __GCC__
    closeDisplay ();
#else
    exit_display();
#endif
}
#endif

void
init_param(T264_param_t* param, const char* file)
{
    FILE* fd; 
    char line[255];
    int32_t b;
    if (!(fd = fopen(file,"r")))
    {
        printf("Couldn't open parameter file %s.\n", file);
        exit(-1);
    }

    memset(param, 0, sizeof(*param));
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    if (b != 4)
    {
        printf("wrong param file version, expect v4.0\n");
        exit(-1);
    }
    fgets(line, 254, fd); sscanf(line,"%d", &param->width);
    fgets(line, 254, fd); sscanf(line,"%d", &param->height);
    fgets(line, 254, fd); sscanf(line,"%d", &param->search_x);
    fgets(line, 254, fd); sscanf(line,"%d", &param->search_y);
    fgets(line, 254, fd); sscanf(line,"%d", &total_no);
    fgets(line, 254, fd); sscanf(line,"%d", &param->iframe);
    fgets(line, 254, fd); sscanf(line,"%d", &param->idrframe);
    fgets(line, 254, fd); sscanf(line,"%d", &param->b_num);
    fgets(line, 254, fd); sscanf(line,"%d", &param->ref_num);
    fgets(line, 254, fd); sscanf(line,"%d", &param->enable_rc);
    fgets(line, 254, fd); sscanf(line,"%d", &param->bitrate);
    fgets(line, 254, fd); sscanf(line,"%f", &param->framerate);
    fgets(line, 254, fd); sscanf(line,"%d", &param->qp);
    fgets(line, 254, fd); sscanf(line,"%d", &param->min_qp);
    fgets(line, 254, fd); sscanf(line,"%d", &param->max_qp);
    fgets(line, 254, fd); sscanf(line,"%d", &param->enable_stat);
    fgets(line, 254, fd); sscanf(line,"%d", &param->disable_filter);
    fgets(line, 254, fd); sscanf(line,"%d", &param->aspect_ratio);
    fgets(line, 254, fd); sscanf(line,"%d", &param->video_format);
    fgets(line, 254, fd); sscanf(line,"%d", &param->luma_coeff_cost);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_INTRA16x16) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_INTRA4x4) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_INTRAININTER) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_HALFPEL) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_QUARTPEL) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_SUBBLOCK) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_FULLSEARCH) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_DIAMONDSEACH) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_FORCEBLOCKSIZE) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_FASTINTERPOLATE) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_SAD) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_EXTRASUBPELSEARCH) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->flags |= (USE_SCENEDETECT) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_16x16P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_16x8P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_8x16P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_8x8P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_8x4P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_4x8P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_4x4P) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_16x16B) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_16x8B) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_8x16B) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &b);
    param->block_size |= (SEARCH_8x8B) * (!!b);
    fgets(line, 254, fd); sscanf(line,"%d", &param->cpu);
    fgets(line, 254, fd); sscanf(line, "%d", &param->cabac);

    fgets(line, 254, fd); sscanf(line,"%s", src_path);
    fgets(line, 254, fd); sscanf(line,"%s", out_path);
    fgets(line, 254, fd); sscanf(line,"%s", rec_path);
    param->rec_name = rec_path;

    fclose(fd);
}

int32_t 
encode(const char* paramfile)
{
    T264_param_t param;
    T264_t* t;
    uint8_t* buf, *dst;
    int32_t size;
    FILE* in_file, *out_file;
    uint32_t len;
    int32_t frame_no;
    int32_t bs_len = 0;

    uint8_t* rec;

    float total_time;
#ifdef _WIN32
    struct _timeb beg, end;
#endif

#ifdef CHIP_DM642 
	clock_t start_T=0,end_T=0,total_T=0;
#endif
    init_param(&param, paramfile);

    param.direct_flag = 1;
    // NOTE: currently we force p reference frame num = 1
    t = T264_open(&param);

    /* YV12p */
    size = param.height * param.width + (param.height * param.width >> 1);
    buf = T264_malloc(size, CACHE_SIZE);
    in_file = fopen(src_path, "rb");
    if (!in_file)
    {
        printf("cannot open input file.");
        return 0;
    }

    out_file = fopen(out_path, "wb");
    if (!out_file)
    {
        printf("cannot write 264 file.\n");
        return 0;
    }

    dst = T264_malloc(size, CACHE_SIZE);
    rec = T264_malloc(size, CACHE_SIZE);

#ifdef _WIN32
    _ftime(&beg);
#endif
    printf("frame poc length qp Y U V\n");
    for(frame_no = 0; frame_no < total_no; frame_no++)
    {        
        if (fread(buf, size, 1, in_file) <= 0)
            printf("cannot read from input file.");
#ifdef CHIP_DM642
		start_T=clock();
#endif
        len = T264_encode(t, buf, dst, size);
#ifdef CHIP_DM642 
		end_T=clock();
		total_T=total_T+end_T-start_T-192;
#endif    
        bs_len += len;

        if (fwrite(dst, len, 1, out_file) < 0)
            printf("cannot write 264 file.\n");
    }
#ifndef CHIP_DM642
#ifdef _WIN32
    _ftime(&end);
    total_time = (float)(end.time - beg.time) + (float)(end.millitm - beg.millitm) / 1000;
#endif
    printf("fps: %.2ffps, Length of Bitstream = %d Compact Ratio = %.2f\n", (float)(total_no) / total_time, bs_len, 1.0 * total_no * size / bs_len);
#endif
#ifdef CHIP_DM642
	printf("fps: %.2ffps with cpu 600MHz, Length of Bitstream = %d Compact Ratio = %.2f\n", ((float)total_no /((float)total_T/(float)600000000)),  bs_len, 1.0 * total_no * size / bs_len);
#endif
    fclose(in_file);
    fclose(out_file);
    T264_free(dst);
    T264_close(t);

    return 0;
}

void
write_frame(T264_t* t,T264_frame_t *frame,FILE *f_rec)
{
    int	i;
    uint8_t* p;

    if (f_rec)
    {
        p = frame->Y[0];
        for(i = 0 ; i < t->height ; i ++)
        {
            fwrite(p, t->width, 1, f_rec);
            p += t->edged_stride;
        }
        p = frame->U;
        for(i = 0 ; i < t->height >> 1 ; i ++)
        {
            fwrite(p, t->width >> 1, 1, f_rec);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美v日韩v国产v| 91网上在线视频| 精品成a人在线观看| 久久精品国产免费看久久精品| 日韩精品一区二区三区在线观看| 久久99久久久久久久久久久| 久久免费电影网| 成人永久免费视频| 亚洲乱码国产乱码精品精小说| 色菇凉天天综合网| 日本亚洲电影天堂| 久久亚洲精品小早川怜子| 国产成人综合在线播放| 亚洲欧美另类在线| 91麻豆精品国产91久久久久久久久| 日韩 欧美一区二区三区| 国产视频一区二区在线观看| 不卡在线视频中文字幕| 亚洲aⅴ怡春院| 久久综合久久99| 91视频在线观看免费| 天天操天天干天天综合网| 精品国精品自拍自在线| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 欧美视频中文字幕| 美女mm1313爽爽久久久蜜臀| 国产精品天天看| 精品1区2区3区| 国产盗摄女厕一区二区三区| 亚洲夂夂婷婷色拍ww47| 久久综合色天天久久综合图片| 97久久精品人人澡人人爽| 青青青伊人色综合久久| 中文字幕在线不卡国产视频| 91精品国产欧美日韩| 成人精品免费看| 免费欧美高清视频| 亚洲视频一二区| 2021国产精品久久精品| 欧美色综合影院| 成人免费毛片片v| 日韩av高清在线观看| 亚洲女人小视频在线观看| 国产亚洲成aⅴ人片在线观看 | 精品一二三四在线| 亚洲精品国产a| 久久久精品免费观看| 在线免费不卡电影| 成人动漫精品一区二区| 精品系列免费在线观看| 亚洲毛片av在线| 欧美国产精品中文字幕| 555www色欧美视频| 精品视频在线看| 色域天天综合网| 成人精品国产免费网站| 狠狠久久亚洲欧美| 美腿丝袜亚洲一区| 亚洲1区2区3区4区| 亚洲电影视频在线| 亚洲猫色日本管| 国产精品不卡视频| 欧美国产一区在线| 中文字幕免费观看一区| 久久综合色婷婷| 日韩精品在线看片z| 日韩视频在线观看一区二区| 色999日韩国产欧美一区二区| 91在线高清观看| av中文字幕亚洲| 99久久99久久精品免费看蜜桃| 国产福利一区二区三区| 国产成人综合网| 成人午夜激情影院| 不卡高清视频专区| 欧美日韩视频一区二区| 色综合久久综合中文综合网| av午夜精品一区二区三区| 99久久婷婷国产综合精品电影| 国产高清亚洲一区| 成人综合在线视频| 成人动漫视频在线| 91黄色免费版| 欧美日韩在线播放一区| 777久久久精品| 日韩女优制服丝袜电影| 精品国产91洋老外米糕| 国产无人区一区二区三区| 日本一二三四高清不卡| 国产精品免费久久| 一区二区三区在线观看国产| 亚洲综合一区二区| 五月婷婷欧美视频| 精品一区二区在线视频| 精品一区二区三区视频| 成人性生交大片免费看视频在线 | 9191成人精品久久| 日韩一级免费观看| 国产片一区二区| 亚洲天堂av一区| 肉肉av福利一精品导航| 精品一区精品二区高清| 成人一区在线看| 精品视频资源站| 久久综合99re88久久爱| 国产精品日韩成人| 亚洲高清免费观看| 国产传媒久久文化传媒| 色av一区二区| 亚洲精品一区二区精华| 亚洲视频精选在线| 石原莉奈在线亚洲三区| 国产精品影视在线| 欧美最猛性xxxxx直播| 精品国产一区二区三区忘忧草| 亚洲国产高清在线观看视频| 偷偷要91色婷婷| 从欧美一区二区三区| 欧美肥胖老妇做爰| 日韩美女久久久| 久久99精品久久久久久动态图| 91性感美女视频| 精品国产一区a| 一区二区三区中文免费| 久久国产剧场电影| 色偷偷成人一区二区三区91| 欧美va在线播放| 亚洲在线视频网站| 成人午夜激情在线| 精品免费日韩av| 一区二区三区四区在线| 国产美女娇喘av呻吟久久| 欧美日精品一区视频| 国产精品久久久久久久久快鸭| 欧美aaa在线| 欧美午夜精品理论片a级按摩| 日本一区二区三区高清不卡| 日韩中文字幕av电影| 99精品久久99久久久久| 久久综合色8888| 三级欧美在线一区| 欧美自拍丝袜亚洲| 亚洲四区在线观看| 风间由美一区二区三区在线观看 | 欧美一级午夜免费电影| 一区二区在线观看不卡| 成人久久视频在线观看| 精品粉嫩超白一线天av| 日韩成人精品视频| 欧美午夜精品久久久久久超碰| 亚洲国产高清在线| 国产不卡免费视频| 久久午夜免费电影| 狠狠狠色丁香婷婷综合久久五月| 欧美一级搡bbbb搡bbbb| 亚洲444eee在线观看| 欧美视频精品在线| 亚洲第一激情av| 欧美性色aⅴ视频一区日韩精品| 中文字幕一区二区三区不卡在线| 国产乱妇无码大片在线观看| 日韩精品影音先锋| 国产在线精品一区二区三区不卡| 日韩免费一区二区| 久久精品国产精品亚洲红杏| 欧美一区二区性放荡片| 免费看日韩精品| 日韩欧美高清dvd碟片| 久久国产精品一区二区| 2欧美一区二区三区在线观看视频| 日韩福利电影在线| 日韩欧美在线不卡| 极品少妇一区二区三区精品视频 | 午夜精品在线看| 欧美视频三区在线播放| 丝袜a∨在线一区二区三区不卡| 欧美日韩在线亚洲一区蜜芽| 婷婷久久综合九色国产成人 | 在线免费观看日韩欧美| 亚洲午夜激情av| 欧美日本高清视频在线观看| 婷婷六月综合亚洲| 精品久久久久久亚洲综合网 | 成人av在线网站| 成人免费在线视频观看| 色播五月激情综合网| 亚洲va在线va天堂| 欧美一卡二卡在线| 国产精品资源站在线| 日韩理论在线观看| 欧美老肥妇做.爰bbww| 老鸭窝一区二区久久精品| 久久精品夜夜夜夜久久| 国产成人丝袜美腿| 亚洲日本一区二区三区| 这里是久久伊人| 国产91清纯白嫩初高中在线观看| 国产精品久久精品日日| 欧美色图在线观看| 韩国理伦片一区二区三区在线播放|