- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我读过一些关于 valgrind 的帖子,但我仍然无法自己弄清楚。
所以我有一个原本可以正常工作的 C 脚本。我后来用一些新的输入修改了它,然后我在我的主要 for 循环之一中遇到了段错误。
我实际上通过一些 printf 函数找到了错误,并且我做了一些实验来找出导致错误的确切行。但我发现的位置中的这些行都与段错误无关。我还仔细检查了我的 malloc 函数和指针,即使它们在原始版本中工作。
然后我读了一些关于 valgrind 的帖子,这是我得到的:
==21733== Invalid write of size 4
==21733== at 0x4014A4: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0x11c27208 is 0 bytes after a block of size
209,584,584 alloc'd
==21733== at 0x4C27A2E: malloc (vg_replace_malloc.c:270)
==21733== by 0x402954: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733==
==21733== Invalid write of size 4
==21733== at 0x4014E9: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0x1e408208 is 0 bytes after a block of size
209,584,584 alloc'd
==21733== at 0x4C27A2E: malloc (vg_replace_malloc.c:270)
==21733== by 0x40297F: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733==
==21733== Invalid write of size 4
==21733== at 0x40152E: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0x2abe9208 is 0 bytes after a block of size
209,584,584 alloc'd
==21733== at 0x4C27A2E: malloc (vg_replace_malloc.c:270)
==21733== by 0x4029AA: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733==
==21733== Invalid write of size 4
==21733== at 0x401573: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0x373ca208 is 0 bytes after a block of size
209,584,584 alloc'd
==21733== at 0x4C27A2E: malloc (vg_replace_malloc.c:270)
==21733== by 0x4029D5: h_spin_shellwriter (in /mnt/scratch-lus
tre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733==
test0 test1 test2 test3 test4
4475
test0 test1 test2 test3 test4
4476
==21733== Invalid read of size 4
==21733== at 0x400A30: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0xffffffff34cc3cdc is not stack'd, malloc'd or (r
ecently) free'd
==21733==
==21733==
==21733== Process terminating with default action of signal 11
(SIGSEGV)
==21733== Access not within mapped region at address
0xFFFFFFFF34CC3CDC
==21733== at 0x400A30: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== If you believe this happened as a result of a stack
==21733== overflow in your program's main thread (unlikely but
==21733== possible), you can try to increase the size of the
==21733== main thread stack using the --main-stacksize= flag.
==21733== The main thread stack size used in this run was 10485760.
==21733== Invalid read of size 4
==21733== at 0x5126D7F: _IO_flush_all_lockp (in /lib64/libc-2.12.so)
==21733== by 0x5127C5E: _IO_cleanup (in /lib64/libc-2.12.so)
==21733== by 0x51F3E62: __libc_freeres (in /lib64/libc-2.12.so)
==21733== by 0x4A2266D: _vgnU_freeres (vg_preloaded.c:62)
==21733== by 0x7FEFFF0C7: ???
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0xc2c80000c2c800c0 is not stack'd, malloc'd or
(recently) free'd
==21733==
==21733==
==21733== Process terminating with default action of signal 11 (SIGSEGV)
==21733== General Protection Fault
==21733== at 0x5126D7F: _IO_flush_all_lockp (in /lib64/libc-2.12.so)
==21733== by 0x5127C5E: _IO_cleanup (in /lib64/libc-2.12.so)
==21733== by 0x51F3E62: __libc_freeres (in /lib64/libc-2.12.so)
==21733== by 0x4A2266D: _vgnU_freeres (vg_preloaded.c:62)
==21733== by 0x7FEFFF0C7: ???
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733==
==21733== HEAP SUMMARY:
==21733== in use at exit: 16,767,087,832 bytes in 30 blocks
==21733== total heap usage: 30 allocs, 0 frees, 16,767,087,832 bytes
allocated
==21733==
==21733== LEAK SUMMARY:
==21733== definitely lost: 0 bytes in 0 blocks
==21733== indirectly lost: 0 bytes in 0 blocks
==21733== possibly lost: 0 bytes in 0 blocks
==21733== still reachable: 16,767,087,832 bytes in 30 blocks
==21733== suppressed: 0 bytes in 0 blocks
==21733== Rerun with --leak-check=full to see details of leaked memory
==21733==
==21733== For counts of detected and suppressed errors, rerun with: -v
==21733== ERROR SUMMARY: 218519 errors from 6 contexts (suppressed: 6
from 6)
谢谢!
感谢您的建议,现在我在下面上传我的代码。这段代码的作用是读取我的 python 代码处理的一些模拟数据。我拥有的是一个尺寸为(512,512,512)的模拟盒子。里面有一种叫做光环和形态(比如SFS)的东西。光环有自旋,形态有涡度,我想知道光环周围的壳,自旋和涡度之间的余弦是多少。另外,我想知道光环自旋的余弦和振幅之间的关系。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#define ArrayAccess2D_n2(a, n1, n2, i1, i2) (a)[ i2+n2*i1 ]
#define ArrayAccess3D_n3(a, n1, n2, n3, i, j, k) ((a)[ ((n2)*(i)+(j))*(n3)+(k) ])
#define ArrayAccess4D_n4(a, n1, n2, n3, n4, i1, i2, i3, i4) ((a)[ i4+n4*(i3+n3*(i2+n2*i1)) ])
#define ArrayAccess5D_n5(a, n1, n2, n3, n4, n5, i1, i2, i3, i4, i5) ((a)[ i5+n5*(i4+n4*(i3+n3*(i2+n2*i1))) ])
#define dotproduct(x1, y1, z1, x2, y2, z2) (x1*x2 + y1*y2 + z1*z2)
//cos between vec (x1, y1, z1) and (x2, y2, z2)
//if there is zero vector, set impossible value -100
float veccos(float x1, float y1, float z1, float x2, float y2, float z2)
{
float cos, dot1, dot2;
dot1 = dotproduct(x1, y1, z1, x1, y1, z1);
dot2 = dotproduct(x2, y2, z2, x2, y2, z2);
if(dot1!=0 && dot2!=0){
cos = dotproduct(x1, y1, z1, x2, y2, z2)/(sqrt(dot1)*sqrt(dot2));
}
else{
cos = -100;
}
return cos;
}
//omega in py is (4,3,ng,ng,ng) array with padding, in order sfs, sfc, ufs, ufc
//halo_spin shape (3,ng,ng,ng) with padding
//halo_g of (3, halo_num), halo_R of (halo_num,) in unit of grids
void h_spin_vor_amp(float *halo_spinlist, int *halo_spinamp, int *halo_g, float *halo_R, float *omega, int halo_start, int halo_end, int halo_num, int ng, float Lbox, int lowbound_fac, int bound_fac, int padding, int ngp, float *out_sfs, float *out_sfc, float *out_ufs, float *out_ufc)
{
long long iter=0;
int g_x, g_y, g_z, g_R; //coordinator on grids
int halo_x1, halo_x2, halo_y1, halo_y2, halo_z1, halo_z2;
int ext_x1, ext_x2, ext_y1, ext_y2, ext_z1, ext_z2;
float phy_R, h_sx, h_sy, h_sz;
int i, j;
//temporary array, recording cos of each type
float *cos_sfst, *cos_sfct, *cos_ufst, *cos_ufct;
cos_sfst = (float *) malloc(ngp*ngp*ngp*sizeof(float));
cos_sfct = (float *) malloc(ngp*ngp*ngp*sizeof(float));
cos_ufst = (float *) malloc(ngp*ngp*ngp*sizeof(float));
cos_ufct = (float *) malloc(ngp*ngp*ngp*sizeof(float));
for(long j=halo_start; j<halo_end; j++){
printf("%d\n", j);
int i;
i=halo_spinamp[j];
printf("test0 ");
g_x = ArrayAccess2D_n2(halo_g, 3, halo_num, 0, i);
g_y = ArrayAccess2D_n2(halo_g, 3, halo_num, 1, i);
g_z = ArrayAccess2D_n2(halo_g, 3, halo_num, 2, i);
phy_R = halo_R[i];
g_R = phy_R*ng/(1000*Lbox);
if( (phy_R*ng/(1000*Lbox) - g_R) > 0.5){
g_R += 1;
}
halo_x1 = g_x - lowbound_fac*g_R; //boundary of halo edges
halo_x2 = g_x + lowbound_fac*g_R;
halo_y1 = g_y - lowbound_fac*g_R; //e.g. y1 < y2
halo_y2 = g_y + lowbound_fac*g_R;
halo_z1 = g_z - lowbound_fac*g_R;
halo_z2 = g_z + lowbound_fac*g_R;
ext_x1 = g_x - bound_fac*g_R; //boundary of extended edges
ext_x2 = g_x + bound_fac*g_R;
ext_y1 = g_y - bound_fac*g_R;
ext_y2 = g_y + bound_fac*g_R;
ext_z1 = g_z - bound_fac*g_R;
ext_z2 = g_z + bound_fac*g_R;
printf("test1 ");
//compute cos of all in boundary
for(long x=ext_x1+padding-1; x<ext_x2+padding; x++){
for(long y=ext_y1+padding-1; y<ext_y2+padding; y++){
for(long z=ext_z1+padding-1; z<ext_z2+padding; z++){
h_sx = ArrayAccess2D_n2(halo_spinlist, 3, halo_num, 0, i);
h_sy = ArrayAccess2D_n2(halo_spinlist, 3, halo_num, 1, i);
h_sz = ArrayAccess2D_n2(halo_spinlist, 3, halo_num, 2, i);
cos_sfst[(ngp*x + y)*ngp + z] = veccos(ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 0, 0, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 0, 1, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 0, 2, x,y,z), h_sx, h_sy, h_sz);
cos_sfct[(ngp*x + y)*ngp + z] = veccos(ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 1, 0, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 1, 1, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 1, 2, x,y,z), h_sx, h_sy, h_sz);
cos_ufst[(ngp*x + y)*ngp + z] = veccos(ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 2, 0, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 2, 1, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 2, 2, x,y,z), h_sx, h_sy, h_sz);
cos_ufct[(ngp*x + y)*ngp + z] = veccos(ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 3, 0, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 3, 1, x,y,z), ArrayAccess5D_n5(omega, 4, 3, ngp, ngp, ngp, 3, 2, x,y,z), h_sx, h_sy, h_sz);
}
}
}
printf("test2 ");
//set all cos in halo to invalid identifier -100
for(int x=halo_x1+padding-1; x<halo_x2+padding; x++){
for(int y=halo_y1+padding-1; y<halo_y2+padding; y++){
for(int z=halo_z1+padding-1; z<halo_z2+padding; z++){
cos_sfst[(ngp*x + y)*ngp + z] = -100;
cos_sfct[(ngp*x + y)*ngp + z] = -100;
cos_ufst[(ngp*x + y)*ngp + z] = -100;
cos_ufct[(ngp*x + y)*ngp + z] = -100;
}
}
}
printf("test3 ");
//recording cos
for(int x=ext_x1+padding-1; x<ext_x2+padding; x++){
for(int y=ext_y1+padding-1; y<ext_y2+padding; y++){
for(int z=ext_z1+padding-1; z<ext_z2+padding; z++){
out_sfs[iter] = cos_sfst[(ngp*x + y)*ngp + z];
out_sfc[iter] = cos_sfct[(ngp*x + y)*ngp + z];
out_ufs[iter] = cos_ufst[(ngp*x + y)*ngp + z];
out_ufc[iter] = cos_ufct[(ngp*x + y)*ngp + z];
cos_sfst[(ngp*x + y)*ngp + z] = 0;
cos_sfct[(ngp*x + y)*ngp + z] = 0;
cos_ufst[(ngp*x + y)*ngp + z] = 0;
cos_ufct[(ngp*x + y)*ngp + z] = 0;
iter++;
}
}
}
printf("test4 \n");
}
printf("iterate upto %lli \n", iter);
}
void h_spin_shellwriter(float Lbox, int ng, long ngp, char *sim_num, char *sm_name, int halo_num, int *bins, int lowbound_fac, int upbound_fac, int padding){
//get shell
char shell[10], shell1[10];
sprintf(shell1, "_r%dto%d", lowbound_fac, upbound_fac);
sprintf(shell, "_r%dto%d", lowbound_fac, upbound_fac);
//sprintf(shell, "_c%dto%d_b1n2", lowbound_fac, upbound_fac);
printf("for shell%s\n", shell);
printf("initializing memory space\n");
//file name, routes
char in_halo_s[100], in_halo_g[100], in_halo_R[100], in_omega[100], in_halo_amp[100];
sprintf(in_halo_s, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_sls%s.dat", shell1, sim_num, sm_name); //fixedrad
//sprintf(in_halo_s, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_s%s.dat", shell, sim_num, sm_name);
sprintf(in_halo_g, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_g%s.dat", shell1, sim_num, sm_name);
sprintf(in_halo_R, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_R%s.dat", shell1, sim_num, sm_name);
sprintf(in_omega, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_omega%s.dat", shell1, sim_num, sm_name);
sprintf(in_halo_amp, "../gadgetsim/halo_spinout/100Mpc/pyout%s/gadg_u%s_halo_ampsort%s.dat", shell1, sim_num, sm_name);
char out_sfsb1[100], out_sfcb1[100], out_ufsb1[100], out_ufcb1[100];
sprintf(out_sfsb1, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfsb1_%s.dat", shell, sim_num, sm_name);
sprintf(out_sfcb1, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfcb1_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufsb1, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufsb1_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufcb1, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufcb1_%s.dat", shell, sim_num, sm_name);
char out_sfsb2[100], out_sfcb2[100], out_ufsb2[100], out_ufcb2[100];
sprintf(out_sfsb2, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfsb2_%s.dat", shell, sim_num, sm_name);
sprintf(out_sfcb2, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfcb2_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufsb2, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufsb2_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufcb2, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufcb2_%s.dat", shell, sim_num, sm_name);
char out_sfsb3[100], out_sfcb3[100], out_ufsb3[100], out_ufcb3[100];
sprintf(out_sfsb3, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfsb3_%s.dat", shell, sim_num, sm_name);
sprintf(out_sfcb3, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfcb3_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufsb3, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufsb3_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufcb3, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufcb3_%s.dat", shell, sim_num, sm_name);
char out_sfsb4[100], out_sfcb4[100], out_ufsb4[100], out_ufcb4[100];
sprintf(out_sfsb4, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfsb4_%s.dat", shell, sim_num, sm_name);
sprintf(out_sfcb4, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cossfcb4_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufsb4, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufsb4_%s.dat", shell, sim_num, sm_name);
sprintf(out_ufcb4, "../gadgetsim/halo_spinout/100Mpc/ampbin%s/gadg_u%s_halo_cosufcb4_%s.dat", shell, sim_num, sm_name);
//array for recording
float *cos_sfsb1, *cos_sfcb1, *cos_ufsb1, *cos_ufcb1;
float *cos_sfsb2, *cos_sfcb2, *cos_ufsb2, *cos_ufcb2;
float *cos_sfsb3, *cos_sfcb3, *cos_ufsb3, *cos_ufcb3;
float *cos_sfsb4, *cos_sfcb4, *cos_ufsb4, *cos_ufcb4;
cos_sfsb1 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfcb1 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufsb1 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufcb1 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfsb2 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfcb2 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufsb2 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufcb2 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfsb3 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfcb3 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufsb3 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufcb3 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfsb4 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_sfcb4 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufsb4 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
cos_ufcb4 = (float *) malloc(ngp*ngp*ngp*sizeof(float)/4);
//initialize outputs
for(int i=0; i<ngp*ngp*ngp/4; i++){
cos_sfsb1[i] = -100;
cos_sfcb1[i] = -100;
cos_ufsb1[i] = -100;
cos_ufcb1[i] = -100;
cos_sfsb2[i] = -100;
cos_sfcb2[i] = -100;
cos_ufsb2[i] = -100;
cos_ufcb2[i] = -100;
cos_sfsb3[i] = -100;
cos_sfcb3[i] = -100;
cos_ufsb3[i] = -100;
cos_ufcb3[i] = -100;
cos_sfsb4[i] = -100;
cos_sfcb4[i] = -100;
cos_ufsb4[i] = -100;
cos_ufcb4[i] = -100;
}
printf("reading halo data\n");
float *halo_s, *halo_R;
int *halo_g, *halo_amp;
halo_s = (float *) malloc(3*halo_num*sizeof(float));
//halo_s = (float *) malloc(3*ngp*ngp*ngp * sizeof(float));
halo_g = (int *) malloc(3*halo_num*sizeof(int));
halo_R = (float *) malloc(halo_num * sizeof(float));
halo_amp = (int *) malloc(halo_num*sizeof(int));
float *omega;
omega = (float *) malloc(4*3*ngp*ngp*ngp * sizeof(float));
FILE *F_halo_s, *F_halo_g, *F_halo_R, *F_halo_amp;
FILE *F_omega;
F_halo_s = fopen(in_halo_s, "rb");
F_halo_g = fopen(in_halo_g, "rb");
F_halo_R = fopen(in_halo_R, "rb");
F_halo_amp = fopen(in_halo_amp, "rb");
F_omega = fopen(in_omega, "rb");
fread(halo_s, sizeof(float), 3*halo_num, F_halo_s);
//fread(halo_s, sizeof(float), 3*ngp*ngp*ngp, F_halo_s);
fread(halo_g, sizeof(int), 3*halo_num, F_halo_g);
fread(halo_R, sizeof(float), halo_num, F_halo_R);
fread(halo_amp, sizeof(int), halo_num, F_halo_amp);
fread(omega, sizeof(float), 4*3*ngp*ngp*ngp, F_omega);
printf("computing cosine...\n");
//get physical radius mean
float phy_R_mean=0;
int g_R_mean=0;
/*
for(int i=0; i<bins[1]; i++){
phy_R_mean = phy_R_mean + halo_R[i]; }
phy_R_mean = phy_R_mean/bins[1];
printf("%d, %f\n", bins[1], phy_R_mean);
//get mean radius in grid
g_R_mean = phy_R_mean*ng/(1000*Lbox);
if((phy_R_mean*ng/(1000*Lbox) - g_R_mean) > 0.5){
g_R_mean += 1; }
printf("mean of radius in grids: %f\n", g_R_mean);
*/
/*
h_spin_vor_fixedrad(halo_s, halo_g, g_R_mean, omega, 0, bins[0], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb1, cos_sfcb1, cos_ufsb1, cos_ufcb1);
h_spin_vor_fixedrad(halo_s, halo_g, g_R_mean, omega, bins[0], bins[1], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb2, cos_sfcb2, cos_ufsb2, cos_ufcb2);
*/
h_spin_vor_amp(halo_s, halo_amp, halo_g, halo_R, omega, 0, bins[0], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb1, cos_sfcb1, cos_ufsb1, cos_ufcb1);
h_spin_vor_amp(halo_s, halo_amp, halo_g, halo_R, omega, bins[0], bins[1], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb2, cos_sfcb2, cos_ufsb2, cos_ufcb2);
h_spin_vor_amp(halo_s, halo_amp, halo_g, halo_R, omega, bins[1], bins[2], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb3, cos_sfcb3, cos_ufsb3, cos_ufcb3);
h_spin_vor_amp(halo_s, halo_amp, halo_g, halo_R, omega, bins[2], bins[3], halo_num, ng, Lbox, lowbound_fac, upbound_fac, padding, ngp, cos_sfsb4, cos_sfcb4, cos_ufsb4, cos_ufcb4);
printf("computation done\n");
free(halo_s);
free(halo_g);
free(halo_R);
free(halo_amp);
free(omega);
printf("writing out the final data...\n");
FILE *F_out_sfsb1, *F_out_sfcb1, *F_out_ufsb1, *F_out_ufcb1;
FILE *F_out_sfsb2, *F_out_sfcb2, *F_out_ufsb2, *F_out_ufcb2;
FILE *F_out_sfsb3, *F_out_sfcb3, *F_out_ufsb3, *F_out_ufcb3;
FILE *F_out_sfsb4, *F_out_sfcb4, *F_out_ufsb4, *F_out_ufcb4;
F_out_sfsb1 = fopen(out_sfsb1, "wb");
F_out_sfcb1 = fopen(out_sfcb1, "wb");
F_out_ufsb1 = fopen(out_ufsb1, "wb");
F_out_ufcb1 = fopen(out_ufcb1, "wb");
fwrite(cos_sfsb1, sizeof(float), ngp*ngp*ngp/4, F_out_sfsb1);
fwrite(cos_sfcb1, sizeof(float), ngp*ngp*ngp/4, F_out_sfcb1);
fwrite(cos_ufsb1, sizeof(float), ngp*ngp*ngp/4, F_out_ufsb1);
fwrite(cos_ufcb1, sizeof(float), ngp*ngp*ngp/4, F_out_ufcb1);
//free(cos_sfsb1), free(cos_sfcb1), free(cos_ufsb1), free(cos_ufcb1);
F_out_sfsb2 = fopen(out_sfsb2, "wb");
F_out_sfcb2 = fopen(out_sfcb2, "wb");
F_out_ufsb2 = fopen(out_ufsb2, "wb");
F_out_ufcb2 = fopen(out_ufcb2, "wb");
fwrite(cos_sfsb2, sizeof(float), ngp*ngp*ngp/4, F_out_sfsb2);
fwrite(cos_sfcb2, sizeof(float), ngp*ngp*ngp/4, F_out_sfcb2);
fwrite(cos_ufsb2, sizeof(float), ngp*ngp*ngp/4, F_out_ufsb2);
fwrite(cos_ufcb2, sizeof(float), ngp*ngp*ngp/4, F_out_ufcb2);
//free(cos_sfsb2), free(cos_sfcb2), free(cos_ufsb2), free(cos_ufcb2);
/*
F_out_sfsb3 = fopen(out_sfsb3, "wb");
F_out_sfcb3 = fopen(out_sfcb3, "wb");
F_out_ufsb3 = fopen(out_ufsb3, "wb");
F_out_ufcb3 = fopen(out_ufcb3, "wb");
fwrite(cos_sfsb3, sizeof(float), ngp*ngp*ngp/4, F_out_sfsb3);
fwrite(cos_sfcb3, sizeof(float), ngp*ngp*ngp/4, F_out_sfcb3);
fwrite(cos_ufsb3, sizeof(float), ngp*ngp*ngp/4, F_out_ufsb3);
fwrite(cos_ufcb3, sizeof(float), ngp*ngp*ngp/4, F_out_ufcb3);
//free(cos_sfsb3), free(cos_sfcb3), free(cos_ufsb3), free(cos_ufcb3);
F_out_sfsb4 = fopen(out_sfsb4, "wb");
F_out_sfcb4 = fopen(out_sfcb4, "wb");
F_out_ufsb4 = fopen(out_ufsb4, "wb");
F_out_ufcb4 = fopen(out_ufcb4, "wb");
fwrite(cos_sfsb4, sizeof(float), ngp*ngp*ngp/4, F_out_sfsb4);
fwrite(cos_sfcb4, sizeof(float), ngp*ngp*ngp/4, F_out_sfcb4);
fwrite(cos_ufsb4, sizeof(float), ngp*ngp*ngp/4, F_out_ufsb4);
fwrite(cos_ufcb4, sizeof(float), ngp*ngp*ngp/4, F_out_ufcb4);
//free(cos_sfsb4), free(cos_sfcb4), free(cos_ufsb4), free(cos_ufcb4);
*/
}
int main()
{
//basic info of the set of simulations
float Lbox=100;
int ng=512;
int u0_halo_num=9946, u1_halo_num=9897, u2_halo_num=10380;
int u3_halo_num=9801, u4_halo_num=10062, u5_halo_num=10170;
int u6_halo_num=10028, u7_halo_num=10244, u8_halo_num=9925;
int u9_halo_num=10329, u10_halo_num=10168;
int bins[4];
int u0_bins[] = {8766, 9860, 9942, 9946}; //[ 0. 0.1 0.2 0.3 0.4 ]
int u1_bins[] = {8770, 9812, 9892, 9897};
int u2_bins[] = {9270, 10282, 10371, 10380};
int u3_bins[] = {8645, 9720, 9799, 9801};
int u4_bins[] = {8862, 9966, 10061, 10062};
int u5_bins[] = {9023, 10074, 10164, 10170};
int u6_bins[] = {8884, 9924, 10021, 10027};
int u7_bins[] = {9119, 10156, 10236, 10244};
int u8_bins[] = {8849, 9848, 9923, 9925};
int u9_bins[] = {9213, 10240, 10321, 10329};
int u10_bins[] = {8984, 10073, 10159, 10168};
int lowbound_fac, bound_fac, padding0, padding1, padding2;
int padding3, padding4, padding5, padding6, padding7, padding8;
int padding9, padding10;
long ngp;
/*====================================*/
//control section
/*===============*/
//smoothing scale choice
char sm_name[] = "02";
//choose simulations
char sim_num[] = "0";
int sim_intnum = 0;
int halo_num = u0_halo_num;
for(int i=0; i<4; i++){
bins[i] = u0_bins[i]; //change simulation number here too
}
printf("computing for u%s\n\n", sim_num);
/*============================*/
//compute for different shells
lowbound_fac=3, bound_fac=5, padding0=41, padding1=45, padding2=47;
padding3=54, padding4=49, padding5=35, padding6=37, padding7=47, padding8=48, padding9=47, padding10=51;
int padding_r3to5[] = {padding0, padding1, padding2, padding3, padding4, padding5,
padding6, padding7, padding8, padding9, padding10};
ngp=ng+2*padding_r3to5[sim_intnum];
h_spin_shellwriter(Lbox, ng, ngp, sim_num, sm_name, halo_num, bins, lowbound_fac, bound_fac, padding_r3to5[sim_intnum]);
lowbound_fac=2, bound_fac=3, padding0=25, padding1=27, padding2=29;
padding3=33, padding4=30, padding5=21, padding6=23, padding7=29, padding8=29, padding9=29, padding10=31;
int padding_r2to3[] = {padding0, padding1, padding2, padding3, padding4, padding5,
padding6, padding7, padding8, padding9, padding10};
ngp=ng+2*padding_r2to3[sim_intnum];
h_spin_shellwriter(Lbox, ng, ngp, sim_num, sm_name, halo_num, bins, lowbound_fac, bound_fac, padding_r2to3[sim_intnum]);
lowbound_fac=1, bound_fac=2, padding0=17, padding1=18, padding2=19;
padding3=22, padding4=20, padding5=15, padding6=15, padding7=20, padding8=20, padding9=19, padding10=21;
int padding_r1to2[] = {padding0, padding1, padding2, padding3, padding4, padding5,
padding6, padding7, padding8, padding9, padding10};
ngp=ng+2*padding_r1to2[sim_intnum];
h_spin_shellwriter(Lbox, ng, ngp, sim_num, sm_name, halo_num, bins, lowbound_fac, bound_fac, padding_r1to2[sim_intnum]);
}
最佳答案
如果没有发布任何源代码,很难准确地帮助您,但是如果您在理解 valgrind 输出时遇到问题,可以这样解释:
您遇到了许多错误,每个错误都采用以下形式:
==21733== Invalid write of size 4
==21733== at 0x4014A4: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0x11c27208 is 0 bytes after a block of size
209,584,584 alloc'd
==21733== at 0x4C27A2E: malloc (vg_replace_malloc.c:270)
==21733== by 0x402954: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
这意味着以下内容:
h_spin_shellwriter
中的 malloc 分配了一些内存 (~200MB)。h_spin_vor_amp
中执行代码时:
block 后 0 字节...
)最有可能发生的情况是,您正在迭代分配的内存中的所有值,并且走得太远了。或者您可能想在某个数组的末尾添加一些内容,但没有检查是否还有剩余空间。没有任何代码,这是最有可能的猜测。
但是,这可能是许多其他问题 - 意外覆盖某些指针、永久增加指针而不是使用临时指针,或者只是进行了错误的偏移计算也可能是原因。
不同的错误:
==21733== Invalid read of size 4
==21733== at 0x400A30: h_spin_vor_amp (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403104: h_spin_shellwriter (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== by 0x403A2C: main (in /mnt/scratch-
lustre/joexu/workplace/myC/halo_samp)
==21733== Address 0xffffffff34cc3cdc is not stack'd, malloc'd or (r
ecently) free'd
表示您可能不小心保存了指向后来被释放的某些内存的指针,或者您在地址计算中犯了错误。
奇怪的是,您没有在堆栈跟踪中获得精确的行信息。如果编译时没有启用调试信息,则应该启用它们。否则,也许删除优化会给你更好的答案。
关于c - 使用 valgrind 调试 c,大小 4 的写入/读取无效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45115567/
我希望 valgrind 在发现第一个错误时停止并退出。 请勿推荐 --vgdb-error=1 :它不会退出 valgrind。您必须连接 gdb 并从那里终止。 --db-attach : 在最近
有人可以快速解释 Valgrind 的工作原理吗?一个例子:它如何知道内存何时被分配和释放? 最佳答案 Valgrind 基本上在“沙箱”中运行您的应用程序。在此沙箱中运行时,它能够插入自己的指令来进
我有一个因 SIGSEGV 而崩溃的应用程序。 --20183-- VALGRIND INTERNAL ERROR: Valgrind received a signal 11 (SIGSEGV) -
我有一个因 SIGSEGV 而崩溃的应用程序。 --20183-- VALGRIND INTERNAL ERROR: Valgrind received a signal 11 (SIGSEGV) -
我想使用 valgrind 检查长时间运行的进程是否存在内存泄漏。我怀疑我所追求的内存泄漏可能仅在执行几个小时后才会发生。我可以在 valgrind 下运行应用程序并获取 valgrind 日志,但这
我想用 valgrind 检查一个长时间运行的进程是否有内存泄漏。我怀疑我所追求的内存泄漏可能仅在执行数小时后才会发生。我可以在 valgrind 下运行应用程序并获得 valgrind 日志,但这样
如何在不通过 valgrind 命令选项启动它的情况下对每个 Process 实例执行 valgrind memcheck。 有没有办法将监控选项保存在进程中,而不是每次都使用 valgrind 命令
我使用了“--trace-children=yes”选项,我还使用了“--trace-children-skip=patt1,patt2,...”选项(过滤掉噪音过程)。但它对我来说仍然很慢,我的多进
我从 Valgrind 得到以下日志: MPK ==5263== 4 bytes in 1 blocks are still reachable in loss record 1 of 84 ==52
如何在 Valgrind 抑制文件中添加注释? 我需要为一个大型项目维护一个 Valgrind 抑制文件。我们从我们链接到的工具中过滤无法修复的错误。随着工具的新版本发布,此文件可能需要随着时间的推移
我有一个大程序要运行。使用 valgrind 需要几个小时才能运行。我听说有一些东西可以让我们为程序中的特定函数调用 valgrind。其余程序将正常执行(没有 valgrind env)。 任何人都
我可以用 valgrind 检测整数溢出缺陷吗?里面的哪个工具可以做到这一点? 最佳答案 Valgrind 没有可以检测整数溢出的工具。 您可能会使用 gcc 选项捕获这些错误: -ftrapv Th
我有一个简单的程序: int main(void) { const char sname[]="xxx"; sem_t *pSemaphor; if ((pSemaphor = sem_o
如何让 Valgrind 准确显示错误发生的位置?我编译了我的程序(通过 PuTTy 在 Windows 机器上通过 Linux 终端)添加了 -g 调试选项。 当我运行 Valgrind 时,我得到
或者最好是全部,而不仅仅是我的代码?我的程序使用 Gtk、Loudmouth 和其他一些东西,而这两个(以及它们背后的一些,libgcrypto、libssl)本身导致了如此多的错误,以至于我无法检测
我想尝试使用 valgrind 进行一些堆损坏检测。通过以下腐败“单元测试”: #include #include #include int main() { char * c = (ch
我看过类似的问题here ,但我的问题是我没有编辑 default.supp 文件的权限。例如,Valgrind 中是否有任何忽略所有抑制文件的命令行选项? 最佳答案 在 Valgrind 3.10.
我在一个运行无限循环的程序上使用 valgrind。 由于memcheck在程序结束后显示内存泄漏,但由于我的程序有无限循环,它永远不会结束。 那么有什么方法可以强制从 valgrind 时不时地转储
我一直在尝试使用 valgrind 查找一些可疑的内存错误。 在被分析的程序甚至到达我希望分析的点之前,它会因为对 mmap 的调用开始失败而退出。当它不在 valgrind 下时,这些调用会成功。
由于 OpenSSL 使用未初始化的内存,因此对使用 openldap2 的 libldap 的程序进行 Valgrind 是一件苦差事。存在一个 --ignore-fn选项,但仅适用于 Valgri
我是一名优秀的程序员,十分优秀!