Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/GAP/hpcgap/demo/   (Algebra von RWTH Aachen Version 4.15.1©)  Datei vom 18.9.2025 mit Größe 2 kB image not shown  

Quelle  parlist.g   Sprache: unbekannt

 
#
# Workers communicate
#
#


    

ParList1 := function(l, f, n)
    local   inch,  outch,  worker,  threads,  count,  res,  i,  x,  t;
    inch := CreateChannel();
    outch := CreateChannel();
    worker := function()
        local   x;
        while true do
            x := ReceiveChannel(inch);
            # x should be mine now since it has come through the channel
            # x[1] is always a public object
            if x[1] = fail then
                return;
            fi;
            atomic readonly x[2] do    
                x[2] := f(x[2]);    
            od;
            SendChannel(outch, x);
        od;
    end;
    threads := List([1..n], i->CreateThread(worker));
    count := 0;
    res := [];
    for i in [1..Length(l)] do
        ShareObj(l[i]);
        atomic readonly l[i] do
            SendChannel(inch, [i,l[i]]);
        od;
        while true do
            x := TryReceiveChannel(outch,fail);
            if x = fail then
                break;
            fi;
            res[x[1]] := x[2];
            count := count+1;
        od;
    od;
    for i in [1..n] do
        SendChannel(inch, [fail]);
    od;
    while count < Length(l) do
        x := ReceiveChannel(outch);
        if x = fail then
            break;
        fi;
        res[x[1]] := x[2];
        count := count+1;
    od;
    for t in threads do
        WaitThread(t);
    od;
    DestroyChannel(inch);
    DestroyChannel(outch);
    return res;
end;

ParList3 := function(l, f)
    local   tasks,  tix,  results,  t;

    tasks := List(l, x-> RunTask(f,x));
    tix := [1..Length(tasks)];
    results := [];
    while tasks <> [] do
        t :=  WaitAnyTask(tasks);
        Print(tix[t]," completed\n");
        results[tix[t]] := TaskResult(tasks[t]);
        Remove(tix,t);
        Remove(tasks,t);
    od;
    return results;
end;

ParList2 := function(l, f, n)
    local   inch,  worker,  threads,  res,  i,  t;
    inch := CreateChannel();
    worker := function()
        local   x;
        while true do
            x := ReceiveChannel(inch);
            if x = fail then
                    return;
            fi;
            res[x] := f(res[x]);    
        od;
    end;    
    threads := List([1..n], i->CreateThread(worker));
    res := AtomicList(l);
    for i in [1..Length(l)] do
        SendChannel(inch, i);
    od;
    for i in [1..n] do
        SendChannel(inch, fail);
    od;
    for t in threads do
        WaitThread(t);
    od;
    DestroyChannel(inch);
    return FromAtomicList(res);
end;

BlockedParlist:= function(ParListFun, blocking)
    return function(l,f,n)
        local   len,  blocks,  i,  j;
        len := Length(l);
        blocks := [];
        i := 1;
        j := i+blocking-1;
        while j <= len do
            Add(blocks, l{[i..j]});
            i := i+blocking;
            j := j+blocking;
        od;
        if i <= len then
            Add(blocks,l{[i..len]});
        fi;
        return Concatenation(ParListFun(blocks, block -> List(block, f), n));
    end;
end;
            


[ Dauer der Verarbeitung: 0.9 Sekunden  (vorverarbeitet)  ]