我正在随机填充一个网格,其中笛卡尔坐标从 0 归一化到 100(100x100x100 网格),其中每个数据点的“强度”从 0 归一化到 256。这是我在 perl 中的代码的摘录:
open(FILE,$file);
while(sysread(FILE,$data,16)) {
@row=unpack("f>4",$data); # input file is binary so I had to convert here
$x=int((($row[0] - $xmin)/($xmax - $xmin)*10) + 0.5); # max and min variables
$y=int((($row[1] - $ymin)/($ymax - $ymin)*10) + 0.5); # are previously defined
$z=int((($row[2] - $zmin)/($zmax - $zmin)*10) + 0.5);
$i=int(($row[3]/62*256) + 0.5);
$i=255 if ($i>255);
$out[$x][$y][$z]=$i; # simply assigns an intensity for each data
# point (in random order), only 1 point can be
# added to each 1x1x1 cell
}
有些点靠得太近,被放置在同一个 1x1x1 单元格中。发生这种情况时,添加的每个强度都会覆盖前一个强度。如何计算一个单元格中放置多个点的次数?
提前致谢!