Dobrý deň, pridávam moje riešenie, ktoré by som rád porovnal s Vaším prístupom.
ALU
Činnosť PROM v kombinácii s RAM a adresným čítačom ste už naznačili skôr.
V PROM Využívam jeden z adresných vstupov na odlíšenie adresy registrov preddeličiek a adresy hodín (diódová kombinačná logika D1, D2). Nasledujúce 2 adresné vstupy rozlišujú registre jednotiek minút/desiatok minút/jednotiek hodín/ jednotiek poldní (10-6-12-14) alebo v prípade preddeličky modulo 15-16-16-16. Ďalšie 4 adresné vstupy sú spätná väzba minulej hodnoty registru. Posledný vstup je C (carry), ktorý je zavedený cez D flip-flop.
Na riadenie zápisu (R/W) do pamäte RAM používam 16.384kHz hodiny vstupujúce do adresného čítača 7493 (jeden cyklus zápis/čítanie pre každú adresu).
Na porovnávanie času s budíkom, sú použíté obvody 7475 (latch) a 7485 (komparátor magnitúdy). Do 7475 zachytím hodnotu registra hodiniek a porovnám s hodnotou registra časovačov. Keďže za jeden celý cyklus (16 adries) môžem porovnať hodnotu iba 1 registra, medzivýsledok porovnania uložím v pamäti a porovnávam sekvenčne v 4 cykloch. Na medzivýsledok používam dva samostatné D flip-flop pre čas ON a čas OFF.
Krokovanie adresy registra (minúty/desiatky minút/hodiny/poldne) pre toto sekvenčné porovnanie robím dodatočným vydelením frekvencie najvyššieho bitu (MSb) adresného čítača pomocou 2-bitového čítača zostaveného z deličiek dvomi (7474). Táto hodnota sa zmení raz za 1 celý cyklus (16 adries). Ich hodnota je neustále porovnávaná s okamžitou hodnotou adresného čítača. Keď nastane zhoda, je povolený buď prepis LATCH registra (register hodiniek) alebo pamäti prenosu porovnania času ON, času OFF pomocou kombinačného obvodu tvoreného IC3, IC4A, IC5.
Zobrazovanie som vyriešil nasledovne:
Dekodér 1-z-10 má využité 3 po sebe idúce adresy. 2 nižšie postavené bity krokujú pozíciu 0-1-2 pre cyklické prepínanie medzi segmentovkami, 2 vyššie bity určujú, či sa zobrazujú hodiny, budík ON, budík OFF. Zatiaľ som nedoriešil ako ošetriť zobrazovanie registra na najvyššej adrese -poldní, zatiaľ na tomto stojím. Predpokladám, že by sa dal ešte využiť na toto dodatočný 5. vstup 74188?
Inkrement minút-hodín-poldní - tu pre nedostatok hradiel som urobil diódovú logiku sledujúcu podľa zatlačeného spínača, ktorá logickým AND vyhodnocuje, či výstup adresného čítača zodpovedá hodinám, minútam alebo dňom. Potom, ak je stlačené tlačítko, vytvorím cez derivačný článok impulz dlhý 1 plný adresný cyklus, čo v logickom súčine vytvorí logickú 1 počas doby trvania adresy minút, hodín alebo dní. Tu moja otázka znie, či sa vo Vašom návrhu inkrement nastavenia času deje iba jednorázovo pri stlačení tlačítka alebo počas doby jeho držania?
Predpokladám, že pre nastavenie/ inkrement hodnoty hodiniek (alebo budíka) používate carry logiku. To by vyžadovalo externou logikou (nie v tabuľke PROM) zakázať prenos medzi najvyšším registrom hodiniek a registrom budíka, ktorý v normálnej prevádzke zostáva nemenný. Prenos (slúžiaci takto na inkrement) by bol povolený len impulzom z tlačítka inkrementu. Toto zatiaľ nemám dokončené. Iné riešenie pre nastavenie registrov mi zatiaľ na um neprišlo.
Ešte nemám vyriešený výstup budíka, tu mi vychádza, že by bolo treba si zapamätať hodnotu porovnania/prenosu, keď adresa registra dovŕši najvyššiu adresu (teda poldní).
Taktiež ešte nemám urobený denný/týždenný cyklus.
Zostávajú mi voľné 2 hradlá 7404, ktoré zrejme budem musieť použiť na inverziuq
⁵ hodinových signálov na registre medzipamäti porovnávania.
Určite by sa celý tento obvod dal vyriešiť elegantnejšie, tu by ste mi veľmi pomohli nasmerovať, ktorú časť by ste urobili ináč, lebo je urobená neefektívne.
Časy uváděny v GMT + 1 hodina Jdi na stránku Předchozí1, 2, 3, 4, 5
Strana 5 z 5
Nemůžete odesílat nové téma do tohoto fóra. Nemůžete odpovídat na témata v tomto fóru. Nemůžete upravovat své příspěvky v tomto fóru. Nemůžete mazat své příspěvky v tomto fóru. Nemůžete hlasovat v tomto fóru. Nemůžete připojovat soubory k příspěvkům Můžete stahovat a prohlížet přiložené soubory
Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.