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

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

?? encoder.c

?? 圖象壓縮程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/***************************************************************************** * x264: h264 encoder ***************************************************************************** * Copyright (C) 2003 Laurent Aimar * $Id: encoder.c,v 1.12 2004/03/28 09:21:44 fenrir Exp $ * * Authors: Laurent Aimar <fenrir@via.ecp.fr> * * 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, USA. *****************************************************************************/#include <stdlib.h>#include <stdio.h>#include <string.h>#include <stdint.h>#include <math.h>#include "../core/common.h"#include "../core/cpu.h"#include "set.h"#include "analyse.h"#include "ratecontrol.h"#include "macroblock.h"/**************************************************************************** * ******************************* x264 libs ********************************** * ****************************************************************************/static float x264_psnr( uint8_t *pix1, int i_pix_stride, uint8_t *pix2, int i_pix2_stride, int i_width, int i_height ){    int64_t i_sqe = 0;    int x, y;    for( y = 0; y < i_height; y++ )    {        for( x = 0; x < i_width; x++ )        {            int tmp;            tmp = pix1[y*i_pix_stride+x] - pix2[y*i_pix2_stride+x];            i_sqe += tmp * tmp;        }    }    if( i_sqe == 0 )    {        return -1.0;    }    return (float)(10.0 * log( (double)65025.0 * (double)i_height * (double)i_width / (double)i_sqe ) / log( 10.0 ));}/* Fill "default" values */static void x264_slice_header_init( x264_slice_header_t *sh, x264_param_t *param,                                    x264_sps_t *sps, x264_pps_t *pps,                                    int i_type, int i_idr_pic_id, int i_frame ){    /* First we fill all field */    sh->sps = sps;    sh->pps = pps;    sh->i_type      = i_type;    sh->i_first_mb  = 0;    sh->i_pps_id    = pps->i_id;    sh->i_frame_num = i_frame;    sh->b_field_pic = 0;    /* Not field support for now */    sh->b_bottom_field = 1; /* not yet used */    sh->i_idr_pic_id = i_idr_pic_id;    /* poc stuff, fixed later */    sh->i_poc_lsb = 0;    sh->i_delta_poc_bottom = 0;    sh->i_delta_poc[0] = 0;    sh->i_delta_poc[1] = 0;    sh->i_redundant_pic_cnt = 0;    sh->b_direct_spatial_mv_pred = 0;    sh->b_num_ref_idx_override = 0;    sh->i_num_ref_idx_l0_active = 1;    sh->i_num_ref_idx_l1_active = 1;    sh->i_cabac_init_idc = param->i_cabac_init_idc;    sh->i_qp_delta = 0;    sh->b_sp_for_swidth = 0;    sh->i_qs_delta = 0;    if( param->b_deblocking_filter )    {        sh->i_disable_deblocking_filter_idc = 0;    }    else    {        sh->i_disable_deblocking_filter_idc = 1;    }    sh->i_alpha_c0_offset = 0;    sh->i_beta_offset = 0;}static void x264_slice_header_write( bs_t *s, x264_slice_header_t *sh, int i_nal_ref_idc ){    bs_write_ue( s, sh->i_first_mb );    bs_write_ue( s, sh->i_type + 5 );   /* same type things */    bs_write_ue( s, sh->i_pps_id );    bs_write( s, sh->sps->i_log2_max_frame_num, sh->i_frame_num );    if( sh->i_idr_pic_id >= 0 ) /* NAL IDR */    {        bs_write_ue( s, sh->i_idr_pic_id );    }    if( sh->sps->i_poc_type == 0 )    {        bs_write( s, sh->sps->i_log2_max_poc_lsb, sh->i_poc_lsb );        if( sh->pps->b_pic_order && !sh->b_field_pic )        {            bs_write_se( s, sh->i_delta_poc_bottom );        }    }    else if( sh->sps->i_poc_type == 1 && !sh->sps->b_delta_pic_order_always_zero )    {        bs_write_se( s, sh->i_delta_poc[0] );        if( sh->pps->b_pic_order && !sh->b_field_pic )        {            bs_write_se( s, sh->i_delta_poc[1] );        }    }    if( sh->pps->b_redundant_pic_cnt )    {        bs_write_ue( s, sh->i_redundant_pic_cnt );    }    if( sh->i_type == SLICE_TYPE_B )    {        bs_write1( s, sh->b_direct_spatial_mv_pred );    }    if( sh->i_type == SLICE_TYPE_P || sh->i_type == SLICE_TYPE_SP || sh->i_type == SLICE_TYPE_B )    {        bs_write1( s, sh->b_num_ref_idx_override );        if( sh->b_num_ref_idx_override )        {            bs_write_ue( s, sh->i_num_ref_idx_l0_active - 1 );            if( sh->i_type == SLICE_TYPE_B )            {                bs_write_ue( s, sh->i_num_ref_idx_l1_active - 1 );            }        }    }    /* ref pic list reordering */    if( sh->i_type != SLICE_TYPE_I )    {        int b_ref_pic_list_reordering_l0 = 0;        bs_write1( s, b_ref_pic_list_reordering_l0 );        if( b_ref_pic_list_reordering_l0 )        {            /* FIXME */        }    }    if( sh->i_type == SLICE_TYPE_B )    {        int b_ref_pic_list_reordering_l1 = 0;        bs_write1( s, b_ref_pic_list_reordering_l1 );        if( b_ref_pic_list_reordering_l1 )        {            /* FIXME */        }    }    if( ( sh->pps->b_weighted_pred && ( sh->i_type == SLICE_TYPE_P || sh->i_type == SLICE_TYPE_SP ) ) ||        ( sh->pps->b_weighted_bipred == 1 && sh->i_type == SLICE_TYPE_B ) )    {        /* FIXME */    }    if( i_nal_ref_idc != 0 )    {        if( sh->i_idr_pic_id >= 0 )        {            bs_write1( s, 0 );  /* no output of prior pics flag */            bs_write1( s, 0 );  /* long term reference flag */        }        else        {            bs_write1( s, 0 );  /* adaptive_ref_pic_marking_mode_flag */            /* FIXME */        }    }    if( sh->pps->b_cabac && sh->i_type != SLICE_TYPE_I )    {        bs_write_ue( s, sh->i_cabac_init_idc );    }    bs_write_se( s, sh->i_qp_delta );      /* slice qp delta */#if 0    if( sh->i_type == SLICE_TYPE_SP || sh->i_type == SLICE_TYPE_SI )    {        if( sh->i_type == SLICE_TYPE_SP )        {            bs_write1( s, sh->b_sp_for_swidth );        }        bs_write_se( s, sh->i_qs_delta );    }#endif    if( sh->pps->b_deblocking_filter_control )    {        bs_write_ue( s, sh->i_disable_deblocking_filter_idc );        if( sh->i_disable_deblocking_filter_idc != 1 )        {            bs_write_se( s, sh->i_alpha_c0_offset >> 1 );            bs_write_se( s, sh->i_beta_offset >> 1 );        }    }}#if 0static void x264_frame_dump( x264_t *h, x264_frame_t *fr, char *name ){    FILE * f = fopen( name, "a" );    int i, y;    fseek( f, 0, SEEK_END );    for( i = 0; i < fr->i_plane; i++ )    {        for( y = 0; y < h->param.i_height / ( i == 0 ? 1 : 2 ); y++ )        {            fwrite( &fr->plane[i][y*fr->i_stride[i]], 1, h->param.i_width / ( i == 0 ? 1 : 2 ), f );        }    }    fclose( f );}#endif/**************************************************************************** * **************************************************************************** ****************************** External API********************************* **************************************************************************** * ****************************************************************************//**************************************************************************** * x264_encoder_open: ****************************************************************************/x264_t *x264_encoder_open   ( x264_param_t *param ){    x264_t *h = x264_malloc( sizeof( x264_t ) );    int i;    x264_me_t me[2];    if( param->i_width <= 0  || param->i_height <= 0 )    {        fprintf( stderr, "invalid width x height (%dx%d)\n",                 param->i_width, param->i_height );        free( h );        return NULL;    }    if( param->i_width % 16 != 0 || param->i_height % 16 != 0 )    {        fprintf( stderr, "width %% 16 != 0 pr height %% 16 != 0 (%dx%d)\n",                 param->i_width, param->i_height );        free( h );        return NULL;    }    memcpy( &h->param, param, sizeof( x264_param_t ) );    if( h->param.i_frame_reference <= 0 )    {        h->param.i_frame_reference = 1;    }    else if( h->param.i_frame_reference > 15 )    {        h->param.i_frame_reference = 15;    }    if( h->param.i_idrframe <= 0 )    {        h->param.i_idrframe = 1;    }    if( h->param.i_iframe <= 0 )    {        h->param.i_iframe = 1;    }    if( h->param.i_bframe < 0 )    {        h->param.i_bframe = 0;    }    else if( h->param.i_bframe > X264_BFRAME_MAX )    {        h->param.i_bframe = X264_BFRAME_MAX;    }    /* XXX for now we use fixed patern IB...BPB...BPB...BP */    if( h->param.i_bframe > 0 )    {        h->param.i_iframe = ((h->param.i_iframe - 1)/(h->param.i_bframe+1))*(h->param.i_bframe+1) + 1;        if( h->param.b_cabac )        {            fprintf( stderr, "cabac not supported with B frame (cabac disabled)\n" );            h->param.b_cabac = 0;        }    }    if( h->param.i_cabac_init_idc < -1 )    {        h->param.i_cabac_init_idc = -1;    }    else if( h->param.i_cabac_init_idc > 2 )    {        h->param.i_cabac_init_idc = 2;    }    h->cpu = param->cpu;    h->i_nal = 0;    h->i_bitstream = 1000000; /* FIXME calculate max size from width/height */    h->p_bitstream = x264_malloc( h->i_bitstream );    h->i_frame = 0;    h->i_frame_num = 0;    h->i_poc   = 0;    h->i_idr_pic_id = 0;    h->sps = &h->sps_array[0];    x264_sps_init( h->sps, 0, &h->param );    h->pps = &h->pps_array[0];    x264_pps_init( h->pps, 0, &h->param, h->sps);    /* init picture and bframe context */    h->picture = NULL;    for( i = 0; i < X264_BFRAME_MAX; i++ )    {        h->bframe_current[i]= NULL;        h->frame_next[i]    = NULL;        h->frame_unused[i]  = NULL;    }    h->frame_next[X264_BFRAME_MAX]  = NULL;    h->frame_unused[X264_BFRAME_MAX]= NULL;    for( i = 0; i < h->param.i_bframe+1; i++ )    {        h->frame_unused[i] = x264_frame_new( h );

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美一区二区精品秋霞影院 | www.欧美.com| 色系网站成人免费| 精品国产123| 一区二区成人在线视频 | 天天色综合天天| 国产mv日韩mv欧美| 538在线一区二区精品国产| 欧美国产日本韩| 日韩经典中文字幕一区| 色美美综合视频| 国产片一区二区| 另类人妖一区二区av| 在线观看不卡一区| 亚洲情趣在线观看| 成人一级黄色片| 久久久久国产精品厨房| 麻豆国产一区二区| 3d成人h动漫网站入口| 亚洲成人一区在线| 91首页免费视频| 国产欧美日韩另类视频免费观看| 日韩av网站免费在线| 欧美亚男人的天堂| 亚洲人成网站色在线观看| www.成人在线| 欧美极品少妇xxxxⅹ高跟鞋 | 国产精品婷婷午夜在线观看| 久久99久久久久| 日韩一级高清毛片| 午夜精品一区二区三区免费视频 | 粉嫩欧美一区二区三区高清影视| 91精品综合久久久久久| 性久久久久久久| 8x8x8国产精品| 婷婷综合另类小说色区| 欧美在线视频你懂得| 亚洲视频免费在线观看| 色婷婷精品久久二区二区蜜臀av| 亚洲视频免费在线| 在线一区二区观看| 亚洲国产精品视频| 91精品欧美福利在线观看| 日韩激情一二三区| 日韩欧美不卡在线观看视频| 乱中年女人伦av一区二区| 欧美成人在线直播| 国产精品资源在线看| 久久久久久久精| 91小视频免费看| 国产在线一区观看| 欧美国产精品一区二区| 99久久精品情趣| 亚洲制服丝袜在线| 日韩视频123| 粉嫩嫩av羞羞动漫久久久| 亚洲精品高清在线| 欧美精品久久99久久在免费线| 日本v片在线高清不卡在线观看| 久久午夜色播影院免费高清| gogo大胆日本视频一区| 亚洲精品你懂的| 日韩一区二区精品在线观看| 国产成人亚洲综合a∨婷婷| 最新日韩av在线| 91麻豆精品91久久久久久清纯| 国产一区二区女| 亚洲激情自拍视频| 欧美v国产在线一区二区三区| 成人精品在线视频观看| 亚洲国产精品久久久久秋霞影院| 7799精品视频| 不卡av免费在线观看| 亚洲高清视频在线| 国产亚洲成aⅴ人片在线观看| 欧美性欧美巨大黑白大战| 黄一区二区三区| 一区二区三区视频在线观看| 精品久久国产97色综合| 在线观看欧美黄色| 国产不卡在线一区| 免费成人在线观看视频| 亚洲精品少妇30p| 久久久国际精品| 宅男在线国产精品| 色激情天天射综合网| 风流少妇一区二区| 久久精品久久久精品美女| 一区二区三区精品视频| 日本一区二区视频在线| 91精品欧美久久久久久动漫| 91亚洲国产成人精品一区二区三| 国产自产v一区二区三区c| 亚洲高清视频在线| 亚洲理论在线观看| 国产精品乱人伦中文| 精品欧美乱码久久久久久| 欧美三区在线观看| 91日韩一区二区三区| 国产1区2区3区精品美女| 久久99精品久久久久| 欧美bbbbb| 天天色综合天天| 亚洲国产裸拍裸体视频在线观看乱了| 国产日韩v精品一区二区| 精品国产乱码91久久久久久网站| 欧美精品粉嫩高潮一区二区| 色偷偷88欧美精品久久久| 99精品视频一区二区| fc2成人免费人成在线观看播放 | 久久久久久免费毛片精品| 亚洲人成精品久久久久| 一区在线观看免费| 色综合久久综合网欧美综合网 | 激情综合色综合久久| 亚洲一区二区三区爽爽爽爽爽| 国产精品久99| 国产精品夫妻自拍| 国产精品美女久久福利网站| 国产欧美视频在线观看| 国产欧美日韩在线| 国产精品美女久久久久久| 国产欧美日韩在线观看| 国产农村妇女毛片精品久久麻豆| 欧美激情一区二区三区蜜桃视频 | 国产精品一区二区免费不卡| 久久成人免费网| 国产福利一区在线| 成人国产电影网| 97精品久久久久中文字幕 | 成人在线一区二区三区| 国产91丝袜在线观看| 97久久超碰国产精品| 欧美亚洲国产一区二区三区 | 欧美一区二区视频观看视频| 欧美色综合影院| 91麻豆精品国产自产在线观看一区| 91麻豆精品91久久久久同性| 日韩欧美成人激情| 国产清纯在线一区二区www| 亚洲视频免费看| 日韩黄色免费电影| 国产精品综合久久| 日本韩国精品在线| 91精品麻豆日日躁夜夜躁| 久久综合九色综合97婷婷| 国产精品久久久久久久久免费樱桃| 一区二区三区毛片| 国内精品伊人久久久久av影院 | 理论电影国产精品| 成人动漫精品一区二区| 欧美日韩高清一区| 久久久精品tv| 亚洲香蕉伊在人在线观| 精品一区二区三区免费毛片爱| 成人高清视频在线| 5月丁香婷婷综合| 国产精品久久久久毛片软件| 午夜影院久久久| 春色校园综合激情亚洲| 91精品免费观看| 亚洲欧美日韩人成在线播放| 奇米色一区二区三区四区| 91麻豆免费视频| 久久久久久电影| 日本三级亚洲精品| 91在线视频在线| 欧美精品一区二区三区一线天视频 | 亚洲另类色综合网站| 黑人巨大精品欧美黑白配亚洲| 色综合中文字幕国产| 91精品国产综合久久久久久久| 国产精品毛片无遮挡高清| 蜜臀av国产精品久久久久| 久久久久久**毛片大全| 水野朝阳av一区二区三区| 色激情天天射综合网| 国产精品免费久久久久| 精品一区二区三区香蕉蜜桃| 欧美久久久久久蜜桃| 亚洲欧美成aⅴ人在线观看 | 美女性感视频久久| 欧美性生活大片视频| 亚洲人成网站在线| av在线不卡免费看| 久久久久青草大香线综合精品| 日韩综合小视频| 欧美亚洲综合一区| 一区二区三区在线观看视频 | 亚洲精品中文在线影院| www.欧美日韩国产在线| 中文字幕免费不卡| 粉嫩嫩av羞羞动漫久久久| 国产亚洲欧美色| 国产精品一区三区| 久久亚洲精华国产精华液| 狠狠色丁香婷婷综合久久片| 日韩精品专区在线影院重磅| 久久国产精品第一页| 欧美大白屁股肥臀xxxxxx|