Optimalizácia rela ných dotazov s agrega nými funkciami (Revízia metód a algoritmov)
|
|
- Σταύρος Καλογιάννης
- 6 χρόνια πριν
- Προβολές:
Transcript
1 FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY UNIVERZITA KOMENSKÉHO Katedra informatiky Optimalizácia rela ných dotazov s agrega nými funkciami (Revízia metód a algoritmov) Diplomová práca Martin Labanc dipl. vedúci RNDr. Ján turc Bratislava apríl 2005
2 Po akovanie Touto cestou vyslovujem po akovanie RNDr. Jánovi turcovi za poskytnutie literatúry, odborné vedenie, cenné rady a pripomienky pri vypracovaní mojej diplomovej práce.
3 ƒestne vyhlasujem, ºe diplomovú prácu som vypracoval samostatne a ºe som uviedol v²etku pouºitú literatúru.... V Bratislave, apríl 2005 Martin Labanc
4 Obsah 1 Úvod 5 2 Modikovaná algebra Denície, základné vz ahy Nekone né relácie Zov²eobecnenie operácií Selekcia Projekcia Algebraický stroj Techniky optimalizácie Spájanie/rozde ovanie agregácií Eager transformácie Lazy transformácie Ostatné transformácie Výsledky Optimaliza ná stratégia Algoritmus optimalizácie Príklady Pouºitá literatúra 35 4
5 1 Úvod Rela né dotazy obsahujúce agrega né funkcie majú vzh adom na objemy dát v databázach v praxi ve ký podiel na celkovom ase spracovania údajov. Mnoho testov výkonnosti - benchmarkov (napr. TPC-D) je zaloºených práve na meraní asu vyhodnotenia dotazu s agrega nou funkciou. Je preto na mieste zaobera sa prevodom týchto dotazov do o najoptimálnej²ieho tvaru. Predmetom ná²ho záujmu budú nerekurzívne dotazy formulované v revidovanej rela nej algebre obohatenej o operáciu agregácie. Pri skúmaní vlastností rela ných dotazov sa budeme snaºi niektoré operácie zov²eobecni a poskytnú tak odli²ný poh ad na ich vyhodnotenie. Tieto úvahy sa budú týka predov²etkým operácie selekcie, ktorú nahradíme zov²eobecneným joinom a agregácie, ktorej záber roz²írime aj na projekciu. Dotkneme sa aj problému nekone ných relácií, ich kone nej reprezentácie a operáciami nad nimi, nako ko nahradením selekcie joinom mnohokrát vyvstane potreba relácie, ktorá reprezentuje ur itú matematickú operáciu. Úvahy o optimalizácii dotazov nebudú vyuºíva platformovo ²pecické implementa né detaily a budú o najviac v²eobecné. Vysta íme si pri nich s pojmami klasickej databázovej teórie. Nakoniec zhrnieme teoretické výsledky do mnoºiny pravidiel resp. odporú aní ako optimálne vyhodnocova rela né dotazy s agrega nými funkciami. alej navrhneme rule-based optimalizátor realizujúci tieto optimaliza né pravidlá. Uvedieme aj motiva né príklady ilustrujúce vyuºitie jednotlivých transformácií. 5
6 2 Modikovaná algebra 2.1 Denície, základné vz ahy V prvom rade uvedieme denície niektorých ²pecických pojmov, ktoré budeme alej pouºíva. Na denovanie operácií revidovanej rela nej algebry vyuºijeme rela ný kalkul. V a ²ích úvahách budeme potom pracova len s pojmami modikovanej algebry. Relácie reprezentujeme zodpovedajúcimi tabu kami, ktoré chápeme ako multimnoºiny (bags). V kaºdej tabu ke implicitne uchovávame osobitný atribút m, ktorý obsahuje záznam o násobnosti daného riadku. Pri dosiahnutí násobnosti 0 riadok v tabu ke prestáva existova. Kvôli jednoduchosti tento atribút v rela nej schéme nezobrazujeme. Ve kos relácie je vyjadrená po tom riadkov tabu ky, ktorá ju reprezentuje. Pre zjednodu²enie úvah predpokladáme, ºe tabu ky obsahujú hodnoty rôzne od NULL. V nasledujúcich deníciách zodpovedá relácii R n (a 1, a 2,..., a k ) predikát P n (x 1, x 2,..., x k ) (x 1, x 2,..., x k ) R n. Denícia (Zjednotenie). R 1 (x) R 2 (x) = {x : P 1 (x) P 2 (x)}. Násobnosti jednotlivých riadkov sa aktualizujú s ítaním násobností záznamov jednotlivých tabuliek: (R 1 R 2 ).m := R 1.m + R 2.m. Denícia (Prienik). R 1 (x) R 2 (x) = {x : P 1 (x) P 2 (x)}. Násobnos záznamu sa rovná men²ej násobnosti riadku vo vstupných tabu kách: (R 1 R 2 ).m := min(r 1.m, R 2.m). Denícia (Rozdiel). R 1 (x, y) R 2 (x) = {x : P 1 (x, y) P 2 (x)}. Násobnos uchovávame len pre záznamy, ktoré patria rozdielu. Ostatné vo výsledku negurujú: (R 1 R 2 ).m := R 1.m Formuly jazyka rela ného kalkulu sú tvorené analogicky ako v jazyku prvého rádu : Termami sú kon²tanty a atribúty relácií. Atomické formuly vzniknú aplikáciou binárnych operátorov <,, =,, >, a matematických operácií na termy. Zloºené formuly tvoríme spájaním atomických formúl pomocou logických operátorov,,. Iné formuly sa v tomto jazyku nenachádzajú. 6
7 Denícia (Selekcia). Operátor selekcie vyberie z relácie riadky vyhovujúce selek nej podmienke,ktorá je vyjadrená formulou F. σ F R(x 1, x 2,..., x n ) = {x 1, x 2,..., x n P (x 1, x 2,..., x n ) F }. Denícia (Projekcia). Operácia projekcie Π x vyberie z relácie ur itú podmnoºinu atribútov. Π x R(x, y) = {x : ( y)p (x, y)}. Denícia (Kartézsky sú in). Najdrah²ia operácia algebry operujúca nad dvomi tabu kami, vytvorí reláciu s mohutnos ou rovnou sú inu mohutností vstupujúcich relácií. R 1 R 2 = {x 1, x 2,..., x n, y 1, y 2,..., y m P 1 (x 1, x 2,..., x n ) P 2 (y 1, y 2,..., y m )}. Denícia (Join). Joinom ²tandardne rozumieme prirodzené spojenie. Formálne: R 1 (x) R 2 (y) = { xy : P 1 (x) P 2 (y)} Joinova moºno relácie pod a jedného alebo viacerých atribútov. Neskôr túto operáciu zov²eobecníme na prípad nulového po tu joinovacích atribútov. Atribút násobnosti riadkov výslednej relácie je sú inom atribútov násobnosti riadkov jednotlivých joinujúcich relácií: (R 1 R 2 ).m = R 1.m R 2.m Denícia (Antijoin). Sémantika antijoinu je ve mi podobná sémantike mnoºinového rozdielu relácií. Od íta v²ak môºeme jedine kompatibilné relácie. Antijoin naproti tomu vyberie z prvej relácie riadky, ktorých ºiadny joinovací atribút sa nerovná zodpovedajúcemu joinovaciemu atribútu druhej relácie. Zapísané v rela nom kalkule : R 1 (x) R 2 (y) = {x : P 1 (x) P 2 (y)} Denícia (Θ join). V²etky druhy joinov moºno chápa ako ²peciálny prípad tejto operácie. Formálne : R 1 (x) F R 2 (y) = σ F (R 1 (x) R 2 (y)), kde F je joinovacia podmienka (pri klasickom joine je to test na rovnos hodnôt atribútov z mnoºiny joinovacích atribútov). Denícia (Selektivita joinu). Selektivita je íslo z intervalu < 0, 1 >, ktoré vyjadruje schopnos joinu zmen²i výslednú reláciu v porovnaní s kartézskym sú inom. Join povaºujeme za tým selektívnej²í, ím je tento pomer R S men²í. Selektivitu joinu kone ných relácií vyjadruje podiel Ak je R S. jedna z relácií nekone ná, kladieme selektivitu R S, kde R je kone ná relácia. V prípade dvoch nekone ných relácií je selektivita ich joinu denitoricky R 0. Analogicky moºno deníciu roz²ír aj na Θ join. Denícia (Funk ná závislos ). Nech Ω je mnoºina v²etkých atribútov rela nej schémy R. Nech X, Y Ω sú mnoºiny atribútov. Hovoríme, ºe X ur uje Y (X Y ), ak pre ubovo né 2 riadky r 1, r 2 prípustnej relácie R platí : ak sa r 1, r 2 zhodujú vo v²etkých atribútoch mnoºiny X, potom sa zhodujú aj vo v²etkých atribútoch mnoºiny Y. 7
8 Denícia (Pseudok ú ). Nech R je rela ná schéma a Ω jej mnoºina atribútov. Podmnoºinu I Ω nazveme vstupnou mnoºinou atribútov, ak existuje len kone ný po et n-tíc s rovnakými hodnotami atribútov z I. Minimálnu vstupnú mnoºinu atribútov P Ω v mnoºinovom zmysle nazveme pseudok ú. Pre v²etky kone né relácie je pseudok ú prázdna mnoºina. Denícia (Nadk ú ). Ak R je rela ná schéma a Ω jej mnoºina atribútov, tak S Ω je nadk ú om práve vtedy, ke S Ω. Denícia (K ú ). Ak R je rela ná schéma a Ω jej mnoºina atribútov, tak K Ω je k ú om R K je nadk ú om, ale ºiadna jeho vlastná podmno- ºina nadk ú om R nie je. K ú je teda minimálny nadk ú v mnoºinovom zmysle. Agrega né funkcie nie sú ²tandardnou sú as ou rela nej algebry. Klasická rela ná algebra má totiº rovnakú výrazovú silu ako jazyk logiky prvého rádu. To znamená, ºe v nej nemoºno vykona výpo et pevného bodu (teda napr. vypo íta tranzitívny uzáver grafu). Takisto nie je moºné v takomto jazyku vyjadri spo ítavanie objektov, teda napr. porovnáva mohutnosti mnoºín. Pre na²e potreby preto roz²írime okruh rela ných operátorov o operáciu agregácie. Denícia (Agrega ná funkcia). Agrega nú funkciu Γ formálne denujeme pomocou rela ného kalkulu nasledovne: Γ x (R(x, y, z)) = {xy : ( agg(y), z)p (x, y, z)}, kde x je zoskupujúci(groupby) agg(y) atribút a y je agregovaný atribút. Denícia Hovoríme, ºe agrega ná funkcia Γ je dekomponovate ná, ak existujú agrega né funkcie Γ 1, Γ 2,..., Γ n také, ºe Γ(S 1 S 2 ) sa dá napísa ako aritmetický výraz nad Γ 1, Γ 2,..., Γ n, kde S 1, S 2 sú mnoºiny hodnôt a je operátor zjednotenia. Táto vlastnos má ve ký význam pre rozde ovanie agregácií. Platia nasledovné vz ahy: Sum(S 1 S 2 ) = Sum(Sum(S 1 ), Sum(S 2 )) Min(S 1 S 2 ) = Min(Min(S 1 ), Min(S 2 )) Count(S 1 S 2 ) = Sum(Count(S 1 ), Count(S 2 )) Avg(S 1 S 2 ) = Sum(Avg(S 1) Count(S 1 ),Avg(S 2 ) Count(S 2 )) Sum(Count(S 1 ),Count(S 2 )) 8
9 V procese optimalizácie narazíme pri realizácii skorej agregácie na problém duplikátov. Tomu musíme prispôsobi aj sémantiku modikovanej algebry. Citlivos na duplicitu ur uje, i sa odstránením duplikátov na vstupe zmení výsledok agrega nej funkcie. Sum, Count, Avg sú citlivé na duplikáty, t.j. duplicitné riadky musia by zachované pred ich vyhodnotením. Naopak, Max a Min nie sú citlivé na duplikáty. Denícia (Úspora agregácie). Pod úsporou agregácie rozumieme schopnos operácie zoskupenia zmen²i mohutnos výslednej relácie. Vyjadruje ju podiel Γ agg(y) x (R), pri om agregácia je tým úspornej²ia, ím je tento R pomer men²í. Táto vlastnos agrega ných funkcií je k ú ová z poh adu optimalizácie. 2.2 Nekone né relácie Nekone né relácie nemoºno v databáze uloºi ako (kone né) tabu ky, treba ich implementova vo forme virtuálnych relácií pomocou zodpovedajúcich algoritmov. Matematické relácie je potrebné implementova ako programy. Takýto program sa navonok správa ako relácia. Za predpokladu rekurzívnosti v²etkých relácií v databáze sme ku kaºdej vstupnej mnoºine schopní poskytnú algoritmus(index), ktorý vráti v²etky n-tice s danou hodnotou vstupnej mno- ºiny. Príklad 2.1. : S ítanie reprezentujeme matematickou reláciou add(x, y, z) = {xyz : z = x+y}. Vstupnou mnoºinou pre túto reláciu sú v²etky dvojprvkové mnoºiny. Operátory aritmetického porovnania intuitívne implementujeme ako virtuálne relácie less(a, b), gr(a, b), eq(a, b). V relácii less(a, b) pre v²etky záznamy platí x < y, analogicky gr(a, b), eq(a, b). Pre eq sú pseudok ú om mnoºiny {a} a {b}, pre gr a less je to len mnoºina {a, b}. Uvedené mnoºiny sú pre tieto relácie aj k ú mi. Naproti tomu, pre reláciu F actor(x, y) = {xy : x delí y} je pseudok ú om {y}, k ú om je v²ak len {x, y}. Pri optimalizácii pouºívame len matematické relácie s 2 alebo 3 atribútmi. Táto trieda relácií kompletne pokryje na²e potreby. Relácie s 2 atribútmi slúºia na porovnávanie atribútov. Na implementáciu ubovo ného algoritmu posta ia 2 atribúty ako vstup a jeden ako výstup 3-atribútovej relácie. Zloºitej²ie vz ahy modelujeme príslu²nými joinami. Nekone né relácie vyuºívame 9
10 pri simulovaní selekcie joinom. Bliº²ie je tento proces popísaný v nasledujúcej kapitole. 2.3 Zov²eobecnenie operácií Táto kapitola pojednáva o ²pecickom poh ade na operácie selekcie a projekcie. Tieto chápeme ako ²peciálne prípady joinu, resp. agregácie. Odli²ný poh ad na základné databázové operácie tak umoº uje ²pecický prístup pri optimalizácii dotazov s agrega nými funkciami. Pokia sme teda doposia hovorili o SPJA(select, project, join, aggregate) dotazoch, odteraz budeme pracova s tzv. GPJ(Generalized projection, Join) dotazmi Selekcia Selekcia je základná databázová operácia pracujúca s jednotlivými riadkami. Slúºi na vybratie riadkov do výslednej relácie na základe ur itého kritéria. Základom reprezentácie selekcie joinom je nahradenie selek nej podmienky zodpovedajúcou reláciou, ktorá prakticky realizuje vz ah medzi atribútmi. Táto relácia potom pri vhodnom joinovaní so vstupnou reláciou vyberie po- ºadované riadky. Selek ná podmienka je vyjadrená formulou pod a denície v 2. kapitole. Okrem uvedených kon²truktov musíme v²ak bra do úvahy aj aritmetické operácie, nako ko tie sa tieº vyskytujú vo formulách. Pri tvorbe formúl vysta íme s : rela nými operátormi <, >, = logickými operátormi,, matematickými operáciami +, -, *, /... Kedºe platia nasledovné vz ahy : A B (A < B) (A = B) A B (A > B) (A = B) A B (A = B) a pomocou,, moºno vyjadri kaºdú binárnu logickú spojku, tieto operácie posta ujú na tvorbu v²etkých selek ných formúl. Formuly selek ných podmienok na jazyku relácií denujeme induktívne : 10
11 Rela né operátory = Test na rovnos s kon²tantou reprezentuje jednoriadková relácia E(vstupný atribút,kon²tanta). Test na rovnos atribútov dvoch relácií je priamou aplikáciou klasického joinu. <, > Porovnanie s kon²tantou je realizované joinom s nekone nou reláciou L(vstupný atribút, kon²tanta) pre operátor <, resp. G(vstupný atribút, kon²tanta) pre operátor >. V oboch prípadoch je relácia naplnená riadkami, ktoré majú prvý atribút men²í (resp. vä ²í) ako hodnota kon²tantného druhého atribútu. Porovnanie atribútov relácie pre prípad aritmetického operátora < uskuto níme joinom relácie less(a, b) so vstupnou reláciou R(a, b, x 1,..., x n ) pod a atribútov a, b. Formálne: σ a<b R(a, b, x 1,..., x n ) = R(a, b, x 1,..., x n ) less(a, b) Operátor > realizujeme analogicky. Logické operátory Prvým krokom prepisu selek ných podmienok je ich transformácia na konjunktívnu normálnu formu. alej vyuºitím DeMorganových pravidiel prepí²eme výrazy tvaru (F 1 F 2 ) na ( F 1 F 2 ) a (F 1 F 2 ) na ( F 1 F 2 ). V a ²om ozna me R reláciu zú astnenú na selekcii. Nech F 1, F 2 sú selek né formuly a P 1, P 2 sú im zodpovedajúce relácie. Potom F 1 F 2 reprezentujeme ako (R P 1 ) (R P 2 ). Nech F 1, F 2 sú selek né formuly a P 1, P 2 sú im zodpovedajúce relácie. Potom F 1 F 2 reprezentujeme ako (R P 1 ) (R P 2 ). Nech F je selek ná formula a nech P je relácia, ktorá jej zodpovedá. Potom F reprezentujeme ako R P. Aritmetické operácie moºno za predpokladu znalosti vstupnej mnoºiny realizova joinom s vhodnou matematickou reláciou Projekcia Projekcia je operácia nad celou reláciou manipulujúca s atribútmi. Táto operácia sa správa rovnako ako agregácia bez výpo tu agregátov. Konkrétne moºno napísa : 11
12 SELECT DISTINCT D FROM R SELECT D FROM R GROUP BY D V rela nej algebre : Π D R = Γ DD (R) Toto je my²lienka zov²eobecnenia operácie agregácie aj na projekciu [02]. Zavedieme teda novú operáciu, ktorú nazveme Zov²eobecnená projekcia(generalized projection - GP). Podobne ako agregácia, aj GP obsahuje zoskupujúce komponenty a agregované komponenty. Komponentami sú atribúty a funkcie, ktorých argumentami sú tieto atribúty. Vyºadovanými atribútmi GP nazveme zoskupujúce atribúty spolu s agregovanými atribútmi. V prípade, ºe GP nahrádza projekciu, neobsahuje ºiadne agregované komponenty. Zoskupujúce komponenty sú k ú om výslednej relácie, o má dva dôleºité dôsledky: 1. Ak vyºadované atribúty funk ne ur ujú zvy²né atribúty vstupnej relácie(napr. ke je sú as ou zoskupujúcich komponentov GP k ú vstupnej relácie), agregáciu môºeme vynecha a GP bude jednoduchou projekciou na tieto atribúty. 2. GP eliminuje duplikáty vo výsledku. Projekcia zachovávajúca duplikáty je potom reprezentovaná agrega nou funkciou count. Táto spo íta riadky, ktoré sa zhodujú v zoskupujúcich atribútoch: SELECT D FROM R SELECT D, count(*) AS m FROM R GROUP BY D V rela nej algebre : Π d R = Γ m=count( ) (R m ) d kde R m je pôvodná relácia R s pridaným atribútom násobnosti m. Kvôli dekomponovate nosti je potrebné, aby m atribút modikovala aj GP avg. Ostatné GP tento atribút vyuºívajú len pri dodato nej agregácii. Technická poznámka : Operácia GP môºe slúºi aj na premenovanie atribútov. Je to len technická operácia bez reálneho dopadu na výsleok. V rela nom kalkule pouºívame vo výrazoch premenné, naproti tomu operácie rela nej algebry manipulujú nad natívnymi atribútmi, ktoré treba pred aplikáciou joinu kvôli kompatibilite premenova. Príklad 2.2. : Výraz P (x, y) P (u, v) preloºíme do algebry ako R(x, y) (R(x, y)). Γu x v y Pri kon²trukcii algoritmu optimalizácie nebudeme tejto operácii venova ²peciálnu pozornos. 12
13 2.3.3 Algebraický stroj Dotaz na databázu v rela nej algebre je spracovávaný algebraickým strojom. Uvedieme potrebné modikácie klasického algebraického stroja na spracovanie dotazov modikovanej algebry. Kartézsky sú in chápeme ako ²peciálny prípad joinu s prázdnou mno- ºinou joinovacích atribútov. Priamej realizácii tejto operácie sa pri kon²trukcii optimaliza ných pravidiel snaºíme vyhnú, nako ko selektivita zodpovedajúceho joinu je 1. Join reprezentujúci kartézsky sú in preto po ítame pomocou techniky nested-loops. Join dvoch relácií, z ktorých aspo jedna je nekone ná uskuto níme metódou nested-loops. Θ join potom realizujeme nasledovne: Postupne generujeme výslednú reláciu ako pri kartézskom sú ine. Kaºdú novovytvorenú n-ticu pred jej zaradením do výsledku joinujeme s matematickou reláciou reprezentujúcou selek nú podmienku Θ joinu. Pomocou tohto prístupu sa vyhneme kon²trukcii ve kej do asnej relácie. V modikovanej rela nej algebre vyzerá realizácia Θ joinu nasledovne: R 1 F R 2 = (R 1 R 2 ) R F kde R F je relácia reprezentujúca selek nú podmienku vyjadrenú formulou F. Pseudok ú pre R F je sú as ou testovanej n-tice. ƒasová zloºitos takejto operácie je O( R 1 R 2 ). Logické operátory sú v modikovanej algebre denované pomocou mno- ºinových operácií. Takáto priamo iara realizácia by v²ak nebola optimálna vzh adom na spolo né podvýrazy vo formuliach. Vezmime prípad atomických formúl A 1, A 2 reprezentovaných reláciami R A1 a R A2. Podobne ako pri výpo te Θ joinu prechádzame riadky vstupnej kone nej relácie R. V prípade formuly A 1 A 2 joinujeme R najprv s R A1 a vzniknutú reláciu s R A2. Formulu A 1 A 2 realizujeme dvomi joinami: R 1 = R R A1 a R 2 = R R A2, pri om R 2 treba po íta len ak R 1 =. Do výslednej relácie zaradíme ubovo nú neprázdnu z týchto dvoch n-tíc. Pri klasickom Joine dvoch kone ných relácií preferujeme metódu sort&merge. Dôvodom je skuto nos, ºe výpo et agregácie zah a triedenie. Vezmime prípad výpo tu GP a následného joinu. Pokia sú joinovacie atribúty sú as ou zoskupujúcich komponentov GP, u²etríme triedenie 13
14 pri sort&merge joine. Podobná situácia nastane pri opa nom poradí vykonania joinu a GP. Mnoºinové operácie zjednotenie, prienik a rozdiel realizujú SQL príkazy UNION, INTERSECT a EXCEPT. Ke ºe kaºdá z týchto operácií pracuje len s kompatibilnými mnoºinami, vykonávame ich aº po vyhodnotení jednotlivých zloºiek. Operácie, ktoré relácie zmen²ujú(prienik, rozdiel) vykonávame o najskôr. Prienik sa dá reprezentova joinom relácií pod a v²etkých ich atribútov a rozdiel moºno nahradi antijoinom pod a v²etkých atribútov. Tieto operácie v²ak ponecháme v nezmenenej podobe, nako ko v stratégii optimalizácie majú osobitné miesto. Denovali sme transformácie a roz²írenie klasickej rela nej algebry, ktorú vyuºijeme v a ²om skúmaní. Na²a revidovaná rela ná algebra má teda rovnakú výrazovú silu ako SQL a pozostáva z nasledovných operácií: Join pokrývajúci kartézsky sú in, join a v kombinácii s matematickými reláciami aj selekciu a Θ join Generalizovaná projekcia Γ Mnoºinové operácie,, x agg(y) (R) zah ajúca projekciu a agregáciu 14
15 3 Techniky optimalizácie V tejto kapitole preskúmame rôzne transformácie plánu vyhodnotenia z poh adu korektnosti ich pouºitia. Na²a modikovaná algebra obsahuje okrem mnoºinových operácií len GP a joiny, transformácie sa budú preto týka najmä vz ahov týchto dvoch operácií. Pojednaniu o vhodnosti pouºitia týchto úprav je venovaná samostatná kapitola. Na vizualizáciu dotazu vyuºije hypergraf. Uzlami grafu sú atribúty jednotlivých relácií. Uzly zodpovedajúce joinovacím atribútom stotoºníme. Tieto budeme v a ²om ozna ova termínom Join Point(JP). V prípade kartézskeho sú inu pridáme do grafu ktívne JP. Agregované atribúty ozna íme plným a ostatné atribúty prázdnym krúºkom. Ak je nejaký atribút agregovaným atribútom jednej GP a sú asne zoskupujúcim atribútom inej GP, ozna íme ho plným krúºkom. Plnými hyperhranami spojíme atribúty patriace jednej relácii. Do hypergrafu zahrnieme aj pomocné nekone né relácie a im zodpovedajúce hrany. ƒiarkovanými hranami spojíme atribúty zú ast ujúce sa na GP (agregované aj zoskupujúce). Ku grafu pod a potreby pridáme názvy relácií a ich atribútov. A B C D R1 E F R2 Obrázok 1: Reprezentácia dotazu hypergrafom Príklad 3.1. Daná je rela ná schéma R 1 (A, B, C, D), R 2 (E, F, G). Na obrázku 1 je znázornený SQL dotaz SELECT B, C, agg(d) FROM R 1, R 2 WHERE R 1.B = R 2.G GROUP BY B, C v modikovanej algebre zapísaný ako Γ B,C (R 1 R 2 ). agg(d) 15
16 3.1 Spájanie/rozde ovanie agregácií Nasledovné techniky sú sú as ou Eager/Lazy transformácii a vyuºívajú dekomponovate nos GP. V procese optimalizácie môºeme narazi na prípad dvoch alebo viacerých GP idúcich za sebou bez joinu medzi nimi. V takomto prípade je výhodné spoji tieto výpo ty do jedného, ak je to moºné. V a ²om ozna me prvú agregáciu v poradí vykonania GP 1 a druhú GP 2. Transformácia Ak GP 2 nie je citlivá na duplicitu (min, max, projekcia) a v²etky jej vyºadované atribúty sú zoskupujúcimi atribútmi GP 1, výpo et GP 1 môºeme vynecha. Transformácia Ak agregovaný atribút GP 2 je agregovaným atribútom GP 1 a sú asne GP 1 aj GP 2 sú rovnakého typu, výpo et agregácie vykonáme vrámci GP 2. V prípade, ºe nejaký zoskupujúci atribút GP 2 je agregovaným atribútom GP 1, nemôºeme GP 1 a GP 2 spoji. Transformácia Kaskáda GP. Ak prvá GP v kaskáde neobsahuje ºiadne agregované atribúty (simulácia projekcie), potom platí : Γ AA (Γ BB (R)) = Γ AA (R) Γ AA (Γ C agg(d) (R)) = Γ AA (R) pri om C je ubovo ný atribút (vrátane A). Rozdelenie výpo tu GP do kaskády viacerých GP idúcich za sebou je opa ným postupom k spájaniu. Po rozdelení GP musí plati, ºe vzniknuté zloºky spojením vytvoria pôvodnú GP. Pri optimalizácii vyuºívame najmä iasto né grupovanie pod a jednotlivých atribútov z(ale aj mimo) mnoºiny zoskupujúcich atribútov. Kvôli korektnosti musia v²etky zoskupujúce atribúty GP 2 gurova medzi zoskupujúcimi atribútmi v²etkých iasto ných agregácií. Transformácia Daná je relácia R(A, B, C, D). Potom Γ A agg(d) (R) = Γ A (Γ A,B f(y ) Y =agg(d) (R)) = Γ A (Γ A,C (R)) = Γ A (Γ A,B,C (R)) f(y ) Y =agg(d) f(y ) Y =agg(d) kde agg je dekomponovate ná agrega ná funkcia a f je dodato ná agregácia z denície dekomponovate nosti(napr. pre agg count je f sum). Uvedená transformácia je priamou sú as ou skorej agregácie. 16
17 3.2 Eager transformácie Trieda transformácií vyuºívajúca schopnos agregácie významne zredukova po et riadkov vo výslednej relácii. Samotná agregácia je vykonaná skôr ako pri priamo iarom prepise dotazu do algebry, preto ju zvykneme ozna ova skorá agregácia(early, alebo tieº Eager aggregation). Technika vyuºíva výpo et iasto ných grúp pred joinom. Takto sa zredukuje po et riadkov vstupujúcich do joinu, na ktoré potom ale treba aplikova dodato ný výpo et agregácie. Tá je odvodená z vlastnosti dekomponovate nosti pôvodnej agregácie. Za ur itých podmienok moºno túto agregáciu vynecha. Táto technika sa dá s úspechom pouºi na podporu pre tvorbu materializovaných view obsahujúcich iasto né agregáty. V praxi sa táto metóda vyuºíva hlavne pri distribuovaných systémoch. Problematikou view sa v²ak nebudeme bliº²ie zaobera. Eager transformácie nemenia sémantiku dotazu, len spôsob jeho vyhodnotenia. Musia preto sp a ur ité podmienky: 1. Ke ºe GP projektuje vstupnú reláciu na svoje vyºadované atribúty, sú medzi nimi joinovacie atribúty v²etkých joinov nasledujúcich po tejto GP. 2. Zjednotenie mnoºín zoskupujúcich atribútov iasto ných(skorých) GP je nadmnoºinou mnoºiny zoskupujúcich atribútov pôvodnej GP. Táto podmienka pochádza z pravidiel o rozde ovaní agregácií. 3. V prípade GP citlivých na duplikáty je po aplikovaní iasto ných GP zachovaná mohutnos relácií bez agregovaných atribútov vstupujúcich do joinu, ktorý predchádza pôvodnej GP. Túto podmienku zabezpe íme pouºitím m atribútu relácií. Na základe týchto sémantických obmedzení kon²truujeme jednotlivé transforma né pravidlá. Ukáºkové prípady sú kvôli preh adnosti zjednodu²ené, priamo iaro ich v²ak moºno zov²eobecni na zloºitej²ie varianty. Viac príkladov sa nachádza v poslednej kapitole. Na popis jednotlivých transformácií vyuºijeme rela nú schému z úvodu kapitoly. Podobne ako pri rozde ovaníspájaní agregácií ozna íme pôvodnú agrega nú funkciu agg a dodato nú agregáciu f. Transformácia Γ B,C (R 1 R 2 ) Γ B,C (R 1 ) R 2 agg(d) agg(d) Situácia pre tento prípad je znázornená na obrázku 1. Namiesto aplikovania agregácie na join relácií R 1, R 2 vykonáme agregáciu na R 1 a výsledok následne joinujeme s R 2. Takáto transformácia je najjednoduch²ia(vymení sa 17
18 len poradie joinu a GP) a v praxi najefektívnej²ia. Na jej korektné uskuto nenie je v²ak nutné splni pomerne silný predpoklad: V²etky joinovacie atribúty relácie R 1 sú zoskupujúce atribútmi GP(podmienka 1) a zárove R 1 R 2 je joinom na cudzí k ú. V na²om konkrétnom prípade teda R 2.G je cudzím k ú om v R 1. Dôvod tohto obmedzenia je nasledovný[03]: Musí plati, ºe riadky prislúchajúce rôznym grupám po aplikovaní skorej GP budú prislúcha rôznym grupám aj vo výsledku. Cudzí k ú sa joinuje maximálne s jedným riadkom danej relácie, pri om klasický join by mohol eventuelne duplikova niektoré hodnoty zoskupujúcich atribútov. To by ale nebolo sémanticky korektné, nako ko agrega ná funkcia po íta agregáty práve na základe týchto hodnôt. V prípade, ºe uvedená podmienka neplatí, je potrebné vykona dodato nú agregáciu: Γ B,C (Γ B,C (R 1 ) R 2 ) f(d) agg(d) Transformácia Γ C agg(d) (R 1 R 2 ) Γ C (Γ B,C f(d) agg(d) (R 1 ) R 2 ) V tomto prípade nie je splnená podmienka 1, výpo et agregácie treba teda rozdeli na 2 fázy : agg a f. Pre Γ B,C agg(d) (R 1 ) sú v²ak uº splnené v²etky podmienky, moºno ju teda realizova pred joinom s R 2. Po vykonaní tohto joinu sú splnené podmienky aj pre dodato nú agregáciu pomocou ktorej z iasto ných grúp vyrobíme kone ný výsledok. Obrázok 2: Eager transformácia. 2 Transformácia Γ C,E (R 1 R 2 ) Γ C,E (Γ B,C agg(d) f(d) agg(d) (R 1 ) Γ E,G (R 2 )) E,G Uvedený dotaz poru²uje podmienku 1, nako ko joinovací atribút nie je sú- as ou zoskupujúcich atribútov ani pôvodnej GP. Tú preto rozdelíme na 2 zloºky, ktoré operujú nad jednotlivými joinujúcimi reláciami R 1, R 2. Pre ne uº platia podmienky vykonania skorej agregácie. 18
19 Obrázok 3: Eager transformácia. 3 Transformácia Γ E,B,C (R 1 R 2 ) Γ E,B,C (Γ B,C (R 1 ) Γ E,G (R 2 )) agg(d) f(d) agg(d) E,G Situácia podobná predo²lej, aº na to, ºe pôvodná GP zah a vrámci svojich zoskupujúcich atribútov v²etky joinovacie atribúty. Priamemu vykonaniu skorej agregácie bráni v²ak neprítomnos v²etkých vyºadovaných atribútov v ase jej aplikácie. Zoskupujúci atribút E je totiº sú as ou relácie R 2 a k dispozícii je aº po vykonaní joinu R 1 s R 2. Rie²ením je rovnaký postup ako v predchádzajúcom prípade. Obrázok 4: Eager transformácia. 4 Transformácia Γ C,E (R 1 R 2 ) Γ C,E (Γ B,C (R 1 ) Γ EE (R 2 )) agg(d) f(d) agg(d) Vezmime 3. transformáciu a aplikujme ju na prípad joinu s prázdnou mno- ºinou joinovacích atribútov. Pri realizácii skorej agregácie v tomto prípade teda sta í overova prirodzenú poºiadavku na prítomnos v²etkých vyºadovaných atribútov danej GP. Zoskupujúcimi atribútmi parciálnych GP budú zoskupujúce atribúty pôvodnej GP vrámci jednotlivých joinujúcich relácií. Z 19
20 dôvodu uvedeného v 1. pravidle treba nakoniec aplikova dodato nú GP. Obrázok 5: Eager transformácia. 5 Na rela nej schéme z Príkladu 3.1 popí²eme rolu m atribútu pri jednotlivých transformáciách na konkrétnych GP. Po joine s R 2 má záznam vo výslednej relácii vºdy R 2.m-krát vä ²iu mohutnos ako mal v R 1. Tomu treba náleºite prispôsobi výpo ty agregátov v dodato ných GP citlivých na duplicitu. Γ B,C,E (R 1 R 2 ) Γ B,C,E (Γ B,C (R 1 ) Γ G,E (R 2 )) min(d) min(d) min(d) G,E Γ B,C,E (R 1 R 2 ) Γ B,C,E (Γ B,C (R 1 ) Γ G,E (R 2 )) max(d) max(d) max(d) G,E Γ B,C,E (R 1 R 2 ) Γ B,C,E (Γ B,C (R 1 ) Γ G,E (R 2 )) sum(d) sum(d R 2.m) sum(d) m=count( ) Γ B,C,E (R 1 R 2 ) Γ B,C,E (Γ B,C (R 1 ) Γ G,E (R 2 )) count( ) sum(r 1.m R 2.m) m=count( ) m=count( ) Γ B,C,E avg(d) (R 1 R 2 ) Γ B,C,E sum(avg(d) R 1.m R 2.m) sum(r 1.m R 2.m) (Γ B,C (R 1 ) Γ G,E (R 2 )) avg(d),m=count( ) m=count( ) Vykonanie GP vo vetve R 2 teda so sebou priná²a dodato nú réºiu v podobe aktualizácie m atribútu. Pri kon²trukcii optimaliza ných pravidiel musíme preto tento fakt zoh adni. V doteraj²ích úvahách sme predpokladali, ºe joiny sa týkajú iba zoskupujúcich atribútov GP. Analyzujme situáciu, ke joinovací atribút patrí medzi agregované atribúty GP: GP je sú as ou výrazu za SQL operátorom HAVING. Poradie vyhodnotenia nazna uje aj naivný prepis do rela nej algebry - join nasleduje aº po vyhodnotení GP. 20
21 V opa nom prípade je nutné vykona join pred GP, nako ko doty ný agregovaný atribút vystupuje v SQL dotaze vo WHERE podmienke. V oboch prípadoch je teda vzájomné poradie joinu a GP ur ené jednozna ne sémantickými obmedzeniami. 3.3 Lazy transformácie Pozdrºa vyhodnotenie agregácie aº po vyhodnotení joinu je vhodné vtedy, ak je join dostato ne selektívny. Táto operácia je ur itým spôsobom reverzná vo i eager transformácii a ozna uje sa neskorá agregácia(lazy aggregation). V tomto prípade joinom zredukovaný po et riadkov urýchli výpo et agregácie. Vyuºitie nájde táto metóda hlavne pri joinoch, ktoré simulujú selekcie so silnými selek nými podmienkami. Naivný prepis rela ného dotazu do rela nej algebry obsahuje výpo et agregácie aº po v²etkých joinoch. Pre pouºitie tejto techniky teda neexistujú ²peciálne obmedzenia, ke ºe je príklonom ku klasickému výpo tu. V na²ej stratégii optimalizácie ju chápeme ako neaplikovanie skorej agregácie. 3.4 Ostatné transformácie Algebraické pravidlá pre vyhodnocovanie dotazov známe z klasickej rela nej algebry[01] teraz popí²eme na jazyku modikovanej algebry. Algebraické pravidlá modikovanej algebry: Transformácia Komutativita joinu R 1 R 2 = R 2 R 1 V aka zov²eobecneniu operácií táto transformácia pokrýva komutativitu joinu a kartézskeho sú inu so selekciou a medzi sebou. Transformácia Asociativita joinu R 1 (R 2 R 3 ) = (R 1 R 2 ) R 3 pokrýva zárove asociativitu kartézskeho sú inu. Transformácia Distributívnos joinu vzh adom na join V prípade, ºe joinovacie atribúty z R 3 sú obsiahnuté v R 1 aj R 2, platí: (R 1 R 2 ) R 3 = (R 1 R 2 ) (R 1 R 3 ) Uvedené pravidlo je analógiou komutativity selekcie a joinu z klasickej algebry. Selek nú podmienku vyjadruje relácia R 3. 21
22 Transformácia Distributívnos joinu vzh adom na mnoºinové operácie a - R 1 (R 2 R 3 ) = (R 1 R 2 ) (R 1 R 3 ) R 1 (R 2 R 3 ) = (R 1 R 2 ) (R 1 R 3 ) Transformácia Kaskáda joinov (R 1 R 2 ) R 3 = R 2 (R 1 R 3 ) Toto pravidlo sa pouºíva hlavne v situáciách, ke simulujeme selekciu joinom. R 1, R 2 v tomto prípade reprezentujú dve asti konjunkcie selek nej podmienky. Uvedené transformácie nám umoºnia modikova poradie vyhodnotenia joinov pri kon²trukcii optimálneho výrazu vyhodnotenia. 22
23 4 Výsledky V závere nej kapitole uvedieme nieko ko príkladov vhodného pouºitia optimaliza ných techník a poukáºeme aj na riziká spojené s ich neuváºenou aplikáciou. Opí²eme zárove integráciu pravidiel odvodených z týchto techník do existujúcich optimizérov. Men²í po et operácií modikovanej rela nej algebry má za následok aj men²í po et potrebných pravidiel, o výrazne zjednodu²í návrh optimaliza ného algoritmu. 4.1 Optimaliza ná stratégia V kapitole o technikách optimalizácie sme uviedli nieko ko platných transformácií plánu vyhodnotenia. Na tomto mieste preskúmame moºnosti pouºitia týchto techník z h adiska zlep²enia asovej a priestorovej realizácie plánu. Ke ºe ²peciká praktických databázových systémov nie sú predmetom ná²ho skúmania, nezaoberáme sa konkrétnou optimálnou realizáciou operácií joinu resp. agregácie. Pri kon²trukcii pravidiel optimalizácie si vysta íme so v²eobecnými informáciami o reláciách v databáze, ktoré sú k dispozícii kaºdému systému. Konkrétne sa jedná o: Prítomnos primárneho/cudzieho k ú a Fyzická velkos relácie Funk né závislosti Hlavným cie om optimalizácie je o najviac zmen²i ve kos do asných relácií, ktoré pouºívame na vyhodnotenie dotazu. Táto stratégia odráºa v²eobecný princíp optimaliza ných techník - vykonáva najskôr najúspornej²ie operácie. Zo základných vlastností relácií vyplýva v²eobecná selektivita joinov a cena agregácií zú astnených na dotaze. Hlavným princípom na²ej stratégie je práve porovnanie týchto dvoch veli ín vrámci nasledujúcich úvah: Joiny dvoch relácií, z ktorých aspo jedna je ve mi malá(toto íslo nie je presne ohrani ené, vo v²eobecnosti ide o po ty nepresahujúce jednu desiatku) sa dajú vä ²inou realizova ve mi efektívne. Pre potreby optimaliza ného algoritmu im prisúdime odhadovanú selektivitu 0.1. Joiny kone ných relácií s matematickými reláciami sú zvy ajne vysoko selektívne. Ich selektivitu aproximujeme nulou. 23
24 Moºno o akáva, ºe selektivita joinov na cudzí k ú je lep²ia ako bez prítomnosti cudzieho k ú a. Ke ºe riadok z relácie obsahujúcej cudzí k ú sa joinuje s maximálne jedným riadkom druhej relácie, selektivita daného joinu je ur ite men²ia ako 1. Algoritmus predpokladá selektivitu numericky 0.5. Ak existuje funk ná závislos medzi atribútmi joinujúcich relácií, potom tieto relácie pravdepodobne vznikli dekompozíciou inej relácie pomocou Join projecting mapping [01]. Pri takýchto joinoch je selektivita lep²ia neº pri klasických joinoch a moºno ju odhadnú podobne ako v predchádzajúcom prípade(bliº²ie v [06]). Klasické joiny bez dodato ných vlastností majú ve mi zlú o akávanú selektivitu. Táto selektivita bude navy²e tým hor²ia, ím menej joinovacích atribútov obsahujú. Algoritmus optimalizácie ju bude povaºova za 1. Úspora GP je zmen²ená o cenu výpo tu agregátov. Táto úspora bude teda s rastúcim po tom agregovaných atribútov klesa. Moºno predpoklada, ºe ím viac zoskupujúcich atribútov GP obsahuje, tým je jej úspora men²ia. Extrémnym prípadom je potom GP s vyºadovanými atribútmi zah ajúcimi v²etky atribúty relácie. Tento prípad je spomenutý aj v kapitole o zov²eobecnení operácií. Uvedené skuto nosti transformujeme na heuristiky, ktoré vyuºijeme pri kon²trukcii algoritmu optimalizácie: Pravidlo Joiny ve mi malých relácií vykonáva pred GP s agregovanými atribútmi. Pravidlo Joiny relácií, z ktorých aspo jedna je matematická vykonáva o najskôr(pred GP). Toto pravidlo je zhodné s pravidlom o v asnej realizácii selekcie z klasickej algebry. Pravidlo GP bez agregovaných atribútov vykonáva hne ako je to moºné, ale neaplikova na u skorú agregáciu. Pravidlo odráºa heuristiku klasickej algebry o skorej aplikácii projekcie. Pravidlo Joiny na cudzí k ú a joiny relácií vzniknutých dekompozíciou vykonáva pred klasickými joinami. Pokia je na výsledok joinu aplikovaná nejaká GP, uskuto níme zjednodu²enú skorú agregáciu. Konkrétne vezmime situáciu pre Eager transformácie 3 a 4. Ak má daný join uvedené vlastnosti, GP dekomponujeme len na vetvu vrámci relácie s agregovaným 24
25 atribútom a dodato nú GP. Zjednodu²ené verzie transformácií 3 a 4 potom vyzerajú nasledovne: resp. Γ C,E (R 1 R 2 ) Γ C,E (Γ B,C (R 1 ) R 2 ) agg(d) f(d) agg(d) Γ E,B,C agg(d) (R 1 R 2 ) Γ E,B,C (Γ B,C (R 1 ) R 2 ) f(d) agg(d) Pomocou tohto prístupu sa v prípade GP citlivých na duplicitu vyhneme aktualizácii m atribútu v relácii R 2, ktorá vzh adom na dobrú o akávanú selektivitu joinu výpo et len spomalí. Pravidlo Klasické joiny dostato ne ve kých relácií vykonáva o najneskôr, aplikova na zú astnené relácie skorú agregáciu pod a Transformácií vºdy, ke je to moºné. 4.2 Algoritmus optimalizácie Predstavíme realizáciu optimaliza ných pravidiel získaných pomocou teoretických úvah v podobe rule-based optimalizátora. V sú asnej praxi je pou- ºitie tohto typu optimalizátorov obmedzené, nako ko pre výrobcu databázy je výhodnej²ie h ada optimálne vykonanie operácií na základe ²pecických, platformovo závislých informácií, ako sú napr. rôzne ²tatistiky, ktoré si o reláciách databázový systém zaznamenáva. Tento prístup má v²ak jedno negatívum: pri h adaní optimálneho plánu vyhodnotenia treba navzájom porovnáva mnoho potenciálnych plánov, ktorých po et je vzh adom na po et relácií vstupujúcich do dotazu vo v²eobecnosti exponenciálny. Na odstránenie tohto neºiadúceho faktu slúºi práve navrhovaný optimalizátor. Ten zmen²í po et potenciálnych plánov vstupujúcich do cost-based optimalizátora a zna ným spôsobom tak urýchli celkový proces. Optimalizátor pritom berie do úvahy agregáciu a joiny, teda operácie, ktoré sa na celkovom ase vyhodnotenia podie ajú najvä ²ou as ou. Výstup rule-based optimalizátora bude okrem dodato ných informácií o prostredí databázy jediným vstupom pre cost-based fázu. Z tejto mnoºiny je potom cost-based procesom s oh adom na ²pecické prostredie databázy vybratý najoptimálnej²í plán, ktorý bude realizovaný. Pracovný graf dotazu - vstup algoritmu skon²truujeme spôsobom uvedeným v predo²lej kapitole. Na výstupe je mnoºina výrazov v modikovanej rela nej algebre s horeuvedenými vlastnos ami. Algoritmus(Rule-based optimalizácia) 25
26 INPUT : Naivný prepis SQL dotazu do rela nej algebry. OUTPUT : Mnoºina výrazov v modifikovanej algebre. (1) Transformuj zadaný výraz do modifikovanej algebry (2) Zostroj hypergraf tohto výrazu (3) Kým sa v pracovnom grafe nie o mení, opakuj pre v²etky grafy: (4) H adaj výskyty GP a aplikuj na ne transforma né pravidlá (5) Tranformáciou hypergrafov vyrob mnoºinu výrazov v algebre. (6) Na výrazy aplikuj transformácie (7) Vrá mnoºinu odvodených výrazov. Pri rule-based optimalizácii môºe v kroku (4) eventuelne nasta konikt pravidiel. Príkladom sú situácie výpo tu GP na joine malých relácií bez dodato ných vlastností alebo výpo tu GP s ve kým po tom agregujúcich atribútov na joine s prítomnos ou cudzieho k ú a/funk ných závislostí. V takomto prípade algoritmus vygeneruje dva grafy, kaºdý reprezentujúci výsledok aplikácie iného pravidla a pridá ich do mnoºiny pracovných grafov. Po aplikovaní transformácií v kroku (6) algoritmus pracuje stále s rovnakým po tom výrazov. Transformácie totiº vºdy znamenajú zrýchlenie výpo tu, pretoºe eliminujú zbyto né operácie. Nie je potrebné teda generova alternatívne plány. Pri kon²trukcii výrazu pre dotaz naráºame na klasický problém optimálneho vyhodnotenia joinov. Táto oblas je pomerne dobre preskúmaná a existuje nieko ko kvalitných algoritmov na ur enie poradia joinov. Mnohé z nich v²ak pracujú s reálnymi selektivitami a navy²e nezoh ad ujú prítomnos matematických relácií. Pre na²e ²pecické prostredie teda zvolíme inú metódu - pivotizáciu. Princíp tejto techniky je nasledovný: Na základe ur itých pravidiel vybra spomedzi sekvencie joinov jeden, nazvime ho pivot, ktorý sa vyhodnotí nakoniec. Pivot zárove rozdelí mnoºinu joinov na dve podmnoºiny, ktoré rekurzívne spracujeme. Ak sa v sekvencii nachádza len jediný join, je automaticky pivotom. Takýmto spôsobom pridávame do sekvencie zátvorky a ur ujeme poradie vyhodnotenia jednotlivých joinov. Príklad 4.1. Daný je výraz R 1 R 2 R 3 R 4 R 5. Za pivota zvo me R 2 R 3. Výraz sa transformuje na (R 1 R 2 ) (R 3 R 4 R 5 ). V avej vetve sme narazili na triviálny prípad a algoritmus tu kon í. Vrámci pravej vetvy vyberme R 3 R 4. Tým algoritmus kon í aj v tejto vetve a spracovaný výraz má tvar (R 1 R 2 ) (R 3 (R 4 R 5 )). Algoritmus je ur ený pre nerekurzívne dotazy, ktoré sú reprezentované acyklickým grafom. Pouºitie matematických relácií v²ak situáciu mení. Na 26
27 zabezpe enie korektnosti z poh adu dostupnosti vstupnej mnoºiny v ase joinovania s matematickou reláciou je potrebné ²peciálne poradie vyhodnotenia. Jedná sa o prípad, ke vstupná mnoºina nejakej matematickej relácie obsahuje dva atribúty vrámci dvoch rôznych relácií. V prípade, ºe takáto matematická relácia nie je sú as ou nejakého cyklu, je potrebné ho vyrobi pridaním ktívneho JP medzi relácie, ktoré obsahujú atribúty vstupnej mno- ºiny matematickej relácie. Ako bolo uº spomenuté, v²etky ktívne JP vyhodnocujeme metódou nested-loop. Okrem takto umelo vytvorených cyklov sa v grafe môºu nachádza aj cykly, ktoré vyplývajú z charakteru dotazu(príklad 4.2). Na kaºdom cykle v grafe sa teda podie a matematická relácia a to práve dvomi svojimi atribútmi. Algoritmus zabezpe í sprístupnenie vstupnej mno- ºiny pre nekone né relácie v cykle vyhodnotením joinov relácií obsahujúcich potrebné atribúty pred joinom s matematickou reláciou. Kvôli preh adnosti je as algoritmu venovaná detekcii cyklov oddelená od pivotizácie. Algoritmus(Transformácia hypergrafu) INPUT : Hypergraf dotazu v modifikovanej rela nej algebre. OUTPUT : Výraz modifikovanej algebry. GLOBAL : Mnoºina in²tancovaných atribútov (1) Nájdi matematickú reláciu s atribútmi vstupnej mnoºiny vrámci rôznych relácií R1, R2 mimo cyklu (2) Medzi R1, R2 pridaj fiktívny JP (3) Ak existuje v grafe cyklus (4) Identifikuj v om nekone nú reláciu R obsahujúcu 2 JP (5) Prstenec = transformuj zvy²ok cyklu (6) Rest = transformuj zvy²ok grafu (7) Vrá (R join Prstenec) join Rest (8) Inak pivotizáciou transformuj graf na výraz Kaºdý JP je reprezentovaný dvojicou (selektivita, zoznam joinujúcich relácií). V algoritme pivotizácie predpokladáme, ºe kaºdému JP prislúchajú práve dve relácie. V praxi sa v²ak môºe vyskytnú situácia s viacerými reláciami na jeden JP. Tento prípad redukujeme na predpokladaný nasledovne: Vykonáme pivotizáciu "v malom"na joinoch daného JP, pri om takto vznikne z pôvodného JP nieko ko nových JP, ktoré uº obsahujú len dve joinujúce relácie. Pre algoritmus pivotizácie sú k ú ové dva kroky: Výber pivota je v súlade s optimaliza nou stratégiou. To znamená, ºe za pivota vyberieme JP s najhor²ou odhadovanou selektivitou. V prípade nejednozna nosti vezmeme JP zah ajúci vä ²ie relácie. Táto heuristika 27
28 predpokladá, ºe vstupné relácie joinu so zlou selektivitou sa podarí aplikáciou selektívnej²ích joinov zmen²i. V prípade nejednozna nosti uprednost ujeme pri výbere pivota JP reprezentujúci join vä ²ích relácií a join nezah ajúci relácie obsahujúce vyºadované atribúty nejakej GP. Realizácia GP: Aby mohla by GP vykonaná, musia by k dispozícii v²etky vyºadované atribúty. Vrámci algoritmu je táto podmienka overovaná porovnaním mnoºiny vyºadovaných atribútov GP s mnoºinou in²tancovaných atribútov. Ak sú vyºadované atribúty uº in²tancované, je sémanticky korektné GP vykona. O optimálnosti tejto operácie v²ak rozhodnú aº pravidlá Algoritmus(Pivotizácia) INPUT : Acyklický hypergraf dotazu. OUTPUT : Výraz modifikovanej algebry. (01) Ak v grafe neexistuje JP (02) Result = jediná reláciu grafu R (03) Medzi in²tancované atribúty pridaj atribúty R (04) Inak (05) Nájdi pivotujúci JP J a ozna ho (06) R1 = prvá joinujúca relácia vrámci J (07) R2 = druhá joinujúca relácia vrámci J (08) Ak sa v grafe nachádza neozna ený JP (09) Result_R1 = transformuj podstrom zo strany R1 (10) Result_R2 = transformuj podstrom zo strany R2 (11) Inak (12) Medzi in²tancované atribúty pridaj atribúty R1, R2 (13) Ak na R1 existuje GP1, ktorú moºno vykona (14) Result_R1 = GP1(R1), inak Result_R1 = R1 (15) Ak na R2 existuje GP2, ktorú moºno vykona (16) Result_R2 = GP2(R2), inak Result_R2 = R2 (17) Result = (Result_R1) join (Result_R2) (18) Ak na Result existuje GP, ktorú moºno vykona (19) Result = GP(Result) (20) Vrá Result Tvrdenie: Mnoºina plánov generovaná rule-based optimalizáciou má nasledovné vlastnosti: 1. je konzervatívne ohrani ená, t.j. po et vygenerovaných plánov je asymptoticky men²í ako exponenciálny 28
29 2. obsahuje plán, ktorý nie je hor²í ako naivný plán získaný priamym prepisom SQL dotazu do rela nej algebry Po et výstupných plánov je ur ený mnoºstvom situácií, na ktorých vznikne pri rule-based optimalizácii v kroku (4) nejednozna nos. Tieto nastávajú pri aplikácii Transforma ných pravidiel, ktoré sa týkajú GP v grafe výrazu. V prevaºnej vä ²ine praktických dotazov je po et GP s agregovanými atribútmi zhora ohrani ený íslom log 2 (N), kde N je po et zú astnených relácií. Rádovo na to kých miestach teda algoritmus vygeneruje alternatívny plán. Tento fakt limituje mohutnos mnoºiny výstupných výrazov na lineárnu funkciu N. Optimaliza ná stratégia kladie dôraz na vyhodnotenie agregovaných atribútov, ktoré pri skúmaných dotazoch tvorí najvýznamnej²iu as výpo tu. Úspe²nos prístupu do zna nej miery závisí od ve kostí zú astnených tabuliek. V prípade, ºe dodato ná réºia skorej agregácie preváºi jej úsporu, priklá a sa optimalizátor ku klasickej(neskorej) variante výpo tu. Aplikácia skorej agregácie mení poradie joinov oproti klasickému plánu. Je preto potrebné zárove optimalizova aj túto as dotazu. Heuristika pivotizácie zoh ad uje dôleºité vlastnosti jednotlivých joinov, ako bolo spomenuté vy²²ie. Algoritmus pracujúci na základe týchto princípov má preto dobré predpoklady generova plány, ktoré sú minimálne tak dobré, ako klasické dotazy. 4.3 Príklady V nasledujúcich príkladoch ukáºeme fungovanie optimaliza ného algoritmu na nieko kých typických prípadoch dotazov. Príklad 4.2. Cie om príkladu je demon²trova prácu s matematickými reláciami. Daná je rela ná schéma R 1 (A, B); R 2 (B, C, D, E); R 3 (E, F, G); R 4 (H, I) kde B je cudzí k ú v R 2 a SQL dotaz SELECT E, max(f) FROM R 1, R 2, R 3, R 4 WHERE (R 1.B = R 2.B) AND (R 1.C + R 2.G < R 4.H) GROUP BY E Priamou transformáciou z naivného prepisu dotazu do klasickej rela nej algebry zapí²eme tento dotaz v modikovanej algebre ako Γ E max(f ) (R 1 R 2 R 3 Add Less R 4 ) 29
30 Okrem kone ných relácií sa vo výraze vyskytujú aj matematické relácie Add a Less. Prvá z nich je sú as ou cyklu, pod a toho teda algoritmus postupuje pri vyhodnotení. Kvôli Less musíme takýto cyklus vyrobi pridaním ktívneho JP Y (0, {Add, R 4 }). Ostatné JP sú: B(0.5, {R 1, R 2 }), C(0, {Add, R 2 }), E(1, {R 2, R 3 }), G(0, {Add, R 3 }), H(0, {Less, I}), X(0, {Less, Add}) R1 A B G X Add C D E R2 R3 F H Less I R4 Obrázok 6: Hypergraf dotazu k príkladu 4.2 Simulujme teraz Rule-based optimalizáciu na takomto grafe: Pod a Pravidla vykonáme skorú agregáciu Transformáciou Do grafu pribudne a ²ia GP - dodato né ur enie celkového maxima z parciálnych maxím jednotlivých zoskupení a výraz bude ma tvar Γ E max(f ) (R 1 R 2 (Γ E (R 3 )) Add Less R 4 ) max(f ) JP E nereprezentuje join na cudzí k ú, pôvodnú GP teda nemoºno odstráni. a ²ím krokom je vyhodnotenie cyklov: Γ E max(f ) (R 1 (((R 2 (Γ E (R 3 ))) Add) R 4 ) Less) max(f ) 30
31 Nakoniec procesom pivotizácie ur íme skoré vykonanie R 1 R 2, nako ko tento join má lep²iu selektivitu ako R 2 R 3. Poradie ostatných joinov je uº ur ené sémantickými ohrani eniami, výsledný výraz má teda tvar: Γ E max(f ) (((((R 1 R 2 ) (Γ E max(f ) (R 3 ))) Add) R 4 ) Less) Príklad 4.3. V tomto príklade sa zameráme na algoritmus pivotizácie. Daná je rela ná schéma R 1 (A, B, C); R 2 (C, D, E); R 3 (E, F, G, H); R 4 (G, I, J) kde E je cudzí k ú v R 3 a SQL dotaz SELECT G,I, sum(h) FROM R 1, R 2, R 3, R 4 WHERE (R 2.C = R 1.C) AND (R 2.E = R 3.E) AND (R 4.J < X) AND (R 1.A = Y ) GROUP BY G,I Eq R1 E F G H Y D R2 I R3 A B C J X R4 Less Obrázok 7: Hypergraf dotazu k príkladu 4.3 Po iato ným výrazom dotazu v modikovanej algebre je Γ G,I sum(h) ((Eq R 1 ) R 2 R 4 (Less R 3 )) Eq a Less sú pomocné matematické relácie testujúce R 1.A na rovnos a R 4.J na nerovnos s kon²tantou. V a ²om kroku algoritmus aplikuje na graf Transformáciu Po nej má zodpovedajúci výraz tvar Γ G,I sum(h ) ((Eq R 1 ) R 2 Γ E,G (R 4 ) Γ G,I (Less R 3 )) sum(h) m=count( ) 31
32 H = m H kvôli kompenzácii duplicitných riadkov, ktoré vznikli aplikáciou (Less R 3 ). Alternatívny výraz, v ktorom nie je potrebné zahrnú Γ G,I G,I multiplicitu riadkov: Γ G,I sum(h) ((Eq R 1 ) R 2 Γ E,G sum(h) (R 4 ) (Less R 3 )) Nakoniec procesom pivotizácie ur íme poradie vyhodnotenia joinov. Vzh adom na charakter jednotlivých joinov volíme za pivotov JP v nasledovnom poradí: Prvým pivotom je C, vo vetve R 1 je to potom automaticky A. Vo vetve R 2 vyberieme za pivota G, výber E a J je alej jednozna ný. Po vyhodnotení poradia joinov potom získame nasledovné výstupné výrazy, z ktorých cost-based optimalizátor vyberie lep²í Γ G,I sum(m H) Γ ((Eq R 1 ) ((R 2 Γ E,G (R 4 )) Γ G,I (Less R 3 ))) sum(h) m=count( ) G,I sum(h) ((Eq R 1 ) ((R 2 Γ E,G sum(h) (R 4 )) (Less R 3 ))) Reálny prínos optimalizácie teraz demon²trujeme zjednodu²enou analýzou niektorých dotazov z praxe. Príklad 4.4. Daná je rela ná schéma Objednavka(idProd,idPred,mnozstvo); Predajca(id,mesto); Produkt(id,oddelenie); kde idprod a idpred sú cudzími k ú mi v relácii Objednavka a dotaz SELECT idprod,idpred,sum(mnozstvo) FROM Objdenavka, Predajca, Produkt WHERE (Predajca.mesto='Bratislava') AND (Produkt.oddelenie='Doprava') AND (Objednávka.idProd=Produkt.id) AND (Objednávka.idPred=Predajca.id) GRUP BY idprod,idpred Klasický spôsob vyhodnotenia je Γ sum(mnozstvo) ((P redajca P rodukt) Objednavka) idp rod,idp red s príslu²nými selekciami realizovanými pred jednotlivými joinami. Vezmime praktickú situáciu, ºe relácia Objednavka je omnoho va ²ia ako relácie Produkt a Predajca (ve kosti sú typicky rádovo postupne 10 5, 10 2, 10 1 ). Ke ºe sú na to splnené v²etky podmienky, môºeme aplikova Transformáciu
33 a výpo et grúp vykona na relácii Objednavka pred joinami s reláciami Predajca a Produkt (Γ sum(mnozstvo) (Objednavka) P redajca) P rodukt idp rod,idp red Nako ko relácia Predajca je relatívne malá, dostávame pomocou pivotizácie a Pravidla alternatívny plán Γ sum(mnozstvo) (Objednavka) (P redajca P rodukt) idp rod,idp red Pretoºe relácie Predajca a Produkt sú oproti relácii Objednavka o nieko ko rádov men²ie, skorá agregácia prinesie zlep²enie asu výpo tu. Konkrétne, v relácii Objednavka sa môºe nachádza rádovo maximálne = 10 3 záznamov s rôznou hodnotou atribútov idprod alebo idpred. To pod a Dirichletovho princípu znamená, ºe aplikovaním skorej agregácie sa táto relácia zmen²í minimálne 100-násobne. Takéto zmen²enie s najvä ²ou pravdepodobnos ou preváºi selektivitu joinov s reláciami Predajca resp. Produkt. Optimálnos jednotlivých plánov potom záleºí od reálnych selektivít daných joinov. Príklad 4.5. Majme teraz nasledovnú rela nú schému: Objednavka(idProd,idPred,mnozstvo); Produkt(id,idOdd); Oddelenie(id,idSek); s ve kos ami relácií rádovo 10 5, 10 2, 10 1 záznamov a nad ou dotaz SELECT idprod,idsek,idodd,sum(mnozstvo) FROM Oddelenie,Objednavka,Produkt WHERE (Objednavka.idProd=Produkt.id) AND (Produkt.idOdd=Oddelenie.id) AND(Objednavka.idPred='3') GROUP BY idprod,idsek,idodd Klasický plán vyhodnotenia bez oh adu na selekcie(kvôli jednoduchosti) je Γ sum(mnozstvo) idp rod,idsek,idodd ((Objednavka (P rodukt Oddelenie)) Ak chceme pouºi skorú agregáciu v tomto prípade, musíme ju najskôr rozdeli do kaskády pod a Tranasfomácie Po vykonaní rule-based optimalizácie budeme ma potom k dispozícii nasledovné plány: Γ sum(mnozstvo) (Γ sum(mnozstvo) idp rod,idsek,idodd idp rod,idodd (Γ sum(mnozstvo) (Objednavka) P rodukt) Oddelenie) idp rod 33
Motivácia Denícia determinantu Výpo et determinantov Determinant sú inu matíc Vyuºitie determinantov. Determinanty. 14. decembra 2010.
14. decembra 2010 Rie²enie sústav Plocha rovnobeºníka Objem rovnobeºnostena Rie²enie sústav Príklad a 11 x 1 + a 12 x 2 = c 1 a 21 x 1 + a 22 x 2 = c 2 Dostaneme: x 1 = c 1a 22 c 2 a 12 a 11 a 22 a 12
Matematika Funkcia viac premenných, Parciálne derivácie
Matematika 2-01 Funkcia viac premenných, Parciálne derivácie Euklidovská metrika na množine R n všetkých usporiadaných n-íc reálnych čísel je reálna funkcia ρ: R n R n R definovaná nasledovne: Ak X = x
Cvičenie č. 4,5 Limita funkcie
Cvičenie č. 4,5 Limita funkcie Definícia ity Limita funkcie (vlastná vo vlastnom bode) Nech funkcia f je definovaná na nejakom okolí U( ) bodu. Hovoríme, že funkcia f má v bode itu rovnú A, ak ( ε > )(
Ekvačná a kvantifikačná logika
a kvantifikačná 3. prednáška (6. 10. 004) Prehľad 1 1 (dokončenie) ekvačných tabliel Formula A je ekvačne dokázateľná z množiny axióm T (T i A) práve vtedy, keď existuje uzavreté tablo pre cieľ A ekvačných
Eulerovské grafy. Príklad Daný graf nie je eulerovský, ale obsahuje eulerovskú cestu (a, ab, b, bc, c, cd, d, da, a, ac, c, ce, e, ed, d, db).
Eulerovské grafy Denícia Nech G = (V, E) je graf. Uzavretý ah v G sa nazýva eulerovská kruºnica, ak obsahuje v²etky hrany G. Otvorený ah obsahujúci v²etky hrany grafu sa nazýva eulerovská cesta. Graf sa
Katedra matematiky Fakulta elektrotechniky a informatiky
Katedra matematiky Fakulta elektrotechniky a informatiky Technická univerzita v Ko²iciach GRAFOVÉ ALGORITMY A FORMÁLNA LOGIKA Marián Kle², Ján Plavka Ko²ice 2008 RECENZOVALI: RNDr. Vladimír Lacko, PhD.
6 Limita funkcie. 6.1 Myšlienka limity, interval bez bodu
6 Limita funkcie 6 Myšlienka ity, interval bez bodu Intuitívna myšlienka ity je prirodzená, ale definovať presne pojem ity je značne obtiažne Nech f je funkcia a nech a je reálne číslo Čo znamená zápis
ARMA modely čast 2: moving average modely (MA)
ARMA modely čast 2: moving average modely (MA) Beáta Stehlíková Časové rady, FMFI UK, 2014/2015 ARMA modely časť 2: moving average modely(ma) p.1/24 V. Moving average proces prvého rádu - MA(1) ARMA modely
Start. Vstup r. O = 2*π*r S = π*r*r. Vystup O, S. Stop. Start. Vstup P, C V = P*C*1,19. Vystup V. Stop
1) Vytvorte algoritmus (vývojový diagram) na výpočet obvodu kruhu. O=2xπxr ; S=πxrxr Vstup r O = 2*π*r S = π*r*r Vystup O, S 2) Vytvorte algoritmus (vývojový diagram) na výpočet celkovej ceny výrobku s
Goniometrické rovnice a nerovnice. Základné goniometrické rovnice
Goniometrické rovnice a nerovnice Definícia: Rovnice (nerovnice) obsahujúce neznámu x alebo výrazy s neznámou x ako argumenty jednej alebo niekoľkých goniometrických funkcií nazývame goniometrickými rovnicami
7. FUNKCIE POJEM FUNKCIE
7. FUNKCIE POJEM FUNKCIE Funkcia f reálnej premennej je : - každé zobrazenie f v množine všetkých reálnych čísel; - množina f všetkých usporiadaných dvojíc[,y] R R pre ktorú platí: ku každému R eistuje
Maticové hry. doc. RNDr. tefan Pe²ko. 9. marca Katedra matematických metód a opera nej analýzy, FRI šu
Katedra matematických metód a opera nej analýzy, FRI šu 9. marca 2018 Antagonistický konikt dvoch hrá ov s kone nými priestormi stratégií modeluje maticová hra. Denícia 3.1 Kone nú hra s nulovým sú tom
Matematika prednáška 4 Postupnosti a rady 4.5 Funkcionálne rady - mocninové rady - Taylorov rad, MacLaurinov rad
Matematika 3-13. prednáška 4 Postupnosti a rady 4.5 Funkcionálne rady - mocninové rady - Taylorov rad, MacLaurinov rad Erika Škrabul áková F BERG, TU Košice 15. 12. 2015 Erika Škrabul áková (TUKE) Taylorov
Obvod a obsah štvoruholníka
Obvod a štvoruholníka D. Štyri body roviny z ktorých žiadne tri nie sú kolineárne (neležia na jednej priamke) tvoria jeden štvoruholník. Tie body (A, B, C, D) sú vrcholy štvoruholníka. strany štvoruholníka
Základy automatického riadenia
Základy automatického riadenia Predná²ka 6 doc. Ing. Anna Jadlovská, PhD., doc. Ing. Ján Jadlovský, CSc. Katedra kybernetiky a umelej inteligencie Fakulta elektrotechniky a informatiky Technická univerzita
ARMA modely čast 2: moving average modely (MA)
ARMA modely čast 2: moving average modely (MA) Beáta Stehlíková Časové rady, FMFI UK, 2011/2012 ARMA modely časť 2: moving average modely(ma) p.1/25 V. Moving average proces prvého rádu - MA(1) ARMA modely
Jednotkový koreň (unit root), diferencovanie časového radu, unit root testy
Jednotkový koreň (unit root), diferencovanie časového radu, unit root testy Beáta Stehlíková Časové rady, FMFI UK, 2012/2013 Jednotkový koreň(unit root),diferencovanie časového radu, unit root testy p.1/18
Pravdepodobnos a ²tatistika (1-INF-435) Poznámky k predná²kam. Radoslav Harman, KAM, FMFI UK
Pravdepodobnos a ²tatistika (1-INF-435) Poznámky k predná²kam Radoslav Harman, KAM, FMFI UK 15. januára 2014 Obsah 1 Úvod 3 2 Axiomatická denícia pravdepodobnosti 3 2.1 Priestor udalostí..................................
Hry N hrá ov. doc. RNDr. tefan Pe²ko. April 9, Katedra matematických metód a opera nej analýzy, FRI šu
Katedra matematických metód a opera nej analýzy, FRI šu April 9, 2018 Budeme predpoklada, ºe kaºdý z N hrá ov (N 2) je inteligentný hrá. Najskôr za budeme zaobera nekooperativnymi hrami, v ktorých hrá
PRUŽNOSŤ A PEVNOSŤ PRE ŠPECIÁLNE INŽINIERSTVO
ŽILINSKÁ UNIVERZITA V ŽILINE Fakulta špeciálneho inžinierstva Doc. Ing. Jozef KOVAČIK, CSc. Ing. Martin BENIAČ, PhD. PRUŽNOSŤ A PEVNOSŤ PRE ŠPECIÁLNE INŽINIERSTVO Druhé doplnené a upravené vydanie Určené
Metódy vol nej optimalizácie
Metódy vol nej optimalizácie Metódy vol nej optimalizácie p. 1/28 Motivácia k metódam vol nej optimalizácie APLIKÁCIE p. 2/28 II 1. PRÍKLAD: Lineárna regresia - metóda najmenších štvorcov Na základe dostupných
M6: Model Hydraulický systém dvoch zásobníkov kvapaliny s interakciou
M6: Model Hydraulický ytém dvoch záobníkov kvapaliny interakciou Úlohy:. Zotavte matematický popi modelu Hydraulický ytém. Vytvorte imulačný model v jazyku: a. Matlab b. imulink 3. Linearizujte nelineárny
Moderné vzdelávanie pre vedomostnú spoločnosť Projekt je spolufinancovaný zo zdrojov EÚ M A T E M A T I K A
M A T E M A T I K A PRACOVNÝ ZOŠIT II. ROČNÍK Mgr. Agnesa Balážová Obchodná akadémia, Akademika Hronca 8, Rožňava PRACOVNÝ LIST 1 Urč typ kvadratickej rovnice : 1. x 2 3x = 0... 2. 3x 2 = - 2... 3. -4x
Úvod do lineárnej algebry. Monika Molnárová Prednášky
Úvod do lineárnej algebry Monika Molnárová Prednášky 2006 Prednášky: 3 17 marca 2006 4 24 marca 2006 c RNDr Monika Molnárová, PhD Obsah 2 Sústavy lineárnych rovníc 25 21 Riešenie sústavy lineárnych rovníc
1. Limita, spojitost a diferenciálny počet funkcie jednej premennej
. Limita, spojitost a diferenciálny počet funkcie jednej premennej Definícia.: Hromadný bod a R množiny A R: v každom jeho okolí leží aspoň jeden bod z množiny A, ktorý je rôzny od bodu a Zadanie množiny
Nekone ný antagonistický konikt
Katedra matematických metód, FRI šu 12. apríl 2012 V al²om výklade sa obmedzíme na také hry dvoch hrá ov H 0, v ktorých sú priestory stratégií hrá ov nekone né mnoºiny. Takýto prístup je výhodný aj v pripadoch
Prechod z 2D do 3D. Martin Florek 3. marca 2009
Počítačová grafika 2 Prechod z 2D do 3D Martin Florek florek@sccg.sk FMFI UK 3. marca 2009 Prechod z 2D do 3D Čo to znamená? Ako zobraziť? Súradnicové systémy Čo to znamená? Ako zobraziť? tretia súradnica
Pavol Jozef afárik University in Ko²ice Faculty of Science. Testovanie a verikácia programov Floydova metóda Gabriela Andrejková
Pavol Jozef afárik University in Ko²ice Faculty of Science Testovanie a verikácia programov Floydova metóda Gabriela Andrejková Pri dokazovaní správnosti programov je potrebné ma ²pecikované: a) programovací
3. kapitola. Axiomatická formulácia modálnej logiky Vzťah medzi syntaxou a sémantikou. priesvitka 1
3. kapitola Axiomatická formulácia modálnej logiky Vzťah medzi syntaxou a sémantikou priesvitka 1 Axiomatická výstavba modálnej logiky Cieľom tejto prednášky je ukázať axiomatickú výstavbu rôznych verzií
Motivácia pojmu derivácia
Derivácia funkcie Motivácia pojmu derivácia Zaujíma nás priemerná intenzita zmeny nejakej veličiny (dráhy, rastu populácie, veľkosti elektrického náboja, hmotnosti), vzhľadom na inú veličinu (čas, dĺžka)
Gramatická indukcia a jej využitie
a jej využitie KAI FMFI UK 29. Marec 2010 a jej využitie Prehľad Teória formálnych jazykov 1 Teória formálnych jazykov 2 3 a jej využitie Na počiatku bolo slovo. A slovo... a jej využitie Definícia (Slovo)
MATEMATIKA I. Základy diferenciálneho počtu. Návody k cvičeniam pre odbory VSVH a STOP. Andrea Stupňanová, Alexandra Šipošová
MATEMATIKA I. Základy diferenciálneho počtu Návody k cvičeniam pre odbory VSVH a STOP Andrea Stupňanová, Alexandra Šipošová MATEMATIKA I. Základy diferenciálneho počtu Návody k cvičeniam pre odbory VSVH
Demonstrační aplikace vyhodnocování dotazu v relačnej algebre
Univerzita Karlova v Praze Matematicko-fyzikální fakulta BAKALÁRSKA PRÁCA Martin Lysík Demonstrační aplikace vyhodnocování dotazu v relačnej algebre Katedra softwarového inženýrství Vedúci bakalárskej
IV Paralelné a distribuované výpo ty. Dana Pardubská
IV 100 - Paralelné a distribuované výpo ty Dana Pardubská 2 Obsah 1 Model distribuovaných výpo tov 7 1.1 Formálny popis...................................... 7 1.2 Overovanie vlastností prechodových systémov.....................
DIPLOMOVÁ PRÁCE. Monika Jakubcová Míry ecience portfolia vzhledem k stochastické dominanci
Univerzita Karlova v Praze Matematicko-fyzikální fakulta DIPLOMOVÁ PRÁCE Monika Jakubcová Míry ecience portfolia vzhledem k stochastické dominanci Katedra pravd podobnosti a matematické statistiky Vedoucí
Základy automatického riadenia
Základy automatického riadenia Predná²ka 9 doc. Ing. Anna Jadlovská, PhD., doc. Ing. Ján Jadlovský, CSc. Katedra kybernetiky a umelej inteligencie Fakulta elektrotechniky a informatiky Technická univerzita
Kompilátory. Cvičenie 6: LLVM. Peter Kostolányi. 21. novembra 2017
Kompilátory Cvičenie 6: LLVM Peter Kostolányi 21. novembra 2017 LLVM V podstate sada nástrojov pre tvorbu kompilátorov LLVM V podstate sada nástrojov pre tvorbu kompilátorov Pôvodne Low Level Virtual Machine
Tomáš Madaras Prvočísla
Prvočísla Tomáš Madaras 2011 Definícia Nech a Z. Čísla 1, 1, a, a sa nazývajú triviálne delitele čísla a. Cele číslo a / {0, 1, 1} sa nazýva prvočíslo, ak má iba triviálne delitele; ak má aj iné delitele,
Podnikateľ 90 Mobilný telefón Cena 95 % 50 % 25 %
Podnikateľ 90 Samsung S5230 Samsung C3530 Nokia C5 Samsung Shark Slider S3550 Samsung Xcover 271 T-Mobile Pulse Mini Sony Ericsson ZYLO Sony Ericsson Cedar LG GM360 Viewty Snap Nokia C3 Sony Ericsson ZYLO
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY NOVÁ METÓDA KONJUGOVANÝCH GRADIENTOV BAKALÁRSKA PRÁCA 2012 Marián PITONIAK UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY,
KATEDRA DOPRAVNEJ A MANIPULAČNEJ TECHNIKY Strojnícka fakulta, Žilinská Univerzita
132 1 Absolútna chyba: ) = - skut absolútna ochýlka: ) ' = - spr. relatívna chyba: alebo Chyby (ochýlky): M systematické, M náhoné, M hrubé. Korekcia: k = spr - = - Î' pomerná korekcia: Správna honota:
7 Derivácia funkcie. 7.1 Motivácia k derivácii
Híc, P Pokorný, M: Matematika pre informatikov a prírodné vedy 7 Derivácia funkcie 7 Motivácia k derivácii S využitím derivácií sa stretávame veľmi často v matematike, geometrii, fyzike, či v rôznych technických
,Zohrievanie vody indukčným varičom bez pokrievky,
Farba skupiny: zelená Označenie úlohy:,zohrievanie vody indukčným varičom bez pokrievky, Úloha: Zistiť, ako závisí účinnosť zohrievania vody na indukčnom variči od priemeru použitého hrnca. Hypotéza: Účinnosť
Markovove procesy. Teória hromadnej obsluhy. doc. RNDr. tefan Pe²ko, CSc. 17. októbra Katedra matematických metód, FRI šu
Teória hromadnej obsluhy Katedra matematických metód, FRI šu 17. októbra 2013 Náhodný re azec {X(t)} t T s mnoºinou stavov S nazveme Markovov proces, ak 1 mnoºina T = 0, ), 2 platí Markovova vlastnos :
Základy automatického riadenia
Základy automatického riadenia Predná²ka 8 doc. Ing. Anna Jadlovská, PhD., doc. Ing. Ján Jadlovský, CSc. Katedra kybernetiky a umelej inteligencie Fakulta elektrotechniky a informatiky Technická univerzita
3. Striedavé prúdy. Sínusoida
. Striedavé prúdy VZNIK: Striedavý elektrický prúd prechádza obvodom, ktorý je pripojený na zdroj striedavého napätia. Striedavé napätie vyrába synchrónny generátor, kde na koncoch rotorového vinutia sa
1. písomná práca z matematiky Skupina A
1. písomná práca z matematiky Skupina A 1. Vypočítajte : a) 84º 56 + 32º 38 = b) 140º 53º 24 = c) 55º 12 : 2 = 2. Vypočítajte zvyšné uhly na obrázku : β γ α = 35 12 δ a b 3. Znázornite na číselnej osi
24. Základné spôsoby zobrazovania priestoru do roviny
24. Základné spôsoby zobrazovania priestoru do roviny Voľné rovnobežné premietanie Presné metódy zobrazenia trojrozmerného priestoru do dvojrozmernej roviny skúma samostatná matematická disciplína, ktorá
Goniometrické substitúcie
Goniometrické substitúcie Marta Kossaczká S goniometrickými funkciami ste sa už určite stretli, pravdepodobne predovšetkým v geometrii. Ich použitie tam ale zďaleka nekončí. Nazačiatoksizhrňme,čoonichvieme.Funkciesínusakosínussadajúdefinovať
METÓDY VNÚTORNÉHO BODU VO FINANƒNÝCH MODELOCH DIPLOMOVÁ PRÁCA
Fakulta matematiky, fyziky a informatiky Univerzity Komenského v Bratislave Katedra aplikovanej matematiky a ²tatistiky METÓDY VNÚTORNÉHO BODU VO FINANƒNÝCH MODELOCH DIPLOMOVÁ PRÁCA 2006 Václav Kolátor
Zbierka rie²ených úloh z matematickej fyziky
Zbierka rie²ených úloh z matematickej fyziky Milan šukovi 22. novembra 2009 2 Obsah Komplexné ísla. Úvod.................................................................2 Úlohy...............................................................
Komplexné čísla, Diskrétna Fourierova transformácia 1
Komplexné čísla, Diskrétna Fourierova transformácia Komplexné čísla C - množina všetkých komplexných čísel komplexné číslo: z = a + bi, kde a, b R, i - imaginárna jednotka i =, t.j. i =. komplexne združené
MATEMATIKA. Martin Kalina
MATEMATIKA Martin Kalina Slovenská technická univerzita v Bratislave Všetky práva vyhradené. Nijaká časť textu nesmie byť použitá na ďalšie šírenie akoukoľvek formou bez predchádzajúceho súhlasu autorov
9. kapitola Boolove funkcie a logické obvody
9. kapitola Boolove funkcie a logické obvody Priesvitka 1 Boolova algebra Elektronické obvody v počítačoch a v podobných zariadeniach sú charakterizované binárnymi vstupmi a výstupmi (rovnajúcimi sa 0
Jednotkový koreň (unit root), diferencovanie časového radu, unit root testy
Jednotkový koreň (unit root), diferencovanie časového radu, unit root testy Beáta Stehlíková Časové rady, FMFI UK, 2013/2014 Jednotkový koreň(unit root),diferencovanie časového radu, unit root testy p.1/27
Ako si nájs chybu? o a ako sa pýta výsledkov
o a ako sa pýta výsledkov Katedra teoretickej fyziky a didaktitky fyziky FMFI, UK Letná ²kola FKS/TMF 29.7.2016 Keby ste sa nudili Túto prezentáciu a mnoºstvo al²ích príkladov nájdete na davinci.fmph.uniba.sk/
Návrh vzduchotesnosti pre detaily napojení
Výpočet lineárneho stratového súčiniteľa tepelného mosta vzťahujúceho sa k vonkajším rozmerom: Ψ e podľa STN EN ISO 10211 Návrh vzduchotesnosti pre detaily napojení Objednávateľ: Ing. Natália Voltmannová
Matematika 2. časť: Analytická geometria
Matematika 2 časť: Analytická geometria RNDr. Jana Pócsová, PhD. Ústav riadenia a informatizácie výrobných procesov Fakulta BERG Technická univerzita v Košiciach e-mail: jana.pocsova@tuke.sk Súradnicové
Planárne a rovinné grafy
Planárne a rovinné grafy Definícia Graf G sa nazýva planárny, ak existuje jeho nakreslenie D, v ktorom sa žiadne dve hrany nepretínajú. D sa potom nazýva rovinný graf. Planárne a rovinné grafy Definícia
VLASTNÉ ČÍSLA A JORDANOV KANONICKÝ TVAR. Michal Zajac. 3 T b 1 = T b 2 = = = 2b
VLASTNÉ ČÍSLA A JORDANOV KANONICKÝ TVAR Michal Zajac Vlastné čísla a vlastné vektory Pripomeňme najprv, že lineárny operátor T : L L je vzhl adom na bázu B = {b 1, b 2,, b n } lineárneho priestoru L určený
4. Výrokové funkcie (formy), ich definičný obor a obor pravdivosti
4. Výrokové funkcie (formy), ich definičný obor a obor pravdivosti Výroková funkcia (forma) ϕ ( x) je formálny výraz (formula), ktorý obsahuje znak x, pričom x berieme z nejakej množiny M. Ak za x zvolíme
RIEŠENIE WHEATSONOVHO MOSTÍKA
SNÁ PMYSLNÁ ŠKOL LKONKÁ V PŠŤNO KOMPLXNÁ PÁ Č. / ŠN WSONOVO MOSÍK Piešťany, október 00 utor : Marek eteš. Komplexná práca č. / Strana č. / Obsah:. eoretický rozbor Wheatsonovho mostíka. eoretický rozbor
2. prednáška. Teória množín I. množina operácie nad množinami množinová algebra mohutnosť a enumerácia karteziánsky súčin
2. prednáška Teória množín I množina operácie nad množinami množinová algebra mohutnosť a enumerácia karteziánsky súčin Verzia: 27. 9. 2009 Priesvtika: 1 Definícia množiny Koncepcia množiny patrí medzi
ZADANIE 1_ ÚLOHA 3_Všeobecná rovinná silová sústava ZADANIE 1 _ ÚLOHA 3
ZDNIE _ ÚLOH 3_Všeobecná rovinná silová sústv ZDNIE _ ÚLOH 3 ÚLOH 3.: Vypočítjte veľkosti rekcií vo väzbách nosník zťženého podľ obrázku 3.. Veľkosti známych síl, momentov dĺžkové rozmery sú uvedené v
Pevné ložiská. Voľné ložiská
SUPPORTS D EXTREMITES DE PRECISION - SUPPORT UNIT FOR BALLSCREWS LOŽISKA PRE GULIČKOVÉ SKRUTKY A TRAPÉZOVÉ SKRUTKY Výber správnej podpory konca uličkovej skrutky či trapézovej skrutky je dôležité pre správnu
Priamkové plochy. Ak každým bodom plochy Φ prechádza aspoň jedna priamka, ktorá (celá) na nej leží potom plocha Φ je priamková. Santiago Calatrava
Priamkové plochy Priamkové plochy Ak každým bodom plochy Φ prechádza aspoň jedna priamka, ktorá (celá) na nej leží potom plocha Φ je priamková. Santiago Calatrava Priamkové plochy rozdeľujeme na: Rozvinuteľné
Príklady na precvičovanie Fourierove rady
Príklady na precvičovanie Fourierove rady Ďalším významným typom funkcionálnych radov sú trigonometrické rady, pri ktorých sú jednotlivé členy trigonometrickými funkciami. Konkrétne, jedná sa o rady tvaru
Funkcie - základné pojmy
Funkcie - základné pojmy DEFINÍCIA FUNKCIE Nech A, B sú dve neprázdne číselné množiny. Ak každému prvku x A je priradený najviac jeden prvok y B, tak hovoríme, že je daná funkcia z množiny A do množiny
3. prednáška. Komplexné čísla
3. predáška Komplexé čísla Úvodé pozámky Vieme, že existujú také kvadratické rovice, ktoré emajú riešeie v obore reálych čísel. Študujme kvadratickú rovicu x x + 5 = 0 Použitím štadardej formule pre výpočet
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY KALIBRÁCIA JEDNOFAKTOROVÉHO MODELU ÚROKOVÝCH MIER POMOCOU VIACERÝCH KRITÉRIÍ DIPLOMOVÁ PRÁCA Bratislava 2015 Bc. Martin ƒechvala
vypilo_sa(k, A, S, I) navstivil(i, _, K), vypil(i, A, M), capuje(k, A, C), S is M * C. /* S = M * C */
4/1/2011 Úvod do databáz, skúškový test, max 25 bodov, 90 min 1. Daná je databáza: capuje(krcma, Alkohol, Cena), lubi(pijan, Alkohol) navstivil(idn, Pijan, Krcma), vypil(idn, Alkohol, Mnozstvo). Platí:
Siete jednosmerného prúdu alebo 77 odporných príkladov
Siete jednosmerného prúdu alebo 77 odporných príkladov Juraj Tekel Katedra teoretickej fyziky a didaktiky fyziky FMFI UK Mlynska Dolina 842 48 Bratislava juraj(a)tekel(b)gmail(c)com http://fks.sk/~juro/phys_materials.html
Meranie na jednofázovom transformátore
Fakulta elektrotechniky a informatiky TU v Košiciach Katedra elektrotechniky a mechatroniky Meranie na jednofázovom transformátore Návod na cvičenia z predmetu Elektrotechnika Meno a priezvisko :..........................
Chí kvadrát test dobrej zhody. Metódy riešenia úloh z pravdepodobnosti a štatistiky
Chí kvadrát test dobrej zhody Metódy riešenia úloh z pravdepodobnosti a štatistiky www.iam.fmph.uniba.sk/institute/stehlikova Test dobrej zhody I. Chceme overiť, či naše dáta pochádzajú z konkrétneho pravdep.
Nám z DBS manuál nestačí I. ( neoficiálne skriptá pre zimný semester Databázových systémov
Prírodovedecká fakulta UPJŠ Košice Nám z DBS manuál nestačí I. ( neoficiálne skriptá pre zimný semester Databázových systémov prednáša: RNDr. Stanislav Krajči, PhD. ) IMPRIMATUR Košice, 7. mája 2002 RNDr.
Úvod do lineárnej algebry
Katedra matematiky Fakulta elektrotechniky a informatiky Technická Univerzita v Košiciach Úvod do lineárnej algebry Monika Molnárová, Helena Myšková 005 RECENZOVALI: RNDr. Štefan Schrötter, CSc. RNDr.
Obsah. 1.1 Reálne čísla a ich základné vlastnosti... 7 1.1.1 Komplexné čísla... 8
Obsah 1 Číselné obory 7 1.1 Reálne čísla a ich základné vlastnosti............................ 7 1.1.1 Komplexné čísla................................... 8 1.2 Číselné množiny.......................................
FUNKCIE N REÁLNYCH PREMENNÝCH
FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY UNIVERZITY KOMENSKÉHO V BRATISLAVE FUNKCIE N REÁLNYCH PREMENNÝCH RNDr. Kristína Rostás, PhD. PREDMET: Matematická analýza ) 2010/2011 1. DEFINÍCIA REÁLNEJ FUNKCIE
AerobTec Altis Micro
AerobTec Altis Micro Záznamový / súťažný výškomer s telemetriou Výrobca: AerobTec, s.r.o. Pionierska 15 831 02 Bratislava www.aerobtec.com info@aerobtec.com Obsah 1.Vlastnosti... 3 2.Úvod... 3 3.Princíp
x x x2 n
Reálne symetrické matice Skalárny súčin v R n. Pripomeniem, že pre vektory u = u, u, u, v = v, v, v R platí. dĺžka vektora u je u = u + u + u,. ak sú oba vektory nenulové a zvierajú neorientovaný uhol
9. kapitola. Viachodnotové logiky trojhodnotová Łukasiewiczova logika a Zadehova fuzzy logika. priesvitka
9. kapitola Viachodnotové logiky trojhodnotová Łukasiewiczova logika a Zadehova fuzzy logika 1 Úvodné poznámky o viachodnotových logikách V klasickej logike existujú prípady, keď dichotomický pravdivostný
MOSTÍKOVÁ METÓDA 1.ÚLOHA: 2.OPIS MERANÉHO PREDMETU: 3.TEORETICKÝ ROZBOR: 4.SCHÉMA ZAPOJENIA:
1.ÚLOHA: MOSTÍKOVÁ METÓDA a, Odmerajte odpory predložených rezistorou pomocou Wheastonovho mostíka. b, Odmerajte odpory predložených rezistorou pomocou Mostíka ICOMET. c, Odmerajte odpory predložených
1. písomná práca z matematiky Skupina A. 1. písomná práca z matematiky Skupina B
. písoá pác z tetik Skpi A. Zjedodšte výz : ) z 8 ) c). Doplňte, pltil ovosť : ) ). Vpočítjte : ) ) c). Vpočítjte : ) ( ) ) v v v c). Upvte výz ovete spávosť výsledk pe : 6. Zostojte tojholík ABC, k c
Riešenie cvičení z 5. kapitoly
Riešenie cvičení z 5. kapitoly Cvičenie 5.1. Vety prepíšte pomocou jazyka predikátovej logiky, použite symboly uvedené v úlohách. (a Niekto má hudobný sluch (H a niekto ho nemá. ( H( ( H( (b Niektoré dieťa
STRIEDAVÝ PRÚD - PRÍKLADY
STRIEDAVÝ PRÚD - PRÍKLADY Príklad0: V sieti je frekvencia 50 Hz. Vypočítajte periódu. T = = = 0,02 s = 20 ms f 50 Hz Príklad02: Elektromotor sa otočí 50x za sekundu. Koľko otáčok má za minútu? 50 Hz =
Derivácia funkcie. Pravidlá derivovania výrazov obsahujúcich operácie. Derivácie elementárnych funkcií
Derivácia funkcie Derivácia funkcie je jeden z najužitočnejších nástrojov, ktoré používame v matematike a jej aplikáciách v ďalších odboroch. Stručne zhrnieme základné informácie o deriváciách. Podrobnejšie
MIDTERM (A) riešenia a bodovanie
MIDTERM (A) riešenia a bodovanie 1. (7b) Nech vzhl adom na štandardnú karteziánsku sústavu súradníc S 1 := O, e 1, e 2 majú bod P a vektory u, v súradnice P = [0, 1], u = e 1, v = 2 e 2. Aký predpis bude
Vybrané partie z logiky
FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY UNIVERZITY KOMENSKÉHO Katedra informatiky Vybrané partie z logiky poznámky z prednášok martin florek 22. mája 2004 Predhovor Vďaka nude a oprášeniu vedomostí z
Implementace vybraných databázových
Univerzita Karlova v Praze Matematicko-fyzikální fakulta DIPLOMOVÁ PRÁCE Ján Majdan Implementace vybraných databázových operací v paralelním prostředí Katedra softwarového inženýrství Vedoucí diplomové
Riešenie sústavy lineárnych rovníc. Priame metódy.
Riešenie sústavy lineárnych rovníc. Priame metódy. Ing. Gabriel Okša, CSc. Matematický ústav Slovenská akadémia vied Bratislava Stavebná fakulta STU G. Okša: Priame metódy 1/16 Obsah 1 Základy 2 Systémy
LR(0) syntaktické analyzátory. doc. RNDr. Ľubomír Dedera
LR0) syntaktické analyzátory doc. RNDr. Ľubomír Dedera Učebné otázky LR0) automat a jeho konštrukcia Konštrukcia tabuliek ACION a GOO LR0) syntaktického analyzátora LR0) syntaktický analyzátor Sám osebe
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY
UNIVERZITA KOMENSKÉHO V BRATISLAVE FAKULTA MATEMATIKY, FYZIKY A INFORMATIKY MINIMAXNÉ OPTIMÁLNE NÁVRHY REGRESNÝCH EXPERIMENTOV DIPLOMOVÁ PRÁCA 2014 Bc. Gabriel GROMAN UNIVERZITA KOMENSKÉHO V BRATISLAVE
HASLIM112V, HASLIM123V, HASLIM136V HASLIM112Z, HASLIM123Z, HASLIM136Z HASLIM112S, HASLIM123S, HASLIM136S
PROUKTOVÝ LIST HKL SLIM č. sklad. karty / obj. číslo: HSLIM112V, HSLIM123V, HSLIM136V HSLIM112Z, HSLIM123Z, HSLIM136Z HSLIM112S, HSLIM123S, HSLIM136S fakturačný názov výrobku: HKL SLIMv 1,2kW HKL SLIMv
Numerické metódy matematiky I
Prednáška č. 7 Numerické metódy matematiky I Riešenie sústav lineárnych rovníc ( pokračovanie ) Prednáška č. 7 OBSAH 1. Metóda singulárneho rozkladu (SVD) Úvod SVD štvorcovej matice SVD pre menej rovníc
Harmonizované technické špecifikácie Trieda GP - CS lv EN Pevnosť v tlaku 6 N/mm² EN Prídržnosť
Baumit Prednástrek / Vorspritzer Vyhlásenie o parametroch č.: 01-BSK- Prednástrek / Vorspritzer 1. Jedinečný identifikačný kód typu a výrobku: Baumit Prednástrek / Vorspritzer 2. Typ, číslo výrobnej dávky
Deliteľnosť a znaky deliteľnosti
Deliteľnosť a znaky deliteľnosti Medzi základné pojmy v aritmetike celých čísel patrí aj pojem deliteľnosť. Najprv si povieme, čo znamená, že celé číslo a delí celé číslo b a ako to zapisujeme. Nech a
Základné poznatky molekulovej fyziky a termodynamiky
Základné poznatky molekulovej fyziky a termodynamiky Opakovanie učiva II. ročníka, Téma 1. A. Príprava na maturity z fyziky, 2008 Outline Molekulová fyzika 1 Molekulová fyzika Predmet Molekulovej fyziky
Spojité rozdelenia pravdepodobnosti. Pomôcka k predmetu PaŠ. RNDr. Aleš Kozubík, PhD. 26. marca Domovská stránka. Titulná strana.
Spojité rozdelenia pravdepodobnosti Pomôcka k predmetu PaŠ Strana z 7 RNDr. Aleš Kozubík, PhD. 6. marca 3 Zoznam obrázkov Rovnomerné rozdelenie Ro (a, b). Definícia.........................................
Úloha. 2: Meranie maximálnej hodnoty
. Meranie imálnej hodnoty Úloha. : Meranie imálnej hodnoty Zadanie: 1) Zmerajte imálnu hodnotu napätia U osciloskopom. 1) Zmerajte efektívnu hodnotu napätia U ef meracím prístrojom. ) Zmerajte imálnu hodnotu
Lineárna algebra I - pole skalárov, lineárny priestor, lineárna závislosť, dimenzia, podpriestor, suma podpriestorov, izomorfizmus
1. prednáška Lineárna algebra I - pole skalárov, lineárny priestor, lineárna závislosť, dimenzia, podpriestor, suma podpriestorov, izomorfizmus Matematickým základom kvantovej mechaniky je teória Hilbertových