nv121_nvl2函数用法

nv121_nvl2函数用法#include#include#include#include#includetypedefunsignedcharuint8_t; /**  *@paramsrcinputnv12rawdataarray  *@paramdstoutputnv12rawdataresult,  *thememor

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用
#include <time.h>

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <sys/stat.h>

typedef unsigned char uint8_t;

 

/** 

 * @param src input nv12 raw data array  

 * @param dst output nv12 raw data result, 

 * the memory need to be allocated outside of the function 

 * @param srcWidth width of the input nv12 image 

 * @param srcHeight height of the input nv12 image 

 * @param dstWidth

 * @param dstHeight 

 */

void nv12_nearest_scale(uint8_t* __restrict src, uint8_t* __restrict dst,

                        int srcWidth, int srcHeight, int dstWidth, int

dstHeight)      //restrict keyword is for compiler to optimize program

{

    register int sw = srcWidth;  //register keyword is for local var to accelorate 

    register int sh = srcHeight;

    register int dw = dstWidth;

    register int dh = dstHeight;

    register int y, x;

    unsigned long int srcy, srcx, src_index, dst_index;

    unsigned long int xrIntFloat_16 = (sw << 16) / dw + 1; //better than float division

    unsigned long int yrIntFloat_16 = (sh << 16) / dh + 1;

    uint8_t* dst_uv = dst + dh * dw; //memory start pointer of dest uv

    uint8_t* src_uv = src + sh * sw; //memory start pointer of source uv

    uint8_t* dst_uv_yScanline;

    uint8_t* src_uv_yScanline;

    uint8_t* dst_y_slice = dst; //memory start pointer of dest y

    uint8_t* src_y_slice;

    uint8_t* sp;

    uint8_t* dp;

 

    for (y = 0; y < (dh & ~7); ++y)  //’dh & ~7′ is to generate faster assembly code

    {

        srcy = (y * yrIntFloat_16) >> 16;

        src_y_slice = src + srcy * sw;

        if((y & 1) == 0)

        {

            dst_uv_yScanline = dst_uv + (y / 2) * dw;

            src_uv_yScanline = src_uv + (srcy / 2) * sw;

        }

        for(x = 0; x < (dw & ~7); ++x)

        {

            srcx = (x * xrIntFloat_16) >> 16;

            dst_y_slice[x] = src_y_slice[srcx];

            if((y & 1) == 0) //y is even

            {

                if((x & 1) == 0) //x is even

                {

                    src_index = (srcx / 2) * 2;

            

                    sp = dst_uv_yScanline + x;

                    dp = src_uv_yScanline + src_index;

                    *sp = *dp;

                    ++sp;

                    ++dp;

                    *sp = *dp;

                }

             }

         }

         dst_y_slice += dw;

    }

}

void nv12_bilinear_scale (uint8_t* src, uint8_t* dst,

        int srcWidth, int srcHeight, int dstWidth,int dstHeight)

{

    int x, y;

    int ox, oy;

    int tmpx, tmpy;

    int xratio = (srcWidth << 8)/dstWidth;

    int yratio = (srcHeight << 8)/dstHeight;

    uint8_t* dst_y = dst;

    uint8_t* dst_uv = dst + dstHeight * dstWidth;

    uint8_t* src_y = src;

    uint8_t* src_uv = src + srcHeight * srcWidth;

    uint8_t y_plane_color[2][2];

    uint8_t u_plane_color[2][2];

    uint8_t v_plane_color[2][2];

    int j,i;

    int size = srcWidth * srcHeight;

    int offsetY;

    int y_final, u_final, v_final; 

    int u_final1 = 0;

    int v_final1 = 0;

    int u_final2 = 0;

    int v_final2 = 0;

    int u_final3 = 0;

    int v_final3 = 0;

    int u_final4 = 0;

    int v_final4 = 0;

    int u_sum = 0;

    int v_sum = 0;

    tmpy = 0;

    for (j = 0; j < (dstHeight & ~7); ++j)

    {

        //tmpy = j * yratio;

    oy = tmpy >> 8;

    y = tmpy & 0xFF;

    tmpx = 0;

    for (i = 0; i < (dstWidth & ~7); ++i)

    {

        // tmpx = i * xratio;

        ox = tmpx >> 8;

        x = tmpx & 0xFF;

    

        offsetY = oy * srcWidth;

            //YYYYYYYYYYYYYYYY

        y_plane_color[0][0] = src[ offsetY + ox ];

        y_plane_color[1][0] = src[ offsetY + ox + 1 ];

        y_plane_color[0][1] = src[ offsetY + srcWidth + ox ];

        y_plane_color[1][1] = src[ offsetY + srcWidth + ox + 1 ];

            

        int y_final = (0x100 – x) * (0x100 – y) * y_plane_color[0][0]

            + x * (0x100 – y) * y_plane_color[1][0]

            + (0x100 – x) * y * y_plane_color[0][1]

            + x * y * y_plane_color[1][1];

        y_final = y_final >> 16;

        if (y_final>255)

            y_final = 255;

        if (y_final<0)

            y_final = 0;

        dst_y[ j * dstWidth + i] = (uint8_t)y_final; //set Y in dest array 

            //UVUVUVUVUVUV

        if((j & 1) == 0) //j is even

        {

            if((i & 1) == 0) //i is even

            {

                u_plane_color[0][0] = src[ size + offsetY + ox ];

                u_plane_color[1][0] = src[ size + offsetY + ox ];

                u_plane_color[0][1] = src[ size + offsetY + ox ];

                u_plane_color[1][1] = src[ size + offsetY + ox ];

                v_plane_color[0][0] = src[ size + offsetY + ox + 1];

                v_plane_color[1][0] = src[ size + offsetY + ox + 1];

                v_plane_color[0][1] = src[ size + offsetY + ox + 1];

                v_plane_color[1][1] = src[ size + offsetY + ox + 1];

            }

            else //i is odd

            {

                u_plane_color[0][0] = src[ size + offsetY + ox – 1 ];

                u_plane_color[1][0] = src[ size + offsetY + ox + 1 ];

                u_plane_color[0][1] = src[ size + offsetY + ox – 1 ];

                u_plane_color[1][1] = src[ size + offsetY + ox + 1 ];

                v_plane_color[0][0] = src[ size + offsetY + ox ];

                v_plane_color[1][0] = src[ size + offsetY + ox + 1 ];

                v_plane_color[0][1] = src[ size + offsetY + ox ];

                v_plane_color[1][1] = src[ size + offsetY + ox + 1 ];

            }

        }

        else // j is odd

        {

            if((i & 1) == 0) //i is even

            {

                u_plane_color[0][0] = src[ size + offsetY + ox ];

                u_plane_color[1][0] = src[ size + offsetY + ox ];

                u_plane_color[0][1] = src[ size + offsetY + srcWidth + ox ];

                u_plane_color[1][1] = src[ size + offsetY + srcWidth + ox ];

                    

                v_plane_color[0][0] = src[ size + offsetY + ox + 1];

                v_plane_color[1][0] = src[ size + offsetY + ox + 1];

                v_plane_color[0][1] = src[ size + offsetY + srcWidth + ox + 1];

                v_plane_color[1][1] = src[ size + offsetY + srcWidth + ox + 1];                                                    

            }

            else //i is odd

            {

                u_plane_color[0][0] = src[ size + offsetY + ox – 1 ];

                u_plane_color[1][0] = src[ size + offsetY + srcWidth + ox – 1 ];

                u_plane_color[0][1] = src[ size + offsetY + ox + 1];

                u_plane_color[1][1] = src[ size + offsetY + srcWidth + ox + 1];

                v_plane_color[0][0] = src[ size + offsetY + ox ];

                v_plane_color[1][0] = src[ size + offsetY + srcWidth + ox ];

                v_plane_color[0][1] = src[ size + offsetY + ox + 2 ];

                v_plane_color[1][1] = src[ size + offsetY + srcWidth + ox + 2 ];

            }

        }

       int u_final = (0x100 – x) * (0x100 – y) * u_plane_color[0][0]

                     + x * (0x100 – y) * u_plane_color[1][0]

                     + (0x100 – x) * y * u_plane_color[0][1]

                     + x * y * u_plane_color[1][1];

       u_final = u_final >> 16;

       int v_final = (0x100 – x) * (0x100 – y) * v_plane_color[0][0]

                      + x * (0x100 – y) * v_plane_color[1][0]

                      + (0x100 – x) * y * v_plane_color[0][1]

                      + x * y * v_plane_color[1][1];

       v_final = v_final >> 16;

       if((j & 1) == 0)

       {

           if((i & 1) == 0)

           {    

               //set U in dest array  

               dst_uv[(j / 2) * dstWidth + i ] = (uint8_t)(u_sum / 4);

               //set V in dest array

               dst_uv[(j / 2) * dstWidth + i + 1] = (uint8_t)(v_sum / 4);

               u_sum = 0;

               v_sum = 0;

           }

       }

       else

       {

           u_sum += u_final;

           v_sum += v_final;

       }

       tmpx += xratio;

    }

    tmpy += yratio;

    }

}

int ImageResize(uint8_t * src, uint8_t* dst, int sw,

        int sh,int dw,int dh)

{

    if( (src == NULL) || (dst == NULL) || (0 == dw) || (0 == dh) ||

            (0 == sw) || (0 == sh))

    {

        printf(“params error\n”);

        return -1;

    }

        nv12_nearest_scale(src, dst, sw, sh, dw, dh);

    //nv12_bilinear_scale(src, dst, sw, sh, dw, dh);

    //greyscale(src, dst, sw, sh, dw, dh);

    return 0;

}

int main(int argc,char**argv)

{

    if(argc!=7)

    {

        printf(“Input Error!\n”);

        printf(“Usage :  <Input NV12file> <Output NV12file> 

                <sw><sh> <dw> <dh>”);

        return 0;

    }

 

    FILE *inputfp = NULL;

    FILE *outputfp = NULL;

 

    inputfp = fopen(argv[1], “rb”);

    if (!inputfp)

    {

        fprintf(stderr, “fopen failed for input file[%s]\n”,argv[1]);

        return -1;

    }

 

    outputfp = fopen(argv[2], “wb”);

 

    if (!outputfp)

    {

        fprintf(stderr, “fopen failed for output file[%s]\n”,argv[2]);

        return -1;

    }

 

    int sw = atoi(argv[3]);

    int sh = atoi(argv[4]);

    int dw = atoi(argv[5]);

    int dh = atoi(argv[6]);

 

    if(sw <= 0 || sh <= 0 || dw <= 0 || dh <=0)

    {

        fprintf(stderr, “parameter error [sw= %d,sh= %d,dw= %d,dh= %d]\n”,sw,sh,dw,dh);

        return -1;

    }

 

    int inPixels = sw * sh * 3/2;

    int outPixels = dw * dh * 3/2;

 

    uint8_t* pInBuffer = (uint8_t*)malloc(inPixels);

    fread(pInBuffer,1,inPixels,inputfp);

    uint8_t* pOutBuffer = (uint8_t*)malloc(outPixels);

 

    ImageResize(pInBuffer,pOutBuffer,sw,sh,dw,dh);

        //compute frame per second

    int i = 0;

    clock_t start = clock();

 

    for(;i<1000;++i)

    {

        ImageResize(pInBuffer,pOutBuffer,1536,1088,1024,600);//can change to be any resolution    

    }

    clock_t finish = clock();

    float duration = (float)(finish-start)/CLOCKS_PER_SEC;

    float fps = 1000 / duration;

    printf(“nv12Scaling:%d*%d–>%d*%d,time cost:%6.2ffps\n”,sw,sh,dw,dh,fps);

 

    fwrite(pOutBuffer, 1 , outPixels, outputfp);

 

    free(pInBuffer);

    free(pOutBuffer);

    fclose(inputfp);

    fclose(outputfp);

    pInBuffer = NULL;

    pOutBuffer = NULL;

    inputfp = NULL;

    outputfp = NULL;

    return 0;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/189959.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 一个servlet登陆过滤器

    一个servlet登陆过滤器

  • 大篆汉字对照表_篆书转换器软件下载(篆体字转换汉字对照表)[通俗易懂]

    笔顺篆书的笔顺和汉字笔顺规则基本相仿,如先横后竖、从上到下、从左到右等,这些对初学者来说是不成问题的。重要的是和汉字不同的笔顺,而这些不同之处正是篆书笔顺的特点,掌握了这些特点,就能把握好篆书的结体,做到匀称匀衡。先中间后左右对称均衡是篆字的特点。对于有中心竖线的篆字,应先写中间竖笔或中间部位的笔画,中间定位后,再写左右对称的其他笔画。对于有中心长弧(一般为撇、捺笔)的篆字,应先从中间长弧写起,再…

  • macpycharm2021激活码【在线注册码/序列号/破解码】

    macpycharm2021激活码【在线注册码/序列号/破解码】,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • java中常见的运行时异常_java五种常见异常

    java中常见的运行时异常_java五种常见异常运行时异常:编译时不会报错,但程序运行起来如果有错误就会报异常。以下为常见的运行时异常:ArithmeticException算数运算异常,由于除数为0引起的异常;ClassCastException类型转换异常,当把一个对象归为某个类,但实际上此对象并不是由这个类创建的,也不是其子类创建的,则会引起异常;ArrayStoreException由于数组存储空间不够引起的异…

  • UART 接口测试「建议收藏」

    UART 接口测试「建议收藏」串口UART测试程序带传参波特率、奇偶校验、停止位、数据位#include<stdio.h>#include<stdlib.h>#include<string.h>#include<pthread.h>#include<fcntl.h>#include<errno.h>#include<std…

  • python微信推送{u‘errcode‘: 40008, u‘errmsg‘: u‘invalid message type rid: 6111061f-19703d5b[通俗易懂]

    python微信推送{u‘errcode‘: 40008, u‘errmsg‘: u‘invalid message type rid: 6111061f-19703d5b[通俗易懂]记录一下前两天自己搞的一个蠢事,当时是要做一个微信信息推送,我先是按照微信的接口文档和网上的一些例子把代码写好了,测试的时候一直报这个40008,看微信接口文档又是说消息类型不对,大概就是说你给的data跟你定义的模板格式不对但是我都对了好几次,发现没问题,后面检查了一下接口的链接,发现跟接口文档里的不一样,应该是在复制别人的时候复制错了,换成文档里的链接后就正常了。所以,以后遇到这种{u’errcode’:40008,u’errmsg’:u’invalidmessagetyperid:

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号