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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? t264.c

?? T264是中國在JM系列和X264的基礎上尋找的新的H264編程途徑
?? 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);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产在线精品国自产拍免费| 中文字幕精品一区| 中文在线免费一区三区高中清不卡| 中文字幕日本乱码精品影院| 麻豆91在线看| 欧美另类变人与禽xxxxx| 国产精品久久网站| 久久99国产乱子伦精品免费| 在线视频欧美精品| 中文字幕亚洲在| 国产成人av福利| 欧美中文字幕一二三区视频| 久久国产生活片100| 91亚洲精华国产精华精华液| 日韩网站在线看片你懂的| 亚洲伊人伊色伊影伊综合网| 成人黄色在线视频| 久久亚洲一区二区三区四区| 免费成人av资源网| 欧美日韩电影在线| 亚洲精品国产无套在线观| 成人一区二区三区视频在线观看| 精品国产3级a| 久久精品理论片| 日韩一区二区三区在线视频| 婷婷丁香激情综合| 欧美色偷偷大香| 亚洲成人先锋电影| 欧美私人免费视频| 艳妇臀荡乳欲伦亚洲一区| 99riav久久精品riav| 国产欧美日韩另类一区| 97精品视频在线观看自产线路二| 欧美一级日韩不卡播放免费| 亚洲综合色成人| 91麻豆免费看| 亚洲美女偷拍久久| 欧美中文字幕一二三区视频| 亚洲成人久久影院| 欧美日韩亚洲综合一区| 天天影视网天天综合色在线播放 | 亚洲精品老司机| 9色porny自拍视频一区二区| 日韩美女精品在线| 色综合天天综合给合国产| 日韩欧美亚洲另类制服综合在线| 在线免费观看视频一区| 中文字幕一区在线| proumb性欧美在线观看| 亚洲婷婷综合色高清在线| 成人91在线观看| 亚洲卡通欧美制服中文| 欧美群妇大交群中文字幕| 日韩成人伦理电影在线观看| 精品国产伦一区二区三区观看体验| 国产精品一区二区91| 中文字幕中文字幕一区| 欧美在线观看视频一区二区三区| 亚洲国产精品一区二区www在线| 欧美福利视频导航| 国产一区不卡精品| 亚洲丝袜自拍清纯另类| 91精选在线观看| 丁香婷婷深情五月亚洲| 成人a级免费电影| 亚洲精品高清在线观看| 欧美日韩一区二区三区在线| 日韩不卡一区二区三区 | 538在线一区二区精品国产| 久久精品噜噜噜成人av农村| 中文字幕一区二区三区在线不卡| 欧美日韩一区三区四区| 国产福利一区二区三区| 亚洲一区在线视频| 久久精品在线免费观看| 欧美日韩中字一区| 国产suv精品一区二区883| 亚洲bdsm女犯bdsm网站| 久久精品视频免费观看| 欧美色国产精品| 国产91精品入口| 免费xxxx性欧美18vr| 综合久久久久久| 久久一区二区三区四区| av日韩在线网站| 久久国产精品一区二区| 国产精品美女一区二区三区| 欧美午夜精品久久久久久孕妇| 美女一区二区三区在线观看| 亚洲免费在线观看视频| 久久免费视频色| 欧美肥大bbwbbw高潮| 色综合天天综合狠狠| 国产精品99久久久久久似苏梦涵 | 成人网在线播放| 免费高清视频精品| 亚洲精品国产成人久久av盗摄| 久久精品视频一区二区| 精品伦理精品一区| 欧美一区二区三区视频免费| 国产日本亚洲高清| 91在线视频在线| 蓝色福利精品导航| 天堂午夜影视日韩欧美一区二区| 国产亚洲精品aa午夜观看| 欧美一区二区网站| 欧美网站一区二区| 色天使色偷偷av一区二区| 成人免费观看视频| 国产在线视频精品一区| 国内精品第一页| 激情小说欧美图片| 久久se精品一区精品二区| 日本免费新一区视频| 五月天国产精品| 亚洲综合自拍偷拍| 夜夜嗨av一区二区三区网页| 亚洲影院免费观看| 亚洲高清三级视频| 午夜电影一区二区| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品视频一二三区| 精品日韩欧美在线| 欧美va在线播放| 久久久久久综合| 亚洲成av人影院| 日韩av一区二区三区| 久久99精品国产麻豆不卡| 国产精品系列在线观看| 不卡的av在线| 欧美性生活一区| 7777精品伊人久久久大香线蕉| 欧美精品乱码久久久久久| 欧美成人vr18sexvr| 欧美mv日韩mv亚洲| 欧美激情中文字幕| 亚洲制服丝袜av| 免费在线看成人av| 国产一区二区精品久久91| 成人app软件下载大全免费| 色综合天天综合在线视频| 欧美群妇大交群中文字幕| 精品免费日韩av| 中文字幕av资源一区| 亚洲综合图片区| 男男成人高潮片免费网站| 国产成人午夜视频| 在线欧美日韩精品| 欧美tickling挠脚心丨vk| 国产精品视频观看| 日韩成人免费电影| 99久久综合国产精品| 7777精品伊人久久久大香线蕉经典版下载| 日韩欧美一卡二卡| 最近日韩中文字幕| 精品一区二区三区免费| 91蝌蚪porny九色| 精品国产乱码久久久久久1区2区| 国产精品人成在线观看免费| 日韩成人午夜精品| 99国产精品久久久久久久久久 | 国产丝袜欧美中文另类| 亚洲人成网站在线| 国产精一品亚洲二区在线视频| 色一情一伦一子一伦一区| 久久影视一区二区| 午夜视黄欧洲亚洲| av一区二区三区在线| 制服丝袜一区二区三区| 国产精品你懂的| 韩日精品视频一区| 欧美日韩精品一区二区天天拍小说| 久久精品水蜜桃av综合天堂| 喷白浆一区二区| 欧美手机在线视频| 最新热久久免费视频| 国产伦精品一区二区三区视频青涩 | 91丨porny丨蝌蚪视频| 亚洲精品在线免费播放| 五月婷婷激情综合网| 91麻豆精东视频| 国产精品久久久久9999吃药| 激情五月播播久久久精品| 欧美日韩国产一级二级| 亚洲另类在线视频| 99免费精品在线| 国产精品欧美一区喷水| 国产一区二区三区在线观看精品| 91精品国产乱| 天堂蜜桃一区二区三区| 欧美日韩在线播放三区| 一区二区三区在线播放| aa级大片欧美| 国产精品国产三级国产aⅴ原创| 国产成人在线视频网站| 久久蜜桃香蕉精品一区二区三区| 久久精品国内一区二区三区| 欧美一级黄色片| 久久99精品久久久久| 亚洲精品一区二区三区福利|