【问题标题】:python linspace in c++C ++中的python linspace
【发布时间】:2015-01-17 15:26:00
【问题描述】:

我正在尝试编写类似版本的 python numpy.linspace 函数。

double linspace(int a, int b, int c){
    double line[c];
    double delta =b-a/(c-1);
    for (int i=0; i<c; ++i){
            line[i]=0 + (i*delta);
    }
    return line;

其中 a 和 b 是数组中的第一个和最后一个组件,而 c 指定数组中元素的数量。但是当我编译这个脚本时它返回:

linspace.cpp: In function ‘double linspace(int, int, int)’:
linspace.cpp:11:9: error: cannot convert ‘double*’ to ‘double’ in return
  return line;
         ^

有没有人知道如何解决这个问题?

【问题讨论】:

  • 另外,b-a/(c-1)(你的意思是(b-a)/(c-1)?)是整数除法。
  • This question 可能感兴趣。总结了一堆模仿c++中numpy的库。

标签: python c++ numpy


【解决方案1】:

这样的事情怎么样:

#include <iostream>
#include <vector>

template<typename T>
std::vector<double> linspace(T start_in, T end_in, int num_in)
{

  std::vector<double> linspaced;

  double start = static_cast<double>(start_in);
  double end = static_cast<double>(end_in);
  double num = static_cast<double>(num_in);

  if (num == 0) { return linspaced; }
  if (num == 1) 
    {
      linspaced.push_back(start);
      return linspaced;
    }

  double delta = (end - start) / (num - 1);

  for(int i=0; i < num-1; ++i)
    {
      linspaced.push_back(start + delta * i);
    }
  linspaced.push_back(end); // I want to ensure that start and end
                            // are exactly the same as the input
  return linspaced;
}

void print_vector(std::vector<double> vec)
{
  std::cout << "size: " << vec.size() << std::endl;
  for (double d : vec)
    std::cout << d << " ";
  std::cout << std::endl;
}

int main()
{
  std::vector<double> vec_1 = linspace(1, 10, 3);
  print_vector(vec_1);

  std::vector<double> vec_2 = linspace(6.0, 23.4, 5);
  print_vector(vec_2);

  std::vector<double> vec_3 = linspace(0.0, 2.0, 1);
  print_vector(vec_3);

  std::vector<double> vec_4 = linspace(0.0, 2.0, 0);
  print_vector(vec_4);


  return 0;
}

C++ 结果:

size: 3
1 5.5 10 
size: 5
6 10.35 14.7 19.05 23.4 
size: 1
0 
size: 0

Numpy 结果:

In [14]: np.linspace(1, 10, 3)
Out[14]: array([  1. ,   5.5,  10. ])

In [15]: np.linspace(6, 23.4, 5)
Out[15]: array([  6.  ,  10.35,  14.7 ,  19.05,  23.4 ])

In [16]: np.linspace(0.0, 2.0, 1)
Out[16]: array([ 0.])

In [17]: np.linspace(0.0, 2.0, 0)
Out[17]: array([], dtype=float64)

【讨论】:

  • 你的模板对我来说失败了,我逐字复制了它,并且得到了一个超出范围的向量错误。
  • @arc_lupus。感谢您指出这一点!我相信我修好了。我像这样编译它并且它工作正常:g++ -std=c++11 my_file.cpp -o my_exec.
  • 我不得不删除 'linspaced.push_back(end);'命令,因为它使“end_in”出现两次。
  • @PedroH.N.Vieira,感谢您指出这一点。我会看看它。您是否有示例输入,以便我可以重现该问题?
  • 它出现在我调用'linspace(-1.0, 1.0, 21)'时出现
【解决方案2】:

您正在尝试做的事情是行不通的。首先,您在linspace 内分配堆栈上的内存

double line[c];

你要么在调用前先分配内存并将其传入,要么动态分配并返回它(记得稍后释放它)。

要动态分配,您可以执行以下操作:

double * line = new double[c];

同样,当您完成它时,需要在稍后的某个时间将其释放,否则您将出现内存泄漏。

delete line[];

double line[c]; 创建一个双精度数组,line 指向它。所以线是double *。您将函数的返回类型指定为double

【讨论】:

  • 举个例子?如果您将double line[c]; 更改为'double * line = new double[c];` 并更改您完成的函数的返回类型。每当您处理完数据时,都需要删除从该函数返回的任何内容。所以... double * lin_ret = linspace(a,b,c); 在你完成 lin_ret 之后再做 delete lin_ret[];
  • 哈! asker 请求示例!真有钱。
  • 你真的应该为此使用矢量而不是赤裸裸的new
猜你喜欢
  • 2021-03-03
  • 2015-08-01
  • 2015-06-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-01-05
  • 2013-05-29
相关资源
最近更新 更多