0

我在 Contiki 3.0 中使用 RPL,我需要在结果为浮动的情况下进行一些计算。但不是给我浮点数的结果,而是只计算整数,例如:5/2 = 2.0 而不是 2.5。我怎样才能得到正确的答案?我无法在 Contiki 3.0 中打印浮点数或双精度数,因此我使用此代码将浮点数转换为字符串:

    // Reverses a string 'str' of length 'len'
    void reverse(char* str, int len)
    {
        int i = 0, j = len - 1, temp;
        while (i < j) {
            temp = str[i];
            str[i] = str[j];
            str[j] = temp;
            i++;
            j--;
        }
    }

  
// Converts a given integer x to string str[]. 
// d is the number of digits required in the output. 
// If d is more than the number of digits in x, 
// then 0s are added at the beginning.
int intToStr(int x, char str[], int d)
{
    int i = 0;
    while (x) {
        str[i++] = (x % 10) + '0';
        x = x / 10;
    }
  
    // If number of digits required is more, then
    // add 0s at the beginning
    while (i < d)
        str[i++] = '0';
  
    reverse(str, i);
    str[i] = '\0';
    return i;
}
  
// Converts a floating-point/double number to a string.
void ftoa(float n, char* res, int afterpoint)
{
    // Extract integer part
    int ipart = (int)n;
  
    // Extract floating part
    float fpart = n - (float)ipart;
  
    // convert integer part to string
    int i = intToStr(ipart, res, 0);
  
    // check for display option after point
    if (afterpoint != 0) {
        res[i] = '.'; // add dot
  
        // Get the value of fraction part upto given no.
        // of points after dot. The third parameter 
        // is needed to handle cases like 233.007
        fpart = fpart * powf(10, afterpoint);
  
        intToStr((int)fpart, res + i + 1, afterpoint);
    }
}
  

感谢您的帮助谢谢 Hanin

4

3 回答 3

0

我还想在cooja中打印浮点值,所以我找到了这个解决方案。

// digits before point
unsigned short d1(float f){
    return((unsigned short)f);
}

// digits after point
unsigned short d2(float f){
    return(1000*(f-d1(f)));
}

int main()
{
  float max = 6.796; 
  printf("max value %u.%u \n", d1(max) , d2(max));
}
于 2021-06-16T08:05:53.240 回答
0

因为 5/2 是整数除法的一种形式,所以你输入的就是输出,也就是说,如果你输入 5/2,你只会得到一个整数,形式为 2。

要解决此问题,请将您的 5/2 设为 5/2.0,以便将其作为浮点数读入,这将确保您得到的答案是浮点小数。

于 2021-03-30T13:50:30.470 回答
0

如果要将数字打印为浮点数,只需将浮点之前的部分打印为整数,打印点,然后将浮点之后的部分乘以 10 的幂,然后将其打印为另一个整数。例如,如果要在浮点后打印 6 位数字,请将小数部分乘以 1000000。

您将需要一个单独的缓冲区来首先打印浮点之后的部分 - 第一个数字必须非零,因此可以安全地选择用另一个数字填充数字,例如“1”,您不打印。为此,只需在乘以之前将 1.0 添加到小数部分。

这是完整的代码:

float f = 5.0 / 2;
char fractional_part[10];
sprintf(fractional_part, "%d", (int)((f - (int)f + 1.0) * 1000000));
printf("%d.%s\n", (int)f, &fractional_part[1]); // prints "2.500000"
于 2021-03-30T14:40:16.453 回答