4 Rekurze, Strukturální indukce Mimo „přímočarých" definic množin a funkcí, jako výčtem prvků či explicitním zadáním, se obzvláště v informatice setkáváme s definicemi nepřímými, které se odvolávají na sebe sama. Odborně se taková situace nazývá rekurzí a induktivní definicí. □ Stručný přehled lekce * Posloupnosti a rekurentní vztahy, jejich řešení. * Induktivní definice množin a funkcí, použití strukturální indukce. * Nazpět k matematické logice: sémantika výrokové logiky a formální převod do normálního tvaru. Petr Hliněný, Fl MU Brno, 2017 1/21 Fl: IB000: Strukturální indukce 4.1 Posloupnosti a rekurentní vztahy • Uspořádané fc-tice z daného oboru hodnot H jsou nazývány konečnými posloupnostmi délky k (nad H). • Pojem posloupnosti zobecňuje toto pojetí na „nekonečnou délku" takto: Definice 4.1. Posloupnost (nekonečná) je zobrazením z přirozených čísel N do oboru hodnot H, neboli p : N -> H. Místo „funkčního" zápisu n-tého členu posloupnosti jako p(n) častěji používáme „indexovou" formu jako pn, ve které se celá posloupnost zapíše (pn)neN-c Oborem hodnot H posloupnosti obvykle bývá nějaká číselná množina, ale může to být i jakákoliv jiná množina. □ Poznámka: Třebaže to není zcela formálně přesné, běžně se setkáme s posloupnostmi indexovanými od nuly nebo od jedničky, jak se to v aplikacích hodí. I my se budeme tímto řídit a vždy si určíme počáteční index podle potřeby. Petr Hliněný, Fl MU Brno, 2017 2/21 Fl: IB000: Strukturální indukce Příklady posloupností • po — 0, pi = 2,... ,pi = 2i,... je posloupnost sudých nezáporných čísel,c • (3, 3.1, 3.14, 3.141,...) je posl. postupných dekadických rozvojů 7r,c • třeba (jablko, hruška, švestka, hruška, hruška,...) je posloupnost nad druhy ovoce coby oborem hodnot.c • (1, —1, 1, —1,...) je posloupnost určená vztahem pi = (—l)z, i > 0, • avšak pokud bychom chtěli stejnou posloupnost (1, —1, 1, —1,...) určit indexy od jedné, tj. zadat ji jako g^, i > 1, tak vztah bude qi — (—1)2_1. Definice: Posloupnost (pn)ne^ Je * rostoucí pokud pn+i > Pn a nerostoucí pokud pn+i ^ Pn> * klesající pokud pn+i < Pn a neklesající pokud pn+i > Pn platí pro všechna n. Petr Hliněný, Fl MU Brno, 2017 3/21 Fl: IB000: Strukturální indukce Rekurentní zadání posloupnosti Definice: Říkáme, že posloupnost (pn)n^ je zadána rekurentně, pokud je dán její počáteční člen po (či několik počátečních členů) a dále máme předpis, jak určit hodnotu členu z hodnot pro nějaká i < n. Ukázky rekurentně zadaných posloupností: • Zadáme-li posloupnost pn počátečním členem po = 1 a rekurentním vztahem = 2pn pro n > 0, pak platí pn = 2n pro všechna n. • Funkce „faktoriál" (na přirozených číslech) je dána počáteční hodnotou 0! = 1 a rekurentním vztahem (n + 1)! = (n + 1) • n\ pro n > 0. • Známá Fibonacciho posloupnost je zadaná počátečními členy f1 = f2 = l a vztahem fn+2 = fn+i + fn pro n > 1. □ Všimněte si v poslední ukázce, že není potřeba doslova dodržovat formu rekurentního vztahu „pn+i z hodnot p^", ale vždy je třeba hodnotu následujícího členu posloupnosti odvozovat z předchozích (tj. už určených) členů. Petr Hliněný, Fl MU Brno, 2017 4/21 Fl: IB000: Strukturální indukce ■f- Řešení rekurentní posloupnosti Příklad 4.2. Posloupnost f : N —> 7L je zadaná rekurentní definicí /(O) =3 a /(n + l)=2-/(n) + l pro všechna přirozená n. Určete hodnotu f(n) vzorcem v závislosti na n. Řešení: V první fázi řešení takového příkladu musíme nějak „uhodnout" hledaný vzorec pro f(n). Jak? Zkusíme vypočítat několik prvních hodnot a uvidíme... /(I) = 2./(0) + l = 2.3 + l = 7 f (2) = 2-/(1)+ 1 = 2-7 + 1 = 15 /(3) = 2-/(2)+ 1 = 2-15 + 1 = 31 /(4) = 2 • /(3) + 1 = 2 • 31 + 1 = 63 Nepřipomínají nám tato čísla něco? Co třeba výrazy 8 — 1, 16 — 1, 32 — 1, 64 — 1... ? Bystrému čtenáři se již asi podařilo uhodnout, že půjde o mocniny dvou snížené o 1. Přesněji, f(n) = 2n+2 - 1. □ Ve druhé fázi nesmíme ale zapomenout správnost našeho „věštění" dokázat, nejlépe matematickou indukcí podle n. □ Petr Hliněný, Fl MU Brno, 2017 5/21 Fl: IB000: Strukturální indukce Příklad 4.2. Posloupnost f : N —>> Z Je zadaná rekurentní definicí /(O) =3 a /(n + l)=2-/(n) + l pro všechna přirozená n. Určete hodnotu f(n) vzorcem v závislosti na n. Řešení: ... Bystrému čtenáři se již asi podařilo uhodnout, že půjde o mocniny dvou snížené o 1. Přesněji, f(n) = 2n+2 - 1. Ve druhé fázi nesmíme ale zapomenout správnost našeho „věštění" dokázat, nejlépe matematickou indukcí podle n. • Báze: /(O) = 2°+2 -1 = 4-1 = 3 = /(O), což platí. □ • Indukční krok: za využití indukčního předpokladu f(n + 1) = 2 • f(n) + 1 = 2- (2n+2 - 1) + 1 = 2 • 2n+2 - 2 + 1 = 2^n+1)+2 - 1, což také platí správně. Podle principu matematické indukce je nyní dokázáno, že pro zadanou rekurentní posloupnost / platí f(n) = 2n+2 — 1 pro všechna přirozená n. □ Petr Hliněný, Fl MU Brno, 2017 6/21 Fl: IB000: Strukturální indukce -so = O a sn = sn-i + n2 pro všechna n > 1. Dokažte, že sn = |n(n + l)(2n + 1) pro všechna přirozená n. Řešení: Opět postupujeme matematickou indukcí podle n. • Báze: s0 = | • 0 • (0 + 1)(2 • 0 + 1) = 0, což platí. □ • Indukční krok: za využití indukčního předpokladu 1 1 sn = sn_i+n2 = - (n-l)(n-l + l)(2n-2 + l) + n2 = -n (2n2 - 3n +1) + n2 6 6 1 1 = -n (2n2 - 3n + 1 + 6n) = -n(n + l)(2n + 1), 6 6 což také platí správně. □ Poznámka: Výsledek Příkladu 4.3 je ukázkou tzv. sumačního vzorce pro řadu l l2 + 22 + • • • + n2 = -n(n + l)(2n + 1). 6 Jinou ukázkou je už dříve zmíněný základní vztah 1 + 2 + • • • + n = \n(n + 1). Petr Hliněný, Fl MU Brno, 2017 7/21 Fl: IB000: Strukturální indukce 4.2 Induktivní definice množin a funkcí Přímým zobecněním rekurentních definic posloupností je následující koncept. Definice 4.4. Induktivní definice množiny. Jedná se obecně o popis (nějaké) množiny M v následujícím tvaru: • Je dáno několik pevných {bázických) prvků ai, a2,..., a& £ M. • Je dán soubor induktivních pravidel typu Jsou-li (libovolné prvky) xi,... ,xt £ M, pak také y £ M. V tomto případě je y typicky funkcí y = fi(xi,..., xt). Pak naše induktivně definovaná množina M je určena jako nejmenší (inkluzí) množina vyhovující všem těmto pravidlům. Petr Hliněný, Fl MU Brno, 2017 8/21 Fl: IB000: Strukturální indukce ■r Několik ukázek. .. • Pro nejbližší příklad induktivní definice se obrátíme na množinu všech přirozených čísel, která je formálně zavedena následovně. - 0 G N - Je-li i G N, pak také succ{i) G N (kde následník succ{i) odpovídá Pro každé y E N můžeme definovat jinou množinu My C N induktivně: - y e My - Jestliže x G My a x + 1 je liché, pak x + 2 G My. □ Pak například M3 = {3}, nebo M4 = {4 + 2i \ i G N}. □ Dalším příkladem induktivní definice je už známé zavedení výrokových formulí z Oddílu 1.5. Uměli byste teď přesně říci, co tam byly bázické prvky a jaká byla induktivní pravidla? A jaká byla v definici formulí role závorek? Petr Hliněný, Fl MU Brno, 2017 9/21 Fl: IB000: Strukturální indukce Jednoznačnost induktivních definic Definice: Řekneme, že daná induktivní definice množiny M je jednoznačná, právě když každý prvek M lze odvodit z bázických prvků pomocí induktivních pravidel právě jedním způsobem. • Definujme například množinu M C N induktivně takto: - 2,3 G M - Jestliže x, y G M a x < y, pak také x2 + y2 a x • y jsou prvky M. Proč tato induktivní definice není jednoznačná? nNapríklad číslo 8 G M lze odvodit způsobem 8 = 2 • (2 • 2), ale zároveň zcela jinak 8 = 22 + 22. • V čem tedy spočívá důležitost jednoznačných induktivních definic množin? Je to především v dalším možném využití induktivní definice množiny jako „základny" pro odvozené vyšší definice, viz následující. Petr Hliněný, Fl MU Brno, 2017 10/21 Fl: IB000: Strukturální indukce Definice 4.5. Induktivní definice funkce z induktivní množiny. Nechť množina M je dána jednoznačnou induktivní definicí. Pak říkáme, že funkce T : M X je definována induktivně (vzhledem k induktivní definici M), pokud je řečeno: • Pro každý z bázických prvků ai, 0,2,..., G M je určeno F{ai) = C{. • Pro každé induktivní pravidlo typu "Jsou-li (libovolné prvky) xi,..., x£ G M, pak také /(xi,..., a^) G M" je definováno ^( / (#1? • • • 5 ^)) na základě hodnot T(x\),..., T{xt)^ Ilustrujme si induktivní definici funkce dětskou hrou na „tichou poštu". Definičním oborem je řada sedících hráčů, kde ten první je bazickým prvkem a každý následující (mimo posledního) odvozuje hráče sedícího hned za ním jako další prvek hry. Hodnotou bázického prvku je první (vymyšlené) posílané slovo. Induktivní pravidlo pak následujícímu hráči přiřazuje slovo, které je odvozeno („zkomolením") ze slova předchozího hráče. Výsledkem hry pak je hodnota-slovo posledního hráče. Petr Hliněný, Fl MU Brno, 2017 11/21 Fl: IB000: Strukturální indukce ■r Pro další příklad se podívejme třeba do manuálu unixového příkazu test No, problematická je otázka jednoznačnosti této definice - jednoznačnost není vynucena (jen umožněna) syntaktickými pravidly, jinak je pak dána nepsanými konvencemi implementace příkazu. To je pochopitelně z matematického hlediska špatně, ale přesto jde o pěknou ukázku z praktického života informatika. EXPRESSION: EXPRESSION is true or false ( EXPRESSION ) ! EXPRESSION EXPRESSI0N1 -a EXPRESSI0N2 EXPRESSI0N1 -o EXPRESSI0N2 [-n] STRING STRING1 = STRING2 and sets exit status. It is one of: EXPRESSION is true EXPRESSION is false both EXPRESSI0N1 and EXPRESSI0N2 are true either EXPRESSI0N1 or EXPRESSI0N2 is true the length of STRING is nonzero the strings are equal □ Petr Hliněný, Fl MU Brno, 2017 12/21 Fl: IB000: Strukturální indukce 4.3 Použití strukturální indukce Příklad 4.6. Jednoduché aritmetické výrazy a jejich význam. Nechť je dána abeceda E = {0,1, 2, 3,4, 5, 6, 7,8,9, 0, 0, (,)}. Definujme množinu jednoduchých výrazů SExp c E* induktivně takto: * Dekadický zápis každého přirozeného čísla n je prvkem SExp (bázické prvky). * Jestliže x,y £ SExp, pak také (x) 0 (y) a (x) 0 (y) jsou prvky SExp. * Jak snadno nahlédneme, díky nucenému závorkování je tato induktivní definice jednoduchých výrazů SExp jednoznačná. Tímto jsme aritmetickým výrazům přiřadili jejich „formu", tedy syntaxi. Pro přiřazení „významu", tj. sémantiky aritmetického výrazu, následně definujme funkci vyhodnocení Val: SExp —> N induktivně takto: * Pro bázické prvky: Va/(n) = n, kde n je dekadický zápis přirozeného čísla n. * První induktivní pravidlo: Val((x) 0 (y)) = Val(x) + Val(y). * Druhé induktivní pravidlo: Val((x) 0 (y)) = Val(x) • Val(y). Co je pak „správným významem" (hodnotou) uvedených aritmetických výrazů? □ Petr Hliněný, Fl MU Brno, 2017 13/21 Fl: IB000: Strukturální indukce Příklad 4.7. Důkaz správnosti přiřazeného „významu" Val: SExp —)► N. Věta. Pro každý výraz ,C,...} je množina výrokových proměnných. Množina ^výrokových formulí je dána těmito pravidly induktivní definice: * Bazickými prvky T jsou proměnné V, tj. X G J- pro každé X G V. * {negace) Je-li (p G J7, pak také je prvkem F.l * {implikace) Je-li £ pak také (92) (^) je prvkem F.l Zároveň platí, že závorky okolo (p lze vynechat pouze pokud (p £ V nebo <^ bylo vytvořeno induktivním pravidlem negace. To stejné platí pro vynechávání závorek okolo ^. Poznámka: Již nad rámec předchozí definice patří dříve uvedené syntaktické zkratky * (p\/ifj {disjunkce / „nebo") je jiný zápis formule =^> ip, * cpAip {konjunkce/„a") je jiný zápis formule —>(—V ~'V7)- * cp ip {ekvivalence) je jiný zápis formule {cp =^> ip) A {ip =^> cp). Petr Hliněný, Fl MU Brno, 2017 15/21 Fl: IB000: Strukturální indukce Sémantika výrokové logiky Na základě jednoznačné induktivní definice množiny J7 výrokových formulí nyní můžeme podat přesnou induktivní definici funkce vyhodnocení (logické hodnoty formulí). Nechť valuace (ohodnocení) je funkce v : V —>> {0,1}. Definice 4.8. Sémantika (význam) výrokové logiky. Pro každou valuaci v definujeme funkci Sv\ .F->{0,1}, zvanou vyhodnocení formule a vzhledek k v, ninduktivně takto: • SV{X) := v{X) pro každé IeP. o í \ 1 jestliže Sv(ld) — 0; # S"(^ := \ 0 jinak. . SJ

B) je ekvivalentní normální tvar A A -iB, • k formuli -.(C A (-^4 B)) je ekvivalentní -.C V (-^4 A -.B), □ • k formuli -.((A => B) C) je ekvivalentní (A B) A -.C). Petr Hliněný, Fl MU Brno, 2017 17/21 Fl: IB000: Strukturální indukce ■r Metoda 4.10. Převod formule p do normálního tvaru ÍF{p)-Používáme T{X) jako „je pravda, že X" a Q{X) jako „nenípravda, že X". T{A) = A G{A) = -iA H-v) = g{p) g (-v) = rivAý) = %)aj(^) g() = g{y)vg{ip) ^vv) = %)vj(^) £(<ŕ>vv) = g{y)f\g{ip) Hv&tí) = Hv)<*H-) G(v&ý) = (^)aW))v(%)ajW)o Pro predikátové formule toto rozšíříme ještě o pravidla: j-~(\/x. (p) = \/x. g (yx. ~^{B V —'(C => -*Ä))). Užitím uvedeného postupu získáme: F(-,(A =>->(B V->(C =>-.A)))) = G (A => ->(B V -i(C => ->A))) =□ ÍF(Ä) A g(^(B V -i(C => -*Ä))) = A A F(B V -i(C => -<Á)) =□ A A (F(B) V J7(-i(C => _|j4))) = A A (B V 0(C ->A)) =□ A A (B V (^(C) A = i A (B V (C A T (A))) =□ AA(BV(CAi)) Petr Hliněný, Fl MU Brno, 2017 18/21 Fl: IB000: Strukturální indukce Důkaz pro normální tvar formule Na závěr následuje další ilustrativní ukázka důkazu strukturální indukcí. Věta 4.11. Pro libovolnou výrokovou formuli (p platí (viz Metoda 4.10), že a) J~((f) je formule v normálním tvaru ekvivalentní k (p b) a G(p>) je formule v normálním tvaru ekvivalentní negaci -op. Důkaz povedeme indukcí ke struktuře formule, neboli indukci povedeme podle „délky" i - počtu aplikací induktivních pravidel při sestavování formule (p. • Báze indukce (í — 0): Pro všechny atomy, tj. výrokové proměnné, zřejmě platí, že T{Ä) — A je ekvivalentní A a G(Á) = -^A je ekvivalentní ->A • V indukčním kroku předpokládejme, že a) i b) platí pro všechny formule (p délky nejvýše £. Vezmeme si formuli i/; délky £ + 1, která je utvořená jedním z následujících způsobů: Petr Hliněný, Fl MU Brno, 2017 19/21 Fl: IB000: Strukturální indukce ý = -.<£. Podle výše uvedeného induktivního předpisu je J7^) = J7^^) — G() je ekvivalentní negaci formule tpi (^2, což jsme zde měli dokázat. Petr Hliněný, Fl MU Brno, 2017 20/21 Fl: IB000: Strukturální indukce * ý = (ifi V ip2). Zde si musíme opět uvědomit, že spojka V je pro nás jen zkratka, a přepsat ^ = (-^pi ^2)- Potom podle předchozích dokázaných případů víme, že Jr(^) = F(~^(pi ^2) — ^r(_,(^i) =^ ^{^2) je ekvivalentní formuli (-"(^í (^2) — V7- c°ž bylo třeba dokázat. Stejně tak = (/("^í ^2) = ^r(_,(^i) A ^((^2) je podle předchozích případů důkazu ekvivalentní A -"(^2) — * ^ = ((^! A (^2) a ^ = (<^i ^2) už dokončíme analogicky. Petr Hliněný, Fl MU Brno, 2017 21/21 Fl: IB000: Strukturální indukce