rodeo has asked for the wisdom of the Perl Monks concerning the following question:
my $maxProc=4; my $pm = new Parallel::ForkManager($maxProc); for(my $idy=0;$idy<=$#ySurf;$idy++) { my $currY = $ySurf[$idy]; for(my $alfaIdx=0;$alfaIdx<=$#alfas;$alfaIdx++) { $pm->start and next; my $alfa = $alfas[$alfaIdx]; my $norVectX = cos($alfa); my $norVectY = 0; my $norVectZ = sin($alfa); my $norTransf=TransfNorVec($input->{az}, $input->{el}, $norVec +tX, $norVectY, $norVectZ, $Side); my $intSurfx = $input->{MiddleX} - $input->{r}*$norVectX; my $intSurfy = $currY; my $intSurfz = ($input->{MiddleZ}+$input->{zOffset})-$input->{ +r}*$norVectZ; my $center = Divide($input->{w}, $input->{h}, $input->{M}, $in +put->{N}, $intSurfx, $intSurfy, $intSurfz, $alfa); my $surf=0; for(my $idx=0;$idx<$center->{count};$idx++) { my $xT = $center->{Px}[$idx]; my $yT = $center->{Py}[$idx]; my $zT = $center->{Pz}[$idx]; my $xTr = coordSystTransf($input->{az}, $input->{el}, $inp +ut->{MiddleX}, $input->{MiddleY}, $input->{MiddleZ}, $input->{ZeroX}, + $input->{ZeroY}, $input->{ZeroZ}, $xT, $yT, $zT, $Side); my $sqDiag = ($input->{w}/$input->{M})**2+($input->{h}/$in +put->{N})**2; my $P = new Points(); $P->{count}=0; for(my $dataIdx=0;$dataIdx<$data->{count};$dataIdx++) { my $inSphere = Check($sqDiag, $xTr->{xe}, $xTr->{ye}, +$xTr->{ze}, $data->{abs_x}[$dataIdx], $data->{abs_y}[$dataIdx], $data +->{abs_z}[$dataIdx]); if($inSphere == 1) { $P->{Px}[$P->{count}]=($data->{magX}[$dataIdx])*co +s($data->{phX}[$dataIdx]); $P->{Py}[$P->{count}]=($data->{magY}[$dataIdx])*co +s($data->{phY}[$dataIdx]); $P->{Pz}[$P->{count}]=($data->{magZ}[$dataIdx])*co +s($data->{phZ}[$dataIdx]); $P->{count}++; } } my $Poynt = new Trans(); if(defined($P->{Px}[0]) && defined($P->{Py}[0]) && defined +($P->{Pz}[0])) { $Poynt->{xe} = summe($P->{Px})/$P->{count}; $Poynt->{ye} = summe($P->{Py})/$P->{count}; $Poynt->{ze} = summe($P->{Pz})/$P->{count}; my $innerProd = $Poynt->{xe}*$norTransf->{xe}+$Poynt-> +{ye}*$norTransf->{ye}+$Poynt->{ze}*$norTransf->{ze}; $surf += ((($input->{w})/$input->{M})*(($input->{h})/$ +input->{N}))*$innerProd; } } print "\ny= ".$currY."; alfa= ".$alfa .";\n"; if($surf == 0) { print 1e-100 ."dB\n"; }else{ print sprintf("%.4f", 20*log(abs($surf))) ." dB\n"; } $pm->finish; } $pm->wait_all_children; }
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: Sharing statics variable between Threads
by roboticus (Chancellor) on Aug 30, 2013 at 11:54 UTC | |
|
Re: Sharing statics variable between Threads
by BrowserUk (Patriarch) on Aug 30, 2013 at 11:06 UTC | |
|
Re: Sharing statics variable between Threads
by BrowserUk (Patriarch) on Aug 30, 2013 at 13:32 UTC | |
by rodeo (Initiate) on Sep 02, 2013 at 08:05 UTC | |
by BrowserUk (Patriarch) on Sep 02, 2013 at 10:14 UTC | |
by rodeo (Initiate) on Sep 02, 2013 at 11:37 UTC | |
by BrowserUk (Patriarch) on Sep 02, 2013 at 11:59 UTC | |
by BrowserUk (Patriarch) on Sep 02, 2013 at 08:22 UTC | |
|
Re: Sharing statics variable between Threads
by BrowserUk (Patriarch) on Aug 30, 2013 at 12:30 UTC |