c++模板杂计

一 杂计

1.1 基础代码

template<typename T>
T add(T a, T b) 
{
    return a + b;
}

template int add<>(int, int); // 显式实例化

int main()
{
    add<int>(1, 2); // 显式指定模板参数 T
    add(1, 2); // 自动推导模板参数 T
    add(1.0f, 2.0f); // 自动推导并且隐式实例化
}

模板是本质上是代码生成器 

1.2 参数中有函数

template <typename T, void (*OpFunc)(T *, T *, T *, T *, int, int, float)>
__mlu_func__ void block3Unary(T *x, T *y, char *nram_buffer, int32_t num_total,
                              int32_t offset_x_half, int32_t offset_aux_a,
                              int32_t offset_aux_b, int32_t num_deal,
                              int32_t num_pong, float coef) {
  if (__is_mpu()) {
    return;
  }
  int32_t num_per_core = num_total / taskDim;
  int32_t num_rem = num_total % taskDim;
  T *addr_x = (T *)x + taskId * num_per_core;
  T *addr_y = (T *)y + taskId * num_per_core;
  if (num_rem > 0 && taskId == taskDim - 1) {
    num_per_core = num_per_core + num_rem;
  }
  int32_t repeat = num_per_core / num_deal;
  int32_t rem = num_per_core % num_deal;
  int32_t align_rem = CEIL_ALIGN(rem, UNARY_ALIGN_NUM);

  T *nram_x = (T *)nram_buffer;
  T *nram_x_half = (T *)nram_buffer + offset_x_half;
  T *nram_aux_a = (T *)nram_buffer + offset_aux_a;
  T *nram_aux_b = (T *)nram_buffer + offset_aux_b;
  int32_t span_handle_size = num_deal * sizeof(T);

  // 3 level pipeline.
  if (repeat > 0) {
    __memcpy_async(nram_x_half, addr_x, span_handle_size, GDRAM2NRAM);
    __sync();
  }

  if (repeat > 1) {
    __memcpy_async(nram_x_half + num_pong, addr_x + num_deal, span_handle_size,
                   GDRAM2NRAM);
    OpFunc(nram_x, nram_x_half, nram_aux_a, nram_aux_b, num_deal, num_deal,
           coef);
    __sync();
  }

在使用的模板时候,需要传入类型参数,和函数的类型

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

youzjuer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值