Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.
Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.
Společnost Kaspersky vydala svůj bezplatný Virus Removal Tool (KVRT) také pro Linux.
Grafický editor dokumentů LyX, založený na TeXu, byl vydán ve verzi 2.4.0 shrnující změny za šest let vývoje. Novinky zahrnují podporu Unicode jako výchozí, export do ePub či DocBook 5 a velké množství vylepšení uživatelského rozhraní a prvků editoru samotného (např. rovnic, tabulek, citací).
Byla vydána (𝕏) nová verze 7.0 LTS open source monitorovacího systému Zabbix (Wikipedie). Přehled novinek v oznámení na webu, v poznámkách k vydání a v aktualizované dokumentaci.
Organizace Apache Software Foundation (ASF) vydala verzi 22 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Společnost AMD na veletrhu Computex 2024 představila (YouTube) mimo jiné nové série procesorů pro desktopy AMD Ryzen 9000 a notebooky AMD Ryzen AI 300.
OpenCV (Open Source Computer Vision, Wikipedie), tj. open source multiplatformní knihovna pro zpracování obrazu a počítačové vidění, byla vydána ve verzi 4.10.0 . Přehled novinek v ChangeLogu. Vypíchnout lze Wayland backend pro Linux.
Národní superpočítačové centrum IT4Innovations s partnery projektu EVEREST vydalo sadu open source vývojových nástrojů EVEREST SDK pro jednodušší nasazení aplikací na heterogenních vysoce výkonných cloudových infrastrukturách, zejména pro prostředí nabízející akceleraci pomocí FPGA.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu aktuálně činí 2,32 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Ubuntu, Linux Mint a Manjaro Linux. Při výběru jenom Linuxu vede SteamOS Holo s 45,34 %. Procesor AMD používá 75,04 % hráčů na Linuxu.
Každý geek by měl jedny mít. A pro ty, kteří opovrhují koupenými nebo jen nemají dost peněz je určen následující návod.
Důležité: před zahájením práce doporučuji přečíst následující články: Jednočipy pod Linuxem I Jednočipy pod Linuxem II a Jednočip ATtiny2313 pod Linuxem. Nebudu se zde zabývat základními věcmi jako jednoduchý programátor, vývojové prostředí nebo nahrávání programu do jednočipu
Disclaimer: veškeré zde uvedené postupy činíte na vlastní nebezpečí. I když jsem tento postup vyzkoušel, za případný spálený paralelní port, základní desku, nebo vlasy. Zkrátka když bude něco špatně, mě z toho vynechte.
#include <avr/io.h> #include <avr/interrupt.h> // definice maker pro prace s bity #define bitSet(var, mask) ((var) |= (1 << (mask))) #define bitClear(var, mask) ((var) &= ~(1 << (mask))) short s=0, m=0, h=0; void showMins(short m); void showHours(short h); SIGNAL (SIG_OVERFLOW0) { // zavola se pri preteceni interniho 8bit citace static unsigned char count = 0; TCNT0=6; // 8MHz/256/250=125 preruseni/sec - pocita s nastavenim interniho oscilatoru na // 8MHz. Pokud tak neni, je nutne prepocitat // 256 (velikost counteru) - 250 (nas delitel) = 6 (pri kazdem preteceni // zaciname od 6 a ne od 0) count ++; if (count == 125) { // pracujeme s kazdym 125 preruseni count=0; extern short h, m, s; s++; if (s%2==0) // kazdou sudou vterinu rozsvitime LED a kazdou lichou zhasneme bitSet(PORTD, PD0); else bitClear(PORTD, PD0); if (s>=60) { // postarame se o korektni cas s=s-60; m++; } if (m>=60) { h++; m=m-60; } if (h==24) h=0; // a nakonec zavolame funkce pro zobrazeni hodin/minut showHours(h); showMins(m); } } SIGNAL (SIG_INT0) { // zavola se pri stisknuti tlacitka minut extern short m,s; m++; s=0; // resetuje vteriny if(m>=60) m=0; // neprehazujeme hodiny, nastavujeme showMins(m); } SIGNAL (SIG_INT1) { // zavola se pri stisknuti tlacitka hodin extern short h,s; h++; s=0; // resetuje vteriny if(h>=24) h=0; showHours(h); } void showHours(short h) { // funkce starajici se o rozsveceni jednotlivych LED pro hodiny if(h>=16) { bitSet(PORTB, PB0); h=h-16; } else bitClear(PORTB, PB0); if(h>=8) { bitSet(PORTD, PD6); h=h-8; } else bitClear(PORTD, PD6); if(h>=4) { bitSet(PORTD, PD5); h=h-4; } else bitClear(PORTD, PD5); if(h>=2) { bitSet(PORTD, PD4); h=h-2; } else bitClear(PORTD, PD4); if(h==1) bitSet(PORTD, PD1); else bitClear(PORTD, PD1); } void showMins(short m) { // funkce starajici se o rozsveceni jednotlivych LED pro minuty if(m>=32) { bitSet(PORTB, PB6); m=m-32; } else bitClear(PORTB, PB6); if(m>=16) { bitSet(PORTB, PB5); m=m-16; } else bitClear(PORTB, PB5); if(m>=8) { bitSet(PORTB, PB4); m=m-8; } else bitClear(PORTB, PB4); if(m>=4) { bitSet(PORTB, PB3); m=m-4; } else bitClear(PORTB, PB3); if(m>=2) { bitSet(PORTB, PB2); m=m-2; } else bitClear(PORTB, PB2); if(m==1) bitSet(PORTB, PB1); else bitClear(PORTB, PB1); } int main() { // Nastaveni pinu jako vystupnich bitSet (DDRD, PD0); // vterinovy blikatko bitSet (DDRD, PD1); // hodiny - 1 bitSet (DDRD, PD4); // 2 bitSet (DDRD, PD5); // 4 bitSet (DDRD, PD6); // 8 bitSet (DDRB, PB0); // 16 bitSet (DDRB, PB1); // minuty - 1 bitSet (DDRB, PB2); // 2 bitSet (DDRB, PB3); // 4 bitSet (DDRB, PB4); // 8 bitSet (DDRB, PB5); // 16 bitSet (DDRB, PB6); // 32 // Nastaveni preruseni bitSet (PCMSK, PD2); // minutovy button bitSet (MCUCR, ISC11); // falling edge bitSet (MCUCR, ISC01); bitSet (GIMSK, INT0); // povoleni preruseni 0 bitSet (PCMSK, PD3); // hodinovy button bitSet (GIMSK, INT1); // povoleni preruseni 1 bitSet(TCCR0B, CS02); // Clock prescaler (/ 256) bitSet(TIMSK, TOIE0); // povoleni preruseni od casovace sei(); // povoleni preruseni globalne while(1) { } return 0; }
Ke zdrojáku snad nemusím nic dodávat, komentáře jsou doufám srozumitelné. Kód zkompilujte a
nahrajte do čipu (návody jsou v již zmíněných článcích). Pokud jste se rozhodli nic nepočítat a
používat 8MHz, je nutné ještě upravit pojistku (odstranit CKDIV8 bit):
avrdude -c dapa -p
t2313 -U lfuse:w:0xE4:m
(pokud používáte jiný programátor, upravte příkaz podle
svého).
Tady přichází ta zajímavější část - součástky pozapojujte podle schématu (POZOR: piny nejsou poporade, ridte se cislovnim - viz datasheet[PDF]).
Zapojte napájení a mělo by to fungovat. :) Dioda D1 svítí každou sudou vteřinu, diody D2-D7 ukazují hodiny a D8-12 minuty. Tlačítkem T1 nastavujete minuty, T2 hodiny a RESET je reset.
A to je pro dnešek vše, přátelé. Jen se na ty hodiny raději moc nespoléhejte, pochybuju, že budou přesné :D
P.S.0: takhle to vypadá u mě:
Místo jednoho kondenzátoru mám 4 menší a na desce v prvém horním rohu jsou vývody "programátoru" (na paralelní port).
P.S.1: Nekamenujte me, je to moje prvni ubastlena hracka :)
P.S.2: Jeste doplnim info o spotrebe, pokud by nekoho zajimala: cca 13mA pri vetsine rozsvicenych diod a napeti 2.7V
Tiskni Sdílej:
Ke zdrojáku snad nemusím nic dodávat, komentáře jsou doufám srozumitelné.1) SIGNAL je deprecated. V novém kódu se má používat ISR. 2) Funkce showMins() je krásná ukázka toho, jak se dá naprosto jednoduchá věc udělat zbytečně složitě. Tohle bude fungovat podstatně efektivněji:
void showMins (unsigned char m) { m <<= 1; if (PORTB & (1 << PORTB0)) m |= 1; m &= 0x7e; //vynuluje bity, které nejsou součástí minut PORTB = m; }(unsigned char je stejně velká, jako short; u short si nejsem jistý, jestli není znaménkové) 3) Přerušení nastavuješ divně:
bitSet (PCMSK, PD2); // minutovy button bitSet (PCMSK, PD3); // hodinovy buttonjsou přerušení na změnu stavu logické hodnoty na pinu (PCINT). Ty ale používáš (a obsluhuješ) signál vnějšího přerušení (INTx). Tato dvě nastavení jsou tedy zbytečná, protože nemají na nic vliv.
1) nevedel jsemhttp://www.nongnu.org/avr-libc/user-manual/group__avr__interrupts.html Úplně dole.
Diky moc :) Rad se poucim :)Není zač. Rád pomůžu - čím víc lidí bude umět s AVR, tím víc lidí si je bude kupovat a používat a tím budou levnější.
- pouzitie non-isp jednocipaku v roku 2008Co to znamena?
- pouzitie modrych supersvietivych led (neznasam ich)Myslim, ze te nikdo neomezuje v tom, tam dat treba zeleny matny nebo fialovo-zluty polomatny s cervenejma puntikama...
- pouzitie non-isp jednocipaku v roku 2008- a proc ne? Doma se mi jich par valelo, tak proc kupovat?
- pouzitie modrych supersvietivych led (neznasam ich)- ale v cerny krabici (pokud to tam nekdy zadrtuju) to bude vypadat skvele!
- pouzitie non-isp jednocipaku v roku 2008Tak to v Atmelu museli od doby, co jsem s Attiny2313 pracoval, to ISP vymontovat.
avrdude -c dapa -p t2313 -t
používají se 2 příkazy: write lfuse 0 hodnota
a read lfuse 0 1
(hodnota může být v decimálním tvaru nebo v hexa 0x..)
V tomhle režimu můžeš hodnotu pomocí write zapsat a pomocí read si potom přečíst, co se skutečně zapsalo. Stejným způsobem můžeš číst/psát do hfuse.
Terminálový režim ukončíš příkazem quit
, pokud jsi změnil některou z hodnot, tak se tě bude ptát, jestli to skutečně myslíš vážně.
Máš dobře připojený ten krystal?Snad jo. Mezi vyvody XTAL1 a 2 a potom pres kondenzatory na zem (zkousel jsem dva krystaly, pro pripad, ze by jeden byl nefunkcni).
Jinak zkus tu hodnotu změnit v terminálovém režimu avrdude: avrdude -c dapa -p t2313 -t
Problem je, ze ten terminalovy rezim uz nespustim. AVRdude skonci, ze nemuze komunikovat s cipem. :( A riskovat dalsi se mi nechce :)
Problem je, ze ten terminalovy rezim uz nespustim. AVRdude skonci, ze nemuze komunikovat s cipem.Což to je mi jasné, myslel jsem vzít jiný čip. S tímhle bez paralelního programátoru nehneš, protože jestli jsi zapsal 0xff do hfuse, tak jsi zakázal programování přes ISP (tj. přes ty vývody MISO/MOSI/SCK) a s dapa programátorem (ani obdobnými) už si neškrtneš Ale i tak je to divný, protože jestli jsi zapsal 0xff do hfuse místo do lfuse, tak by pořád měl fungovat asopň program na vnitřní oscilátor.