source code
<? /* The Computer Language Benchmarks Game
https://salsa.debian.org/benchmarksgame-team/benchmarksgame/
Naive transliteration from Sebastien Loisel's C program
contributed by Isaac Gouy
*/
function eval_A($i, $j) { return 1.0/(($i+ $j)*($i+$j+1)/2+$i+1); }
function eval_A_times_u($N, $u, &$Au)
{
$i = $j = 0;
for($i=0;$i<$N;$i++)
{
$Au[$i]=0;
for($j=0;$j<$N;$j++) $Au[$i]+=eval_A($i,$j)*$u[$j];
}
}
function eval_At_times_u($N, $u, &$Au)
{
$i = $j = 0;
for($i=0;$i<$N;$i++)
{
$Au[$i]=0;
for($j=0;$j<$N;$j++) $Au[$i]+=eval_A($j,$i)*$u[$j];
}
}
function eval_AtA_times_u($N, $u, &$AtAu)
{
$v = array_fill(0, $N, 0.0);
eval_A_times_u($N,$u,$v); eval_At_times_u($N,$v,$AtAu);
}
function main($N)
{
$u = array_fill(0, $N, 1.0);
$v = array_fill(0, $N, 0.0);
for($i=0;$i<10;$i++)
{
eval_AtA_times_u($N,$u,$v);
eval_AtA_times_u($N,$v,$u);
}
$vBv = $vv = 0.0;
for($i=0;$i<$N;$i++) { $vBv+=$u[$i]*$v[$i]; $vv+=$v[$i]*$v[$i]; }
printf("%0.9f\n",sqrt($vBv/$vv));
}
$reps = $argc > 1 ? 12 : 1;
for($r=0;$r<$reps;$r++) {
$n = $argc > 1 ? $argv[1] : 100;
main($n);
}
?>
notes, command-line, and program output
NOTES:
64-bit Ubuntu quad core
PHP 8.4.1 (cli)
(built: Nov 22 2024 14:22:47) (NTS)
Copyright (c) The PHP Group
Zend Engine v4.4.1,
with Zend OPcache v8.4.1,
Copyright (c) Zend Technologies
Sun, 22 Dec 2024 20:20:27 GMT
COMMAND LINE:
/opt/src/php-8.4.1/bin/php -dzend_extension=/opt/src/php-8.4.1/lib/php/extensions/no-debug-non-zts-20240924/opcache.so -dopcache.enable_cli=1 -dopcache.jit_buffer_size=64M -n spectralnorma.php-8.php 5500
PROGRAM OUTPUT:
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153