切片

作者: 菜菜子MJ | 来源:发表于2021-10-09 18:05 被阅读0次

帧长 frame_len
帧移 frame_shift
重叠部分长度 frame_overlap

    /*
    * Cut data length of frame_overlap+buffer_shift+frame_overlap
    * If no enough data, zeros are filled in.
    * The data in fram_overlap just participate in model forward
    * All we care about is the data length of buffer_shift in middle
    * */
    int input_size = new_input_data.size();
    int frame_overlap = _opts.frame_len - _opts.frame_shift;
    int buffer_shift = _opts.sample_frequency * _opts.slice_second;
    for (int start = 0; start < input_size; start += buffer_shift) {
        int end = std::min(start + buffer_shift, input_size);
        int buffer_size = frame_overlap + (end - start) + frame_overlap;
        int start_pad = std::max(start - frame_overlap, 0);
        int end_pad = std::min(end + frame_overlap, input_size);
        int start_buffer = frame_overlap - (start - start_pad);
        int copy_buffer_len = end_pad - start_pad;
        std::vector<float> input_buffer(buffer_size, 0);
        memcpy(input_buffer.data() + start_buffer,
               new_input_data.data() + start_pad,
               copy_buffer_len * sizeof(float));
        std::vector<int64_t> input_dims = {1, (int64_t)input_buffer.size()};
        std::vector<std::vector<BaseFloat>> output_buffer;
        if (_inference_utils->run(input_buffer, input_dims, output_buffer)
            != 0) {
            IDEC_WARN << "Fail to get denoised data";
            return -1;
        }
        if (start == 0) {
            output_data.resize(output_buffer.size());
            for (size_t i = 0; i < output_data.size(); i++) {
                output_data[i].reserve(input_size);
            }
        }
        for (size_t i = 0; i < output_data.size(); i++) {
            IDEC_ASSERT(output_buffer[i].size() == buffer_size);
            output_data[i].insert(
                    output_data[i].end(),
                    output_buffer[i].data() + frame_overlap,
                    output_buffer[i].data() + frame_overlap + (end - start));
        }
    }

相关文章

  • 15.Go_Slice(切片)

    Go 切片 定义切片 切片初始化 len()和cap()函数 空(nil)切片 切片拦截 append() 和co...

  • Python的高级特性

    切片 list切片 tuple切片 str切片 迭代 在Python中迭代是通过for ... in ...来实现...

  • 切片

    切片前的准备 1切片前,备份图片;切片后,也要保存文件,为日后修改做准备。 2切片前设置切片文件夹(?不懂) 切片...

  • 你能一口说出go中字符串转字节切片的容量嘛?

    神奇的现象 切片, 切片, 又是切片! 前一篇文章讲的是切片, 今天遇到的神奇问题还是和切片有关, 具体怎么个神奇...

  • 【golang】slice底层函数传参原理易错点

    切片底层结构 切片的底层结构主要包括引用数组的地址data,切片长度len与切片容量cap。 以切片为参数调用函数...

  • day02-07clice

    切片slise 切片的定义 初始化 长度len和容量cap 由数组得到切片 切片的容量cap是指底层数组从切片的第...

  • Mapreduce切片机制

    FileInputFormat切片机制 切片机制:简单的按照文件的内容长度进行切片切片大小,默认等于Block大小...

  • 数据类型

    切片slice 切片取值 s = s[low : high : max] 切片的三个参数的切片截取的意义为 low...

  • go 语言切片

    go 语言切片 简单切片 slice 是 对 array 的一个 view 创建简单切片 切片作为函数参数 对切...

  • Go数组和切片区别

    数组是值传递,切片是引用传递 切片可扩容 切片多一个cap属性 切片底层用数组实现

网友评论

      本文标题:切片

      本文链接:https://www.haomeiwen.com/subject/ihgqoltx.html