2013-12-15 52 views
-2

采用值的NaN我有这个类上的图像序列的像素的工作原理双后0/0

private int makeRSR(int x, int y) 
    { 
     double bRed = 0;double bGreen = 0; double bBlue = 0; 
     for(int k: sequence.keySet()) 
     { 
     BufferedImage img = sequence.get(k); 
     for(int i=0; i<iteration; i++){ 
      for(int j=0;j<spray_int; j++){ 
       int dist= ((int)(dis_int*Math.random())); 
       double theta=((int)(361*Math.random())) ; 
       double inc_x=dist * Math.cos((theta*(Math.PI/180))); 
       double inc_y=dist * Math.sin((theta*(Math.PI/180))); 
       int row=Math.abs((int)(inc_y+y)); 
       int column=Math.abs((int)(inc_x+x)); 
       if(row<1 || column<1 || row>altI-1 || column>largI-1){ 
        row=Math.abs((int) ((altI-1)*Math.random())); 
        column=Math.abs((int) ((largI-1)*Math.random())); 
       } 
       Color c = new Color(img.getRGB(column,row)); 
       red.add(c.getRed()); 
       green.add(c.getGreen()); 
       blue.add(c.getBlue()); 
      } 
      Color c = new Color(img.getRGB(x,y)); 
      red.add(c.getRed()); 
      green.add(c.getGreen()); 
      blue.add(c.getBlue()); 

      double maxR=max(red); 
      double maxG=max(green); 
      double maxB=max(blue); 

      bRed += ((((double)c.getRed())/(maxR))*255.00); 
      bGreen += ((((double)c.getGreen())/(maxG))*255.00); 
      bBlue += ((((double)c.getBlue())/(maxB))*255.00); 

      red.clear();green.clear();blue.clear(); 
     } 
    } 

    redValue=0;greenValue=0;blueValue=0; 
    redValue= (int) (bRed/(iteration*(sequence.size()))); 
    greenValue= (int) (bGreen/(iteration*(sequence.size()))); 
    blueValue=(int) (bBlue/(iteration*(sequence.size()))); 

    bRed=0.0;bGreen=0.0;bBlue=0.0; 

    return new Color(redValue,greenValue,blueValue).getRGB(); 
} 

的问题是,有时c.getRed()和MAXR都为0(对于相同其他渠道),所以bRed失去其内容并且看重NaN,而且它永远不会改变。是否有错误,我错过了,还是必须通过添加检查来防止0/0? 谢谢,再见

+2

一个简单的方法来避免它来决定你想要发生什么,并产生一个避免这种情况的等式。例如'bRed + = 255.0 * c.getRed()/(maxR + 1e-3);' –

+0

@PeterLawrey使用'if',然而,更清洁,恕我直言更简单。 –

+0

@ Anony-Mousse'if'或'maxR == 0? 0.0:......'可以更清楚,尤其是如果你想要的行为不容易适合方程式。 –

回答

2

由于0/0是一个未定义的数字,您需要决定如何处理它。

  1. 找出为什么你在当前和最大红色值都得到0并防止它。师0的
  2. 结果集(或任意数量的你决定要获得期望的结果),如果两个c.getRed()maxR为0
1

因为被零除是一个错误,它会导致NaN,代表不是数字。涉及NaN的后续操作也将导致NaN,这就是为什么它的价值从未改变之后。

你应该明确检查零分之前的分工,以防止零除。

相关问题