-
Data: 2011-12-22 08:58:38
Temat: Re: Pytanie do fanow Test Driven Design i XP
Od: Roman W <b...@g...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On Wednesday, December 21, 2011 11:13:42 PM UTC, Maciej Sobczak wrote:
> On Dec 21, 5:18 pm, Roman W <b...@g...pl> wrote:
>
> > > Oprócz złożoności liniowej i pogłosu w filharmonii w Koluszkach,
> > > takich przykładów jest znacznie więcej. Np. mamy napisać generator
> > > liczb losowych o zadanym rozkładzie - jak to sprawdzić przez TDD?
> >
> > To akurat robilem. Losowalem np. 10000 probem i sprawdzalem czy histogram
sprawdza sie w ramach zadanej tolerancji z zadana dystrybucja,
>
> Jasne. Powiedzmy, że chodzi o liczby od 0 do 9 i rozkład jednostajny.
>
> Oto mój generator:
>
> int getNextValue()
> {
> static int x = 0;
> if (x == 10) x = 0;
> return x++;
> }
>
> Powyższa funkcja przy odpowiednio wielu wywołaniach daje całkiem dobry
> "histogram".
> Można tak zrobić dowolny zadany "rozkład" i go "przetestować" tak jak
> opisałeś.
I jezeli moj generator ma sluzyc *wylacznie* do obliczania wartosci oczekiwanych
E[f(X)], gdzie X ma miec rozklad jednostajny w zbiorze {0,1,2,...,9}, to taki test w
zupelnosci wystarcza, bo korelacje pomiedzy poszczegolnymi losowaniami mnie nie
obchodza. Ba, do calkowania Monte Carlo takie generatory moga byc lepsze od
standardowych (roznica pomiedzy liczbami pseudo- i quasilosowymi).
Jezeli mnie obchodza, to taki test jest dalece niewystarczajacy.
W praktyce to ja nie pisalem nigdy swoich wlasnych generatorow, tylko bralem Mersenne
Twister (np. z boost) i przeksztalcalem dystrybucje z jednostajnej w np. Gaussowska
albo Levy'ego. I wtedy histogramem + momentami sprawdzalem to co moglem sprawdzic, a
co do reszty to polegalem na poprawnosci implementacji bibliotecznej.
>
> Jakoś jednak sądzę, że ta funkcja jest do bani. Ale test przeszła! To
> może test jest do bani? Pewnie jest - ale jak sprawdzić ten test?
Dobrze wiem, jak trudno jest testowac generatory liczb losowych.
>
> Łatwiej napisać generator liczb losowych, niż jego test.
> To znaczy, że przy takim zadaniu w ogóle nie pisałbym unit-testu.
Nie, to jest bez sensu. Jezeli nie moge sprawdzic 100% wymagan, to nie znaczy, ze
powinienem sprawdzac 0%.
RW
Następne wpisy z tego wątku
- 22.12.11 09:02 Roman W
- 22.12.11 09:06 Roman W
- 22.12.11 09:08 Roman W
- 22.12.11 09:19 Stachu 'Dozzie' K.
- 22.12.11 09:29 Andrzej Jarzabek
- 22.12.11 09:40 bartekltg
- 22.12.11 09:44 Roman W
- 22.12.11 09:05 Roman W
- 22.12.11 09:53 Edek
- 22.12.11 09:55 Andrzej Jarzabek
- 22.12.11 10:02 bartekltg
- 22.12.11 10:04 Andrzej Jarzabek
- 22.12.11 10:07 bartekltg
- 22.12.11 10:15 Andrzej Jarzabek
- 22.12.11 10:14 Roman W
Najnowsze wątki z tej grupy
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-11-25 Karty przedpłacone (podarunkowe) Google Play - pytanie do korzystających
- 2024-11-26 wina Tóska
- 2024-11-26 Rewolucja/Rewelacja!
- 2024-11-25 grupa ożyła ;)
- 2024-11-24 Być jak Clint
- 2024-11-24 Rura kanalizacja konceptu Franke = problem
- 2024-11-25 Wrocław => Lead Java EE Developer <=
- 2024-11-25 Warszawa => Business Development Manager - Network and Network Securit
- 2024-11-25 Kraków => Programista Full Stack (.Net Core) <=
- 2024-11-25 Lublin => Senior PHP Developer <=
- 2024-11-25 Karlino => Konsultant wewnętrzny SAP (FI/CO) <=
- 2024-11-25 Warszawa => ECM Specialist / Consultant <=
- 2024-11-25 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-11-25 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2024-11-25 Lublin => Inżynier Serwisu Sprzętu Medycznego <=