Как вывести приближенные дробные числа из иррационального числа на MatLab? - PullRequest
0 голосов
/ 26 марта 2012

У меня есть неуклюжий код PHP, который я использовал для получения приблизительных чисел дроби для иррациональных чисел, таких как пи, фи, квадратный корень из 2, 3 и так далее. Я хотел бы получить формулу, которую я могу использовать в MatLab, получить таблицу данных и нарисовать график, основанный на приблизительных числах дробей. Может быть, кто-то уже может воспользоваться этим, но я предоставлю код PHP для дополнения кейса:

$n = phi(); # irrational number (imaginary/complex number?)
$x = 500; # how many numbers to check
$max = 50; # how many instances to show
$precision = 0.0001;

# check every i against every j and make a comparison how near their values are to each other
for ($i=1; $i<$x; $i++) {
    for ($j=1; $j<$x; $j++) {
        # compared value is stored on array. very distant numbers needs to be discarded ($precision) or array gets easily too big, limit 64k
        if (($d = abs(($n - ($i/$j)))) && $d > $precision) continue;
        $c[] = array($i, $j, $d);
    }
}

# sort comparison chart by third index (2)
array_qsort($c, 2);

# print max best values from the sorted comparison chart
$count = count($c);
echo "closest fraction numbers for $n from $count calculated values are:<br />\n<br />\n";
$r = 0;
foreach ($c as $abc) {
    $r++;
    $d = $abc[0]/$abc[1];
    echo $abc[0] . '/' . $abc[1] . ' = ' . $d . ' (' . round($abc[2]*(1/$precision), 10) . ')' . "<br />\n";
    if ($r > $max) break;
}

Ответы [ 2 ]

1 голос
/ 26 марта 2012

Есть более эффективные алгоритмы, вот один:

function [a, b, c] = approxfrac( r, precision )
a = floor(r);
r = r - a;
if r==0,
    b=0;
    c=1;
    return
end
p1 = 0; q1 = 1;
p2 = 1; q2 = 1;
b = p1+p2;
c = q1+q2;
while abs(r-b/c) > precision,
    if r>b/c,
        p1 = b; q1 = c;
    else
        p2 = b; q2 = c;
    end
    b = p1+p2;
    c = q1+q2;
end
end
0 голосов
/ 27 марта 2012

Для этого есть функция: крыса

...