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

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

?? t264.c

?? T.264源代碼(基于VC開發環境 最新版本)
?? 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精品福利在线| 久久天天做天天爱综合色| 综合久久综合久久| 高潮精品一区videoshd| 欧美一区二区三区视频在线| 亚洲乱码国产乱码精品精98午夜 | 国产a久久麻豆| 日韩一区二区三免费高清| 亚洲精品国产a| 成人97人人超碰人人99| 2020国产精品| 麻豆成人91精品二区三区| 精品视频一区二区不卡| 亚洲日本电影在线| www.欧美精品一二区| 国产亚洲精品7777| 国产美女精品人人做人人爽| 日韩欧美一区中文| 秋霞午夜鲁丝一区二区老狼| 91最新地址在线播放| 中文字幕一区二区三区色视频| 经典三级视频一区| 精品动漫一区二区三区在线观看| 日韩有码一区二区三区| 91麻豆精品久久久久蜜臀| 亚洲高清免费在线| 欧美日韩国产一区二区三区地区| 亚洲综合色视频| 欧美视频在线一区二区三区 | 国产精品一区在线观看你懂的| 日韩精品一区二| 美女脱光内衣内裤视频久久网站 | 成人永久aaa| 国产精品天干天干在观线| 风间由美性色一区二区三区| 中文字幕欧美区| 99久久精品国产观看| 亚洲免费高清视频在线| 精品视频999| 日韩vs国产vs欧美| 日韩一区二区三区高清免费看看| 免费美女久久99| 国产欧美日韩麻豆91| 成人国产精品视频| 一区二区三区丝袜| 555夜色666亚洲国产免| 九九热在线视频观看这里只有精品| 欧美成人r级一区二区三区| 国产精品主播直播| 亚洲图片激情小说| 色老汉一区二区三区| 青青草原综合久久大伊人精品| 亚洲精品一区二区三区蜜桃下载 | 99国内精品久久| 午夜精品在线视频一区| 国产午夜精品久久久久久免费视| 成人动漫精品一区二区| 天天影视色香欲综合网老头| 久久伊人蜜桃av一区二区| 色综合久久久久网| 免费在线视频一区| 中文字幕在线不卡一区| 欧美一级片在线看| 成人的网站免费观看| 日本亚洲三级在线| 综合网在线视频| 欧美tickle裸体挠脚心vk| 日本道色综合久久| 国产麻豆精品久久一二三| 亚洲一区二区视频在线| 欧美一二三区在线| 91久久国产最好的精华液| 国产精品资源网| 日韩二区三区在线观看| 亚洲视频你懂的| 久久久精品黄色| 欧美一区二区免费视频| 99精品在线观看视频| 亚洲成人一区在线| 日韩毛片高清在线播放| 精品福利二区三区| 欧美一区永久视频免费观看| 色婷婷狠狠综合| 国产.精品.日韩.另类.中文.在线.播放| 亚州成人在线电影| 一区二区三区av电影 | 亚洲午夜激情网页| 国产精品初高中害羞小美女文| 欧美成人综合网站| 欧美日本乱大交xxxxx| 色婷婷av一区二区三区大白胸| 国产成人在线看| 激情综合色综合久久| 成人午夜电影久久影院| 蜜臀国产一区二区三区在线播放| 欧美一区二区三级| 欧美一级午夜免费电影| 日韩欧美国产1| 在线观看网站黄不卡| 欧美日产国产精品| 日本欧美加勒比视频| 亚洲一区二区三区视频在线播放| 亚洲欧洲日产国码二区| 国产精品久久久久影院老司| 久久久91精品国产一区二区精品| 日韩欧美三级在线| 欧美电视剧在线看免费| 91麻豆精品久久久久蜜臀 | 欧美日本在线观看| 欧美日韩一区不卡| 欧美日韩一区 二区 三区 久久精品 | 春色校园综合激情亚洲| 久久99精品久久久| 国产精品18久久久久久vr| 国产精品一区三区| 大尺度一区二区| 国产精品主播直播| 成年人午夜久久久| 99热在这里有精品免费| 一本色道久久综合亚洲91| 日本二三区不卡| 欧美福利视频一区| 日韩一区和二区| 中文字幕欧美一| 亚洲国产成人av网| 日本午夜精品视频在线观看| 蜜桃视频一区二区| 国产在线精品免费av| av激情综合网| 欧洲国内综合视频| 精品三级在线看| 国产精品乱码人人做人人爱| 亚洲精品精品亚洲| 蜜臀99久久精品久久久久久软件| 国产在线精品一区在线观看麻豆| 国产高清久久久久| 欧洲一区在线观看| 精品福利视频一区二区三区| 亚洲桃色在线一区| 日本特黄久久久高潮| 国产精品一区久久久久| 在线中文字幕不卡| 精品久久久影院| 樱桃国产成人精品视频| 伦理电影国产精品| 91在线观看免费视频| 7777精品伊人久久久大香线蕉最新版| 久久综合久久久久88| 一区二区三区中文免费| 国产一区二区不卡老阿姨| 色久综合一二码| 久久久久久久久久久久久夜| 亚洲成人在线免费| 岛国一区二区在线观看| 欧美高清一级片在线| 亚洲欧洲一区二区在线播放| 美女网站在线免费欧美精品| 一本一本久久a久久精品综合麻豆| 日韩欧美电影一二三| 亚洲综合网站在线观看| 成人免费毛片片v| 日韩免费性生活视频播放| 亚洲与欧洲av电影| 大胆欧美人体老妇| 久久久一区二区三区捆绑**| 亚洲444eee在线观看| 99视频有精品| 久久免费电影网| 奇米影视7777精品一区二区| 色一情一伦一子一伦一区| 欧美激情综合在线| 久久99久久99小草精品免视看| 欧美日韩在线直播| 亚洲精品中文在线影院| eeuss鲁片一区二区三区在线观看| 欧美xingq一区二区| 蜜臀va亚洲va欧美va天堂 | 久久精品一区四区| 免费成人美女在线观看| 欧美丝袜自拍制服另类| 伊人开心综合网| 91久久奴性调教| 亚洲自拍偷拍综合| 色综合色综合色综合色综合色综合| 国产午夜精品一区二区| 国产一区不卡精品| 久久亚洲综合av| 国产又粗又猛又爽又黄91精品| 欧美一二三四区在线| 蜜臀av性久久久久蜜臀av麻豆| 4438成人网| 蜜桃免费网站一区二区三区| 日韩精品中午字幕| 国产精品自拍一区| 色88888久久久久久影院按摩| 色久综合一二码| 欧美a一区二区|