-
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!feeder.erje.net
!xlned.com!feeder5.xlned.com!feeder3.cambriumusenet.nl!feed.tweaknews.nl!postne
ws.google.com!glegroupsg2000goo.googlegroups.com!not-for-mail
From: Roman W <b...@g...pl>
Newsgroups: pl.comp.programming
Subject: Re: Pytanie do fanow Test Driven Design i XP
Date: Thu, 22 Dec 2011 00:58:38 -0800 (PST)
Organization: http://groups.google.com
Lines: 60
Message-ID: <12083221.451.1324544318220.JavaMail.geo-discussion-forums@vbbeg7>
References: <13550949.64.1324464699954.JavaMail.geo-discussion-forums@vbjs5>
<1...@n...googlegroups.com>
<6451050.730.1324484292903.JavaMail.geo-discussion-forums@yqja5>
<7...@o...googlegroups.com>
Reply-To: p...@g...com
NNTP-Posting-Host: 193.189.80.39
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: quoted-printable
X-Trace: posting.google.com 1324544318 22854 127.0.0.1 (22 Dec 2011 08:58:38 GMT)
X-Complaints-To: g...@g...com
NNTP-Posting-Date: Thu, 22 Dec 2011 08:58:38 +0000 (UTC)
In-Reply-To: <7...@o...googlegroups.com>
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=193.189.80.39;
posting-account=EexxQQoAAAAkOfWz0VZRKLcHNpXJZLB9
User-Agent: G2/1.0
X-Google-Web-Client: true
Xref: news-archive.icm.edu.pl pl.comp.programming:194445
[ ukryj 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
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-03 ROG
- 2025-07-03 OZE dały Polsce więcej prądu niż elektrownie węglowe
- 2025-07-03 Dlaczego nikt nie powiadamia służb!
- 2025-07-02 Jaka ładowarka sieciowa do Iphona?
- 2025-07-02 ,,The Plot to Get RFK" (,,Spisek, by pozbyć się RFK")
- 2025-07-02 Rozkaz 17-2025: O Zaprzestaniu Zaciągania Kredytów
- 2025-07-02 Rozkaz 16-2025: 2025-06-19 Apelacja Do Wyroku Sądu Rej. w Sprawie IVRNs 295-23
- 2025-07-02 Rozkaz 17-2025: O Zaprzestaniu Zaciągania Kredytów
- 2025-07-02 Inżynierowie... inżynierzy...
- 2025-07-02 Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- 2025-07-02 Kto potrafi sprawdzić aku BMW 48V 10Ah Li-Ion do mini hybrydy, czy sprawny ?
- 2025-07-02 Warszawa => Senior IT Recruitment Consultant <=
- 2025-07-02 Gdańsk => Konsultant wdrożeniowy (systemy controlingowe) <=
- 2025-07-02 Warszawa => IT Hardware Specialist - Wsparcie i Konfiguracja <=
- 2025-07-02 Warszawa => Inżynier oprogramowania .Net <=