免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5819 | 回复: 1
打印 上一主题 下一主题

关于非线性曲线拟合的问题 [复制链接]

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
1 [报告]
发表于 2015-04-15 05:00 |显示全部楼层
本帖最后由 rubyish 于 2015-04-15 01:04 编辑

a hard way ~
f(x) = (17.800935828877)*x**2 + (7.19552718360075)*x

  1. #!/usr/bin/perl

  2. # queke:
  3. # gnuplot> f(x) = (17.800935828877)*x**2 + (7.19552718360075)*x
  4. # gnuplot> plot 'data' with points ps 3 pt 7, f(x) lw 5

  5. use 5.016;
  6. my ( $M, $Y );

  7. while (<DATA>) {
  8.     my ( $x, $y ) = split;
  9.     push @$Y, [$y];
  10.     push @$M, [ $x, $x * $x ];
  11. }

  12. sub gimme {
  13.     my ( $M, $Y ) = @_;
  14.     my $TM = T($M);
  15.     my @A = map $_->[0], @{ M( I( M( $TM, $M ) ), M( $TM, $Y ) ) };
  16.     "f(x) = ($A[1])*x**2 + ($A[0])*x";
  17. }

  18. my $fx = gimme $M, $Y;
  19. say $fx;

  20. sub T {
  21.     my $m = shift;
  22.     my @M = map {
  23.         my $i = $_;
  24.         [ map { $m->[$_][$i] } 0 .. $#$m ]
  25.     } 0 .. $#{ $m->[0] };
  26.     [@M];
  27. }

  28. sub M {
  29.     my ( $A, $B ) = @_;
  30.     my @M = map {
  31.         my $i = $_;
  32.         my @S = map {
  33.             my ( $j, $S ) = $_;
  34.             $S += $A->[$i][$_] * $B->[$_][$j] for 0 .. $#{$B};
  35.             $S;
  36.         } 0 .. $#{ $B->[0] };
  37.         [@S]
  38.     } 0 .. $#{$A};
  39.     [@M];
  40. }

  41. sub I {
  42.     my @m = @{ +shift };
  43.     for my $i ( 0 .. $#m ) {
  44.         my $it = 1.0 / $m[$i][$i];
  45.         $m[$i][$i] = $it;
  46.         for my $j ( 0 .. $#m ) {
  47.             next if $j == $i;
  48.             $m[$i][$j] *= -$it;
  49.             $m[$j][$i] *= $it;
  50.         }
  51.         for my $j ( 0 .. $#m ) {
  52.             next if $j == $i;
  53.             for my $k ( 0 .. $#m ) {
  54.                 next if $k == $i;
  55.                 $m[$j][$k] += $m[$j][$i] * $m[$i][$k] / $it;
  56.             }
  57.         }
  58.     }
  59.     [@m];
  60. }



  61. __DATA__
  62. 0       0
  63. 0.05    0.5487
  64. 0.1     1.0967
  65. 0.15    1.6447
  66. 0.2     2.1937
  67. 0.25    2.7417
  68. 0.3     3.5587
  69. 0.35    4.6387
  70. 0.4     5.7407
  71. 0.45    6.9717
复制代码

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
2 [报告]
发表于 2015-04-18 03:45 |显示全部楼层
回复 11# minirain


    my $a1 = shift;
    my @m  = @{$a1};
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP