Multi-thread grades generation
This commit is contained in:
parent
8ddca7c49a
commit
2e5b2af4d8
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
use v5.10.1;
|
use v5.10.1;
|
||||||
use strict;
|
use strict;
|
||||||
|
use threads;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Carp;
|
use Carp;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
@ -98,7 +99,38 @@ sub grades_generate
|
|||||||
my @trace_dirs = grep { ( ! /^\./ ) && -d "$basedir/$year/$project_id/traces/$_" } readdir($dh);
|
my @trace_dirs = grep { ( ! /^\./ ) && -d "$basedir/$year/$project_id/traces/$_" } readdir($dh);
|
||||||
closedir $dh;
|
closedir $dh;
|
||||||
|
|
||||||
for my $login (@logins)
|
my @ths;
|
||||||
|
my $max_ths = 4;
|
||||||
|
my $login_by_threads = @logins / $max_ths;
|
||||||
|
|
||||||
|
for (my $i = 0; $i < $max_ths; $i++)
|
||||||
|
{
|
||||||
|
my @partlogin = @logins[($i*$login_by_threads) .. (($i+1)*$login_by_threads - 1)];
|
||||||
|
push @ths, threads->create(\&do_grade_generation, $grading, $year, $project_id, $groups, \@trace_dirs, @partlogin);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($login_by_threads * $max_ths < @logins)
|
||||||
|
{
|
||||||
|
my @partlogin = @logins[$login_by_threads * $max_ths .. $#logins];
|
||||||
|
push @ths, threads->create(\&do_grade_generation, $grading, $year, $project_id, $groups, \@trace_dirs, @partlogin);
|
||||||
|
}
|
||||||
|
|
||||||
|
for my $th (@ths) {
|
||||||
|
$th->join();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub do_grade_generation
|
||||||
|
{
|
||||||
|
my $grading = shift;
|
||||||
|
my $year = shift;
|
||||||
|
my $project_id = shift;
|
||||||
|
my $groups = shift;
|
||||||
|
my @trace_dirs = @{ shift() };
|
||||||
|
|
||||||
|
for my $login (@_)
|
||||||
{
|
{
|
||||||
my @files;
|
my @files;
|
||||||
|
|
||||||
@ -157,8 +189,6 @@ sub grades_generate
|
|||||||
|
|
||||||
$grading->reset();
|
$grading->reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub grades_new_bonus
|
sub grades_new_bonus
|
||||||
|
Reference in New Issue
Block a user