eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingOpenMP do zliczania węzłów drzewaRe: OpenMP do zliczania węzłów drzewa
  • Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!not
    -for-mail
    From: Michoo <m...@v...pl>
    Newsgroups: pl.comp.programming
    Subject: Re: OpenMP do zliczania węzłów drzewa
    Date: Mon, 15 Nov 2010 18:15:12 +0100
    Organization: http://onet.pl
    Lines: 51
    Message-ID: <ibrpqv$33s$1@news.onet.pl>
    References: <9...@z...googlegroups.com>
    NNTP-Posting-Host: smaug.int.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: news.onet.pl 1289841311 3196 83.238.197.12 (15 Nov 2010 17:15:11 GMT)
    X-Complaints-To: n...@o...pl
    NNTP-Posting-Date: Mon, 15 Nov 2010 17:15:11 +0000 (UTC)
    User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.1.12) Gecko/20100913
    Icedove/3.0.7
    In-Reply-To: <9...@z...googlegroups.com>
    Xref: news-archive.icm.edu.pl pl.comp.programming:187334
    [ ukryj nagłówki ]

    W dniu 15.11.2010 17:50, Mariusz Marszałkowski pisze:
    > Witam
    >
    > Jest sobie rekurencyjna procedura która zlicza węzły drzewa:
    >
    > int zliczaj( Object *obj , depht ) {
    > if( depht == 0 )
    > return 1;
    > sum = 1;
    > for( int i=0 ; i<ilosc_potomkow( obj ) ; i++ ) {
    > wykonaj_instrukcje( obj );
    > sum += zliczaj( obj , depth-1 );
    > cofnij_instrukcje( obj );
    > }
    > return sum;
    > }
    >
    > Na platformach wieloprocesorowych aż się prosi żeby zrobić po prostu
    > tak:
    >
    > int zliczaj( Object *obj , depht ) {
    > if( depht == 0 )
    > return 1;
    > sum = 1;
    > #pragma omp parallel for private(obj) reduction(+:sum)
    > for( int i=0 ; i<ilosc_potomkow( obj ) ; i++ ) {
    > wykonaj_instrukcje( obj );
    > sum += zliczaj( obj , depth-1 );
    > cofnij_instrukcje( obj );
    > }
    > return sum;
    > }
    >
    > Ale nie działa, kompilator wywala że zmienna obj jest użyta bez
    > zainicjowania, a
    > program się zawiesza. Co robię źle?
    Mieszanie rekurencji i wielowątkowości - czy to jest dowcip?

    jeżeli nie to:
    masz prywatny wskaźnik do obiektu, obiekt jest współdzielony, wykonujesz
    wykonaj_instrukcje i cofnij_instrukcje na nim równolegle.
    Chcesz prawdopodobnie zrobić coś w stylu:
    Object job = *obj;
    i dopiero job potraktować jako private. Albo zapłacić komuś za zrobienie
    tego dobrze.



    --
    Pozdrawiam
    Michoo

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: