I want to convert my code from C++ to C#. The C++ contains pointer, and I want to convert it to C#.
Here is the C++ code:
void callkernel(int *obsx,int *obsy,int *obsz,int no,int nx,int *x,
int *y,int *z,int dx,int dy,int dz,double **k)
{
double dxd2 = dx/2;
double dyd2 = dy/2;
double dzd2 = dz/2;
for (int q=0; q < nx;q++)
{
double xb = x[q]-dxd2; double xa = x[q]+dxd2;
double yb = y[q]-dyd2; double ya = y[q]+dyd2;
double zb = z[q]-dzd2; double za = z[q]+dzd2;
for (int m = 0; m<no; m++)
{
double kernel = mk(obsx[m],obsy[m],obsz[m],xb,yb,zb,xa,ya,za);
k[m][q] = kernel;
}
}
}
Then It will called by:
callkernel(obsx,obsy,obsz,no,nx,x,y,z,dx,dy,dz,k);
here is my code in C#:
void callkernel(int[] obsx, int[] obsy, int[] obsz, int no, int nx, int[] x,
int[] y, int[] z, int dx, int dy, int dz, ref double[][] k)
{
double dxd2 = dx / 2;
double dyd2 = dy / 2;
double dzd2 = dz / 2;
for (int q = 0; q < nx; q++)
{
double xb = x[q] - dxd2; double xa = x[q] + dxd2;
double yb = y[q] - dyd2; double ya = y[q] + dyd2;
double zb = z[q] - dzd2; double za = z[q] + dzd2;
for (int m = 0; m < no; m++)
{
double kernel = mk(obsx[m], obsy[m], obsz[m], xb, yb, zb, xa, ya, za);
k[m][q] = kernel;
}
}
}
It called by:
callkernel(obsx, obsy, obsz, no, nx, x, y, z, dx, dy, dz, ref k);
They are small part of a big code in my program. With the code that I did, it seems have different result. Can anyone let me know where is my mistake?