当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 3 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 如何零误差保存浮点数
帖子发表于 : 2013-05-11 10:45 
头像

注册: 2012-03-17 11:05
帖子: 138
送出感谢: 3
接收感谢: 0 次
是这样的,我做数值计算;一个程序输出了一堆数,想在另一个程序使用,就这一步我想让数据原来是什么样的被读进去还是什么样的,怎么弄?
ps:fprintf保存数据会有截断误差 :em06


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 如何零误差保存浮点数
帖子发表于 : 2013-05-11 13:15 
头像

注册: 2006-03-14 10:25
帖子: 644
送出感谢: 1
接收感谢: 4
代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(int argc, char** argv) {
    double old_value = 3.1415926535897932;
    printf("%f\n", old_value);
   
    int size = sizeof(old_value);
    printf("%d\n", size);

    //save the value to char array, which can be saved to disk
    char *ptr = malloc(size);
    memcpy(ptr, &old_value, size);
   
    int i;
    for (i = 0; i < size; i++) {
        printf("%d\n", *(ptr + i));
    }

    //use the char array to recover the value
    double new_value;
    memcpy(&new_value, ptr, size);
    printf("%f\n", new_value);
   
    //check
    if (old_value == new_value) {
        printf("%s\n", "good");
    } else {
        printf("%s\n", "囗囗囗囗");
    }
   
    return (EXIT_SUCCESS);
}


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 如何零误差保存浮点数
帖子发表于 : 2013-05-11 17:31 
头像

注册: 2010-04-23 20:40
帖子: 1950
地址: 浙江·杭州
系统: Arch Linux
送出感谢: 2
接收感谢: 31
fwrite 直接写出不就好了?
[c]
float numbers[...];
// ...
FILE * fp = fopen("output_file", "w");
fwrite(numbers, sizeof(numbers), 1, fp);
fclose(fp);
[/c]


_________________
我是 Giumo Clanjor(哆啦比猫/兰威举)
Where there is a hacker, there is art. | Develop for Developers. (C & perl5)
博客 | Clanjor Prods.
类 C 语言到 brainfuck 编译器



_________________
评价: 3.7% billcalendar
 
页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 3 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 3 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译