当前位置: 首页>>代码示例>>C++>>正文


C++ tensor_type::at方法代码示例

本文整理汇总了C++中tensor_type::at方法的典型用法代码示例。如果您正苦于以下问题:C++ tensor_type::at方法的具体用法?C++ tensor_type::at怎么用?C++ tensor_type::at使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在tensor_type的用法示例。


在下文中一共展示了tensor_type::at方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: operator

  void operator ()(const tensor_type &x, tensor_type &y) {
    // y = F ∗ x + b
    for (auto i = 0; i < y.shape().at(0); ++i) {
      for (auto j = 0; j < y.shape().at(1); ++j) {
        for (auto s = 0; s < filter_.shape().at(0); ++s) {
          for (auto t = 0; t < filter_.shape().at(1); ++t) {
            for (auto u = 0; u < y.shape().at(2); ++u) {
              F output_value = F(1) * y.at({i, j, u});
              for (auto v = 0; v < filter_.shape().at(3); ++v) {
                output_value += F(1) * filter_.at({s, t, u, v}) * x.at({i + s, j + t, v});
              }
              y.set({i, j, u}, output_value);
            }
          }
        }
      }
    }

    for (auto i = 0; i < y.shape().at(0); ++i) {
      for (auto j = 0; j < y.shape().at(1); ++j) {
        for (auto k = 0; k < y.shape().at(2); ++k) {
          y.set({i, j, k}, F(1) * y.at({i, j, k}) + F(1) * bias_.at({k}));
        }
      }
    }
  }
开发者ID:robertsdionne,项目名称:sacred,代码行数:26,代码来源:convolution.hpp

示例2: operator

 void operator ()(const tensor_type &delta, const tensor_type &x, tensor_type &x_gradient) {
   CHECK_EQ(x.order(), delta.order());
   // TODO(robertsdionne): Support arbitrary tensor order with an n-dimensional iterator.
   for (auto i = 0; i < x.shape().at(0); ++i) {
     for (auto j = 0; j < x.shape().at(1); ++j) {
       x_gradient.set({i, j}, delta.at({i, j}) * (x.at({i, j}) > F(0)));
     }
   }
 }
开发者ID:robertsdionne,项目名称:sacred,代码行数:9,代码来源:rectified_linear_gradient.hpp

示例3: fill_from_file

void fill_from_file(tensor_type& tens, const std::string& str)
{
   std::ifstream ifs(str);
   for(int k = 0 ; k < tens.extent<2>(); ++k)
      for(int j = 0 ; j < tens.extent<1>(); ++j)
         for(int i = 0 ; i < tens.extent<0>(); ++i)
      {
         ifs >> tens.at(i,j,k);
      }
}
开发者ID:IanHG,项目名称:tensor_code_generator.spirit,代码行数:10,代码来源:main_libmda.cpp

示例4: operator

 void operator ()(const tensor_type &x, tensor_type &y) {
   using std::max;
   CHECK_EQ(x.order(), y.order());
   // TODO(robertsdionne): Support arbitrary tensor order with an n-dimensional iterator.
   for (auto i = 0; i < x.shape().at(0); ++i) {
     for (auto j = 0; j < x.shape().at(1); ++j) {
       y.set({i, j}, max(F(0), x.at({i, j})));
     }
   }
 }
开发者ID:robertsdionne,项目名称:sacred,代码行数:10,代码来源:rectified_linear.hpp

示例5: print

void print(const tensor_type& tens, const std::string& str)
{
   std::ofstream of(str);
   of << std::showpos;
   using limit_type = std::numeric_limits<typename tensor_type::value_type>;
   of << std::scientific;
   of << std::setprecision(limit_type::max_digits10);
   for(int k = 0 ; k < tens.extent<2>(); ++k)
      for(int j = 0 ; j < tens.extent<1>(); ++j)
         for(int i = 0 ; i < tens.extent<0>(); ++i)
      {
         of << tens.at(i,j,k) << std::endl;
      }
}
开发者ID:IanHG,项目名称:tensor_code_generator.spirit,代码行数:14,代码来源:main_libmda.cpp


注:本文中的tensor_type::at方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。