ALGORYTMY WYZNACZANIA ŚCIEŻKI KRYTYCZNEJ I ZAPASÓW CZASU W SIECIACH JEDNOPUNKTOWYCH O ROZSZERZONYCH TYPACH RELACJI MIEDZY ZADANIAMI

Podobne dokumenty
Katedra Geoinżynierii SGGW w Warszawie Department of Geotechnical Engineering WULS SGGW

STOSOWANIE ROZSZERZONYCH TYPÓW RELACJI W HARMONOGRAMACH PRZEDSIĘWZIĘĆ BUDOWLANYCH

Zarządzanie projektami

Każde zadanie (ang. task) ma wyróżnione dwa stany:

Zarządzanie projektami. Wykład 3 dr inż. Agata Klaus-Rosińska

WPŁYW BUDOWY SIECI ZALEŻNOŚCI NA PRZEBIEG ŚCIEŻKI KRYTYCZNEJ I WYNIKI AKTUALIZACJI HARMONOGRAMU SIECIOWEGO

1 Obliczanie modeli sieciowych w funkcji środków

PROGRAMOWANIE SIECIOWE. METODA ŚCIEŻKI KRYTYCZNEJ

t i L i T i

WPŁYW TYPU ROZKŁADU CZASU TRWANIA CZYNNOŚCI NA WYNIKI ANALIZY RYZYKA W PLANOWANIU REALIZACJI PRZEDSIĘWZIĘĆ

PRACE ORYGINALNE. Wprowadzenie. Mieczysław POŁOŃSKI

BADANIA OPERACYJNE. dr Adam Sojda Pokój A405

Planowanie przedsięwzięć

PROBLEM Z IDENTYFIKACJĄ ŁAŃCUCHA KRYTYCZNEGO I LOKALIZACJĄ BUFORÓW ZASILAJĄCYCH W HARMONOGRAMIE SIECIOWYM Z OGRANICZONĄ DOSTĘPNOŚCIĄ ZASOBU

Metoda CPM/PERT. dr inż. Mariusz Makuchowski

Lokalizacja buforów czasu w metodzie łańcucha krytycznego w harmonogramach robót budowlanych (cz. II) praktyczne zastosowanie

ZARZĄDZANIE PROJEKTAMI METODA ŚCIEŻKI KRYTYCZNEJ HARMONOGRAM PROJEKTU

Zarządzanie projektami. Zarządzanie czasem w projekcie

Zapasy czasowe czynności

Przykład: budowa placu zabaw (metoda ścieżki krytycznej)

Harmonogramowanie przedsięwzięć

EKONOMIKA I ORGANIZACJA BUDOWY

Harmonogramowanie robót budowlanych z wykorzystaniem metody CCPM Construction schedule using CCPM method

Podstawy zarządzania projektem. dr inż. Agata Klaus-Rosińska

Zarządzanie projektami. mgr inż. Michał Adamczak

ZARZĄDZANIE PROJEKTEM NA PRZYKŁADZIE PRZEDSIĘWZIĘCIA ODLEWNICZEGO

Rys Wykres kosztów skrócenia pojedynczej czynności. k 2. Δk 2. k 1 pp. Δk 1 T M T B T A

METODA PERT. Maciej Patan. Instytut Sterowania i Systemów Informatycznych Uniwersytet Zielonogórski

OPROGRAMOWANIE WSPOMAGAJĄCE ZARZĄDZANIE PROJEKTAMI. PLANOWANIE ZADAŃ I HARMONOGRAMÓW. WYKRESY GANTTA

PLANOWANIE I KONTROLA REALIZACJI OBIEKTU BUDOWLANEGO

PROGRAMOWANIE SIECIOWE. METODY CPM i PERT

Zasady sporządzania modelu sieciowego (Wykład 1)

Microsoft Project laboratorium zarządzania projektami

Modelowanie wyrównania czasowego buforów węzłowych dwupunktowej sieci CPM techniką by-passu

Konstruktory. Streszczenie Celem wykładu jest zaprezentowanie konstruktorów w Javie, syntaktyki oraz zalet ich stosowania. Czas wykładu 45 minut.

Zarządzanie czasem projektu

Ograniczenia projektu. Zakres (co?) Czas (na kiedy?) Budżet (za ile?)

ORGANIZACJA I ZARZĄDZANIE

JAK SKRÓCIĆ ZAGROŻONY TERMIN ZAKOŃCZENIA ROBÓT NA OBIEKCIE BUDOWLANYM?

ANALIZA SIECIOWA PROJEKTÓW REALIZACJI

Dane porównywalne w śródrocznym sprawozdaniu finansowym. Wpisany przez Krzysztof Maksymiuk

WYZNACZANIE WIELKOŚCI BUFORÓW CZASU I TERMINU ZAKOŃCZENIA PRZEDSIĘWZIĘCIA W HARMONOGRAMACH BUDOWLANYCH

Analiza zasobów przedsięwzięcia inżynierskiego w harmonogramie sieciowym na podstawie programu Pertmaster Professional +Risk

Rozdział 7 ZARZĄDZANIE PROJEKTAMI

Dydaktyka matematyki (II etap edukacyjny) II rok matematyki Semestr letni 2016/2017 Ćwiczenia nr 8

KONCEPCJA MONITOROWANIA ZUŻYCIA BUFORÓW CZASU W HARMONOGRAMIE BUDOWLANYM

Opis opcji aktualizacji zadań w programie MS Project 2007

KONSPEKTY LEKCJI. do przedmiotu ekonomika i organizacja przedmiotów

Język angielski. Poziom rozszerzony Próbna Matura z OPERONEM i Gazetą Wyborczą CZĘŚĆ I KRYTERIA OCENIANIA ODPOWIEDZI POZIOM ROZSZERZONY CZĘŚĆ I

Test niezależności chi-kwadrat stosuje się (między innymi) w celu sprawdzenia związku pomiędzy dwiema zmiennymi nominalnymi (lub porządkowymi)

Zarządzanie projektami

Zarządzanie projektami

Zarządzanie projektami. mgr inż. Michał Adamczak

Pendolinem z równaniami, nierównościami i układami

Zarządzanie projektów

Znaleźć wzór ogólny i zbadać istnienie granicy ciągu określonego rekurencyjnie:

Analiza czasowo-kosztowa

LOGISTYKA DYSTRYBUCJI ćwiczenia 11 i 12 WYKORZYSTANIE METOD SIECIOWYCH W PROJEKTACH LOGISTYKI DYSTRYBUCJI. AUTOR: dr inż.

Przykłady zastosowań funkcji tekstowych w arkuszu kalkulacyjnym

Ćwiczenia laboratoryjne - 4. Projektowanie i harmonogramowanie produkcji metoda CPM-COST. Logistyka w Hutnictwie Ćw. L. 4

KURSY DLA ZAWODU TECHNIK INFORMATYK

ZESZYTY NAUKOWE POLITECHNIKI ŚLĄSKIEJ 2014 Seria: TRANSPORT z. 82 Nr kol. 1903

SPOSOBY POMIARU KĄTÓW W PROGRAMIE AutoCAD

P: Czy studiujący i niestudiujący preferują inne sklepy internetowe?

METODA ŚCIEŻKI KRYTYCZNEJ STUDIUM PRZYPADKU

Dane bibliograficzne o artykule:

R-PEARSONA Zależność liniowa

Pochodna i różniczka funkcji oraz jej zastosowanie do rachunku błędów pomiarowych

składa się z m + 1 uporządkowanych niemalejąco liczb nieujemnych. Pomiędzy p, n i m zachodzi następująca zależność:

166 Wstęp do statystyki matematycznej

System wspomagania harmonogramowania przedsięwzięć budowlanych

Algorytm. Krótka historia algorytmów

CHARAKTERYSTYKA I ZASTOSOWANIA ALGORYTMÓW OPTYMALIZACJI ROZMYTEJ. E. ZIÓŁKOWSKI 1 Wydział Odlewnictwa AGH, ul. Reymonta 23, Kraków

Pochodna i różniczka funkcji oraz jej zastosowanie do obliczania niepewności pomiarowych

Zarządzanie projektami. Tadeusz Trzaskalik


Kod U2 Opracował: Andrzej Nowak

ĆWICZENIE Calowanie pokoju gościnnego Ent-teach Rozdział 6 Zarządzanie Projektem

MS Project 2010 w harmonogramowaniu - planowanie zadań, działań, operacji i przedsięwzięć

Analiza sieciowa projektów- metody: CPM, PERT. A. Kasperski, M. Kulej 1

Arbiter krajowego Sądu Polubownego jako podatnik podatku od towarów i usług wybrane aspekty

Próba wyznaczenia wielkości buforów czasu przy deterministycznej ocenie czasu zadań

Dane bibliograficzne o artykule:

FUNKCJA KWADRATOWA. Zad 1 Przedstaw funkcję kwadratową w postaci ogólnej. Postać ogólna funkcji kwadratowej to: y = ax + bx + c;(

ROZWIĄZYWANIE UKŁADÓW RÓWNAŃ NIELINIOWYCH PRZY POMOCY DODATKU SOLVER PROGRAMU MICROSOFT EXCEL. sin x2 (1)

SYSTEMY WSPOMAGANIA DECYZJI

Projekt: Część I Część II

Wstęp do informatyki- wykład 2

Elementy logiki i teorii mnogości

EGZAMIN MATURALNY Z INFORMATYKI

4. Postęp arytmetyczny i geometryczny. Wartość bezwzględna, potęgowanie i pierwiastkowanie liczb rzeczywistych.


Pracownia internetowa w każdej szkole (edycja Jesień 2007)

Inżynieria Morska i Geotechnika nr 5/2013 str

OSI Physical Layer. Network Fundamentals Chapter 8. Version Cisco Systems, Inc. All rights reserved. Cisco Public 1

Modele sieciowe. Badania operacyjne Wykład 6. prof. Joanna Józefowska

Transkrypt:

1 Dane bibliograficzne o artykule: http://mieczyslaw_polonski.users.sggw.pl/mppublikacje Mieczysław POŁOŃSKI 1 ALGORYTMY WYZNACZANIA ŚCIEŻKI KRYTYCZNEJ I ZAPASÓW CZASU W SIECIACH JEDNOPUNKTOWYCH O ROZSZERZONYCH TYPACH RELACJI MIEDZY ZADANIAMI 1. WPROWADZENIE Ścieżka krytyczna jest podstawowym pojęciem i elementem wyznaczanym w harmonogramach sieciowych. Bez jej znajomości nie sposób poprawnie interpretować wyniki obliczeń całego harmonogramu a następnie podejmować racjonalne decyzje w trakcie zarządzania realizacją planowanego przedsięwzięcia budowlanego. W związku z tym można by oczekiwać, że pojęcie to jest bardzo precyzyjnie zdefiniowane, a algorytmy obliczeniowe na podstawie których jest ona wyznaczana, są identyczne we wszystkich programach obliczeniowych służących do wspomagania planowania i zarządzania przedsięwzięciami. stety tak nie jest, na co zwrócił uwagę w swojej publikacji Marcinkowski [1]. Okazuje się, że używając do obliczeń tej samej sieci zależności dwóch różnych programów (MS Project i Pertmaster) można uzyskać dwa różne przebiegi ścieżki krytycznej. Powstaje pytanie skąd biorą się te różnice i czy jest to wynik błędnego działania jednego z tych programów czy też innego algorytmu obliczeniowego przyjętego przez twórców tych programów. Jeśli są to różne algorytmy, to co je różni oraz co legło u podstaw tych różnic oraz jaki ma to wpływ na sposób interpretacji wyników obliczeń? Próba odpowiedzi przynajmmniej na część z tych ważnych pytań znajduje się w dalszej części artykułu. 2. WPŁYW MODELU SIECI ZALEŻNOŚCI I STOSOWANYCH RELACJI MIĘ- DZY ZADANIAMI NA ICH TERMINY I ZAPASY CZASU Istnieją dwa podstawowe typy budowy sieci zależności: historycznie starsze sieci dwupunktowe (zwane też modelami ADM Arrow Diagramming Method) oraz nowsze, aktualnie zdecydowanie najpopularniejsze, tzw. sieci jednopunktowe (zwane też modelami PDM Precedence Diagramming Method) [2]. Pojecie ścieżki krytycznej oraz związane z nią pojęcia całkowitego i swobodnego zapasu czasu oraz sposób ich interpretacji wywodzą się z sieci dwupunktowych i w odniesieniu do tych modeli nie budziły wątpliwości (szczególnie bez wprowadzania terminów dyrektywnych). Z chwilą pojawienia się modeli jednopunktowych, przyjęte dotychczas terminy z sieci dwupunktowych zostały niejako automatycznie przeniesione i zastosowane do inter- 1 Dr hab. inż., prof. nadzw. SGGW, Wydział Inżynierii i Kształtowania Środowiska

2 pretacji tych właśnie sieci zależności. Należy jednak pamiętać, że zastosowanie modeli jednopunktowych nie polegało wyłącznie na odwróceniu notacji i założeniu, że teraz punkt (w graficznej formie prostokąt) obrazuje zadanie a strzałka reprezentuje relację miedzy zadaniami, lecz również między innymi wprowadzono zupełnie nowe typy tych relacji. W sieciach dwupunktowych zakończenie zadania poprzedzającego (osiągniecie zdarzenia następującego tego zadania) oznaczało możliwość rozpoczęcia zadania następującego (osiągnięcie zdarzenia poprzedzającego następnika), czyli następnik nigdy nie mógł się rozpocząć bez całkowitego zakończenia wszystkich poprzedników. Natomiast w sieciach jednopunktowych wprowadzono trzy dodatkowe typy relacji: relację RR (rozpocznij rozpocznij), ZZ (zakończ zakończ) oraz budzącą wiele kontrowersji i praktycznie nieużywaną relację RZ (rozpocznij zakończ). Dodatkowo na każdej relacji (łącznie ze standardową ZR, czyli zakończ rozpocznij) wprowadzono możliwość deklarowania tzw. zwłoki (dodatniej lub ujemnej), czyli dodatkowego czasu, o jaki zostanie opóźnione (zwłoka dodatnia) lub przyśpieszone (zwłoka ujemna) wykonanie następnika. Ważne jest, w jaki sposób te nowe typy relacji zostały zdefiniowane. Otóż relacja typu RR oznacza, że następnik nie może się rozpocząć dopóki nie rozpocznie się poprzednik (czyli może się rozpocząć później). Relacja ZZ oznacza natomiast, że następnik nie może się zakończyć, dopóki nie zakończył się poprzednik (czyli również może się zakończyć później). Należy zauważyć, że w obu typach relacji następnik jest podporządkowany poprzednikowi. stety, w powszechnym rozumieniu relacje te najczęściej są interpretowane błędnie: relacja RR jako konieczność rozpoczęcia obu zadań równocześnie, a relację ZZ jako przymus zakończenia obu zadań razem. Trudno się temu dziwić, jeśli nawet na oficjalnych stronach pomocy firmy Microsoft można przeczytać błędne objaśnienie tego typu relacji [http://office.microsoft.com/training/training.aspx?assetid=rp011369651045&ctt=6& Origin=RC011358691045]. Wiedząc, jak są definiowane rozszerzone typy relacji warto zauważyć, że nie precyzują one jednoznacznie sposobu wyznaczania wszystkich wczesnych i późnych terminów zadań, które są połączone tą relacją. Na przykład, jeżeli zadania M i N są połączone relacją typu ZZ jak wyznaczyć termin najwcześniejszego rozpoczęcia zadania N? Można przyjąć dwa rozwiązania. Pierwsze, że najwcześniejsze rozpoczęcie zadania N wyliczamy jako najwcześniejsze zakończenie tego zadania minus czas jego trwania. Drugie, że ponieważ nie wynika ono z definicji relacji, najwcześniejsze rozpoczęcie zadania N należy przyjąć możliwie najwcześniej a więc równe terminowi rozpoczęcia całego przedsięwzięcia. Podobny dylemat istnieje przy relacji RR przy obliczaniu najpóźniejszego końca zadania M. Można przyjąć termin zakończenia całego przedsięwzięcia lub najpóźniejszy początek plus czas trwania zadania. Podobne wątpliwości pojawiają się przy obliczaniu zapasów czasu. Np. swobodny zapas czasu definiuje się, jako możliwy czas opóźnienia zadania bez opóźnienia zadań następników [MS Project 2007: Pomoc; Kompendium; Opis pól; Zapas swobodny]. Ale czy to znaczy, że nie zostanie opóźniony termin rozpoczęcia czy zakończenia następnika, lub inaczej mówiąc czy dopuszczamy opóźnienie rozpoczęcia następnika czy tylko zwiększenie czasu jego wykonania? Jeżeli następnik jest powiązany z kolejnymi zadaniami relacjami RR ma to zasadnicze znaczenie dla sposobu wyznaczenia ich terminów. Jeszcze więcej niewiadomych kryją w sobie różne, spotykane w literaturze i opisach programów, definicje ścieżki krytycznej (ŚK) i bezpośrednio z nią związanego terminu zapasu całkowitego (ZC). Najczęściej spotkać można takie definicje:

Zapas całkowity czasu - ilość czasu, o jaką data zakończenia zadania może zostać opóźniona bez opóźnienia daty zakończenia projektu [MS Project 2007: Pomoc; Kompendium; Opis pól; Zapas całkowity], Ścieżka krytyczna - seria zadań, które muszą być wykonane zgodnie z harmonogramem, aby projekt został zakończony zgodnie z harmonogramem. Każde zadanie na ścieżce krytycznej jest zadaniem krytycznym. [MS Project 2007: Pomoc; Definicje] stety, trzeba stwierdzić, że obie definicje są wysoce nieprecyzyjne i mogą wprowadzać w błąd. Jak już zostało to pokazane w innej publikacji autora [3], można znaleźć przykład harmonogramu, w którym skrócenie zadania leżącego na ścieżce krytycznej i posiadającego zapas całkowity czasu równy zero nie prowadzi do skrócenia całego harmonogramu a czasami wręcz może wydłużyć całe przedsięwzięcie! Biorąc pod uwagę fakt istnienia różnych typów relacji w sieciach jednopunktowych wydaje się, że najbardziej prostą i precyzyjną definicją ścieżki krytycznej jest stwierdzenie, że jest to ciąg zadań o zapasach całkowitych równych zero, z zastrzeżeniem, że zmiana czasu zadania krytycznego może, ale nie musi, prowadzić do zmiany terminu całego przedsięwzięcia. Jednak, aby dopełnić tą definicję należy bezwzględnie podać, jakie wzory były stosowane do wyznaczenia tego zapasu. stety, twórcy programów opartych na modelach jednopunktowych, zdecydowanie unikają jasnego podania formuł obliczeniowych, które stosowali w obliczeniach, zadawalając się nieprecyzyjnymi opisami używanych terminów. Biorąc pod uwagę fakt, że pomimo znacznej popularności jednopunktowych modeli harmonogramów sieciowych, w literaturze spotyka się algorytmy i opisy obliczeń w sieciach dwupunktowych bez uwzględnienia wpływu na wyniki obliczeń rozszerzonych typów relacji, autor postanowił opracować algorytmy stosowane w popularnych programach komputerowych. Z jednej strony, powinny one pomóc zrozumieć działanie tych programów i ułatwić poprawne konstruowanie sieci zależności obiektów budowlanych, a z drugiej, ułatwić interpretowanie wyników obliczeń i wyjaśnić powody występowania różnic w uzyskanych wynikach obliczeń tych samych harmonogramów przy użyciu różnych programów. Opracowane algorytmy nie pochodzą z dokumentacji programów, gdyż ich autorzy takich nie publikują, a powstały na podstawie analiz autora artykułu. Ze względu na ograniczoną objętość publikacji w artykule znalazł się algorytm jednego z możliwych sposobów prowadzenia obliczeń, stosowany w programie Pertmaster. Prowadząc obliczenia wg podanego algorytmu należy zwrócić uwagę, że: obliczając terminy najwcześniejsze przy połączeniu relacją ZZ, jako termin najwcześniejszego początku zadania wynikający z danej relacji przyjmuje się termin rozpoczęcia całego przedsięwzięcia, w pierwszej kolejności wyznacza się na podstawie wszystkich relacji z poprzednikami termin najwcześniejszego rozpoczęcia zadania a dopiero później termin jego najwcześniejszego końca (w innych algorytmach może być inaczej), przy wyznaczaniu terminów najpóźniejszych przy połączeniu relacją RR, jako termin najpóźniejszego końca poprzednika wynikający z danej relacji przyjmuje się termin zakończenia całego przedsięwzięcia, najpierw wyznacza się na podstawie wszystkich relacji z następnikami termin najpóźniejszego końca zadania a dopiero później najpóźniejszego początku. Analizując wyniki obliczeń uzyskiwane w tym programie zwraca uwagę fakt, że twórcy programu wprowadzili dodatkowe pojęcia niestosowane wcześniej w innych programach 3

4 takie jak: preferowany start i preferowany koniec oraz zapas całkowity i swobodny zadania odnoszący się do preferowanego startu a nie terminu najwcześniejszego początku zadania. Co prawda w opisie programu można znaleźć informację, że preferowany start odpowiada terminowi najwcześniejszemu dopóki nie zostanie przedefiniowany przez użytkownika [Pertmaster Help; Preferred dates defined], jednak przykłady obliczeniowe wskazują, że preferowany start i termin najwcześniejszy zadania mogą różnić się dla zadań, które z poprzednikami połączone są relacją ZZ. Co ciekawe, zadania oznaczane na rysunkach kolorem czerwonym jako krytyczne, kwalifikowane są nie na podstawie zapasu całkowitego a zapasu całkowitego odniesionego do preferowanego startu. W praktyce oznacza to dla użytkownika, że w przypadku stosowania w obliczeniach podanych tu algorytmów, właśnie wartości zapasów czasu odnoszące się do preferowanego startu powinny być podstawą zarządzania obiektem. 3. ALGORYTM OBLICZANIA TERMINÓW I ZAPASÓW CZASU WG ZAŁOŻEŃ PROGRAMU PERTMASTER Poniżej opisano terminy i oznaczenia używane w prezentowanych algorytmach a dalej algorytm wyznaczania terminów najwcześniejszych, najpóźniejszych, preferowanego startu i zapasów czasu. Oznaczenia: i, j numer zadania w sieci zależności, t i czas zadania i, zwłoka i-j dodatnia lub ujemna zwłoka na relacji i-j, TRP termin rozpoczęcia przedsięwzięcia przyjmowany z założenia, TZP termin zakończenia przedsięwzięcia przyjmowany z założenia jako max(nwkj) wszystkich zadań w sieci, NWP j najwcześniejszy początek zadania j, NWP * i-j najwcześniejszy początek zadania j wynikający wyłącznie z relacji tego zadania z jego poprzednikiem i, NWK i najwcześniejszy koniec zadania i, NWK * i-j najwcześniejszy koniec zadania j wynikający wyłącznie z relacji tego zadania z jego poprzednikiem i, NPP * i-j najpóźniejszy początek zadania i wynikający wyłącznie z relacji tego zadania z jego następnikami j, NPK * i-j najpóźniejszy koniec zadania i wynikający wyłącznie z relacji tego zadania z jego następnikami j, ZC i zapas całkowity zadania i, ZS i zapas swobodny zadania i, ZS * i-j zapas swobodny zadania i wynikający wyłącznie z relacji tego zadania z jego następnikiem j, PS i preferowany start zadania i, PS * i-j preferowany start zadania i wynikający wyłącznie z relacji tego zadania z jego następnikami j, ZC i strat zapas całkowity zadania i wynikający z preferowanego startu, ZS i strat zapas swobodny zadania i wynikający z preferowanego startu ; pokazuje o ile można opóźnić rozpoczęcie tego zadania, ZS * i-j strat zapas swobodny zadania i wynikający z preferowanego startu oraz wynikający wyłącznie z relacji tego zadania z jego następnikami j.

5 Przyjmij termin rozpoczęcia przedsięwzięcia TRP (np. 1) Oblicz dla zad. początkowego j NWP j = TRP; NWK j = NWP j + t j -1 Przejdź do obliczenia terminów najpóźniejszych Czy jest w sieci nie obliczony NWP j następnika j zadania i z obliczonym NWK i? Jaka relacja łączy obliczane zadanie j z jego poprzednikiem i? ZR i-j RR i-j ZZ i-j NWP * i-j = max(nwk i +zwłoka i-j +1; TRP) NWP * i-j = max(nwp i +zwłoka i-j ; TRP) Czy obliczono NWP * i-j dla wszystkich relacji zadania j z jego poprzednikami i? NWP * i-j = TRP NWP j = max(nwp * i-j) dla wszystkich poprzedników i danego j Jaka relacja łączy obliczane zadanie j z jego poprzednikiem i? ZR i-j RR i-j ZZ i-j NWK * i-j = NWP j +t j -1 NWK * i-j = NWP j +t j -1 NWK * i-j = NWK i + zwłoka Czy obliczono NWP * i-j dla wszystkich relacji zadania j z jego poprzednikami i? Rys 1. Algorytm obliczania terminów najwcześniejszych wg założeń programu Pertmaster NWK j = max(nwk * i-i) dla wszystkich poprzedników i danego j

6 Przyjmij termin zakończenia przedsięwzięcia TZP = max(nwkj) dla wszystkich j w sieci zależności Oblicz dla zad. końcowego j NPK j = TZP; NPP j = NPK j - t j + 1 Przejdź do obliczenia Preferowanego Startu i zapasów czasu Czy jest w sieci nie obliczony NPK i poprzednika i zadania j z obliczonym NPP j? Jaka relacja łączy obliczane zadanie i z jego następnikiem j? ZR i-j RR i-j ZZ i-j NPK * i-j = min(npp j -zwłoka i-j -1; TZP) NPK * i-j = TZP NPK * i-j = min(npk j -zwłoka i-j ; TZP) Czy obliczono NPK * i-j dla wszystkich relacji zadania i z jego następnikami j? NPK i = min(npk * i-j) dla wszystkich następników j i danego i Jaka relacja łączy obliczane zadanie j z jego poprzednikiem i? ZR i-j RR i-j ZZ i-j NPP * i-j = NPK i -t i +1 NPP * i-j = min(npp j - zwłoka i-j ; NPK i -t i +1) NPP * i-j = NPK i -t i +1 Czy obliczono NPP * i-j dla wszystkich relacji zadania i z jego następnikami j? NPP i = min(npp * i-j) dla wszystkich następników j danego i Rys 2. Algorytm obliczania terminów najpóźniejszych wg założeń programu Pertmaster

7 Oblicz Preferowany Start PS, ZC i ZC-Start dla wszystkich zadań w sieci zależności Jaka relacja łączy obliczane zadanie i z jego następnikiem j? ZR i-j RR i-j ; brak następnika ZZ i-j Czy NWP i = TRP PS * i-j = NWK i - t i + 1 PS * i-j = NWP i PS * i-j = NWP i PS * i-j = NWK i - t i + 1 Czy obliczono PS * i-j dla wszystkich relacji zadania i z jego następnikami j? PS i = min(ps * ij) dla wszystkich następników j danego i ZC i = NPK i - NWP i - t i +1 = NPK i - NWK i ZC i -Start = NPP i - PS i Oblicz ZS i ZS-start dla kolejnych zadań w sieci zależności Jaka relacja łączy obliczane zadanie i z jego następnikiem j? ZR i-j RR i-j ZZ i-j Czy następnik j jest połączony z jego następnikami relacją RR? ZS * i-j = min(nwp j - NWK i -1- zwłoka i-j ; ZC i ) ZS * i-j -start = NWP j - PS i - t i - zwłoka i-j ZS * i-j = ZC i ; ZS * i-j -start = NWP j - PS i - zwłoka i-j ; ZS * i-j = min (NWK j - NWK i - zwłoka i-j ; ZC i ) ZS * i-j = min(nwk j - NWK i - zwłoka i-j - t j ; ZC i ) ZS * i-j -start = NWK j - t j - zwłoka i-j - t i - PS i + 1 ZS * i-j -start = NWK j - PS i - t i - zwłoka i-j + 1 ZS i = min(zs * i-j); ZS i -start = min(zs * i-j-start) dla wszystkich następników j danego i; jeżeli ZS i < 0 to ZS i = 0; jeżeli ZS * i-start <0 to ZS * i-start = 0; jeżeli ZS * i-start > ZS i to ZS * i-start = ZS i Rys 3. Algorytm obliczania preferowanego startu i zapasów czasu wg założeń programu Pertmaster

8 4. PODSUMOWANIE Wbrew powszechnej opinii, pojęcie ścieżki krytycznej oraz sposób wyznaczania zapasów czasu w sieciach jednopunktowych PDM nie jest jednoznacznie zdefiniowane. Świadczyć może o tym fakt, że w różnych programach obliczeniowych dla tej samej sieci zależności można uzyskać różny przebieg ścieżki krytycznej i wartości zapasów czasu. Zdaniem autora, różnice i brak precyzji w sposobie definiowania tych pojęć wynikają z mechanicznego przeniesienia stosowanych wcześniej w sieciach dwupunktowych pojęć na sieci jednopunktowe. Jednak wyznaczanie terminów i zapasów czasu w sieciach jednopunktowych wymaga uwzględnienia nowo wprowadzonych typów relacji miedzy zadaniami: relacji typu RR i ZZ, które zmieniają w istotny sposób prowadzenia obliczeń. Dodatkowe zamieszanie w stosowaniu powszechnie używanych pojęć wprowadzają twórcy programów obliczeniowych, nie podając formuł obliczeniowych na podstawie których wyznaczane są omawiane wartości, ograniczając się jedynie do bardzo ogólnikowych i nieprecyzyjnych opisów, a w niektórych przypadkach wręcz wprowadzających użytkowników w błąd. Powyższe uwagi wskazują na konieczność jednoznacznego sprecyzowania szeroko używanych terminów oraz dostępność algorytmów, służących do ich wyznaczania. W przeciwnym razie menadżerowie zarządzający realizacją obiektów budowlanych będą mieli trudności z prawidłowym interpretowaniem wyników prowadzonych na podstawie harmonogramów sieciowych obliczeń i podejmowaniem racjonalnych decyzji[4]. Literatura [1] Marcinkiewicz R.: Teoretyczne podstawy harmonogramowania realizacji zadań budowlanych. Problemy przygotowania i realizacji inwestycji budowlanych : Warsztaty inżynierów budownictwa : Puławy 22-24 października 2008 r. - Warszawa, 2008. [2] Murray B. Woolf.: Faster Construction Projects With CPM Scheduling. Mcgraw-hill Professional Publishing, 2007 [3] Połoński M.: Stosowanie rozszerzonych typów relacji w harmonogramach przedsięwzięć budowlanych. Problemy przygotowania i realizacji inwestycji budowlanych : Warsztaty inżynierów budownictwa : Puławy 22-24 października 2008 r. - Warszawa, 2008. [4] Korman R, Daniels S. H.: Critics Can't Find the Logic in Many of Today's CPM Schedules. ENR: Engineering News-Record; 5/26/2003, Vol. 250 Issue 20, 2003. ALGORITHMS DETERMINING CRITICAL PATH AND TIME SLACKS IN NETWORKS WITH WIDENDED RELATION TYPES BETWEEN TASKS Critical path is the key word and element in network schedules. Therefore one might assume that such vital term is defined in a particularly precise way and that computational algorithms used to calculating it are identical in all of computational programs. Unfortunately, reality is quite different. Questions arise: where do those variations origin from, what is their essence and foundation and finally, how does it influence an interpretation of calculation. The paper outlines that many definitions and calculation methods where automatically transferred from older two-point system (ADM Arrow Diagramming Method) onto the one-point system(pdm Precedence Diagramming Method) without taking into account new types of relations existing between tasks. This study also presents one of the possible algorithms determining time duration and its supplies employed in Pertmaster software programs.