DuckDuckGo AI Chat umožňuje "pokecat si" s GPT-3.5 Turbo od OpenAI nebo Claude 1.2 Instant od Anthropic. Bez vytváření účtu. Všechny chaty jsou soukromé. DuckDuckGo je neukládá ani nepoužívá k trénování modelů umělé inteligence.
VASA-1, výzkumný projekt Microsoftu. Na vstupu stačí jediná fotka a zvukový záznam. Na výstupu je dokonalá mluvící nebo zpívající hlava. Prý si technologii nechá jenom pro sebe. Žádné demo, API nebo placená služba. Zatím.
Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 140 (pdf) a HackSpace 77 (pdf).
ESPHome, tj. open source systém umožňující nastavovat zařízení s čipy ESP (i dalšími) pomocí konfiguračních souborů a připojit je do domácí automatizace, například do Home Assistantu, byl vydán ve verzi 2024.4.0.
LF AI & Data Foundation patřící pod Linux Foundation spustila Open Platform for Enterprise AI (OPEA).
Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.1 specifikace OpenXR (Wikipedie), tj. standardu specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro AR (rozšířenou realitu) a VR (virtuální realitu). Do základu se z rozšíření dostalo XR_EXT_local_floor. Společnost Collabora implementuje novou verzi specifikace do platformy Monado, tj. open source implementace OpenXR.
Byla vydána nová verze 0.38.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 4.4 nebo novější a také libplacebo 6.338.2 nebo novější.
ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzích 1.3.1, 1.2.3 a 1.0.6. Ve verzi 1.3.1 je mimo jiné řešena bezpečnostní chyba CVE-2024-20380.
Digitální a informační agentura (DIA) oznámila (PDF, X a Facebook), že mobilní aplikace Portál občana je ode dneška oficiálně venku.
#HACKUJBRNO 2024, byly zveřejněny výsledky a výstupy hackathonu města Brna nad otevřenými městskými daty, který se konal 13. a 14. dubna 2024.
Zdravim mohl byste mi nekdo poradit jak se da resit programek v cecku abych si pri spusteni navolil v prikazove radce jaky pseudo terminal se bude pouzivat ( ptsX ). Program se pak propoji na dalsi pseudo terminal a navzajem si posilaji data.
Presne zadani zde:
........................................Napište program, teletype. Tento program otevře sériový port a vyšle na něj každý z klávesnice zapsaný znak a vypíše každý jednotlivý znak ze sériové linky přijatý. Pomocí sériového kabelu propojte COM1 a COM2 a spusťte 2 instance programu teletype. Který COM se bude používat specifikujte z příkazové řádky při spouštění programu.
________________Vim jak udelat abych se propojil na terminal a cetl z nej znaky ale nevim jak udelat aby jsme mohl navzajem mezi terminali prijimat i odesilat. Snad pomoci fce select? Prosim poradte, ( nechci to naprogramovat, jen nakopnout), zatim je to pro me spanelska vesnice. Dekuji
EXAMPLE #include <stdio.h> #include <sys/time.h> #include <sys/types.h> #include <unistd.h> int main(void) { fd_set rfds; struct timeval tv; int retval; /* Watch stdin (fd 0) to see when it has input. */ FD_ZERO(&rfds); FD_SET(0, &rfds); /* Wait up to five seconds. */ tv.tv_sec = 5; tv.tv_usec = 0; retval = select(1, &rfds, NULL, NULL, &tv); /* Don't rely on the value of tv now! */ if (retval == -1) perror("select()"); else if (retval) printf("Data is available now.\n"); /* FD_ISSET(0, &rfds) will be true. */ else printf("No data within five seconds.\n"); return 0; }
#define BUF_LEN 200 struct termios set_attributes; int main(int argc, char *argv[]) { char *ttyID; char buffer[BUF_LEN]; int result; fd_set terminal, klavesnice; struct timeval timeout; /* Struktura s časovým limitem */ size_t len; ttyID = argv[1]; /* Nacteme ttyID pseudo terminalu */ int tty = open(ttyID, O_RDWR); // nastav nove parametry terminalu tcgetattr(tty, &set_attributes); set_attributes.c_lflag &= ~ICANON; // necekej na cely radek (noncanonical) //set_attributes.c_lflag &= ~ECHO; // nezobrazuj ctene znaky set_attributes.c_cc[VMIN] = 1; set_attributes.c_cc[VTIME] = 0; tcsetattr(tty, TCSAFLUSH, &set_attributes); while(1){ FD_ZERO(&terminal); /* Odstranime nahodna data z mnoziny */ FD_ZERO(&klavesnice); /* Odstranime nahodna data z mnoziny */ FD_SET(fileno(stdin), &klavesnice); /* Naplnime mnozinu stdin */ FD_SET(tty, &terminal); /* Naplnime mnozinu ttyckem */ // Nadefinovany casovy interval 4 sekundy a 5 milis.. timeout.tv_sec = 4; timeout.tv_usec = 50000; // Zavolám select (V Linuxu musím mít nastavenou proměnnou FD_SETSIZE) --- tezko rict co je na tom pravdy result = select(FD_SETSIZE, &klavesnice, &terminal, NULL, &timeout); switch(result){ case -1: perror("select"); /* Nastala chyba */ exit(1); case 0: printf("timeout \n"); /* Vypršel časový limit */ break; default: /* Obsluha soketu. Zde je možné vytvořit nové vlákno nebo proces, který obslouží událost na soketu. Server pak je vícevláknový. */ if (FD_ISSET(fileno(stdin), &klavesnice)) { /* Data available on stdin */ char a; read(fileno(stdin), &a, sizeof(a)); write(tty, &a, sizeof(a)); } if (FD_ISSET(tty, &terminal)) { char c; read(tty, &c, sizeof(c));/*:!*/ if(c == '\004') { // `C-d' // program skonci az prijme Ctrl-D break; } else { putchar(c); // vyprazdni vystupni buffer // a zpusob tak zobrazeni znaku // i v nekanonickem modu terminalu fflush(stdout); } } break; } } }
. . . switch(select(1, &rfds, NULL, NULL, &tv)) { case -1: perror("select()"); return -1; /* no break */ case 0: printf("No data in 5 sec.\n"); break; default: printf("DAATAAA!!!.\n"); /* FD_ISSET(0, &rfds) will be true. */ break; } return 0; . . .
hlavicky void *readFromTERMINAL( void *ptr ) { char *terminal; terminal = (char *) ptr; int tty = open(terminal, O_RDONLY);/*:!*/ if(tty < 0) { perror("ERROR open device /dev/ttyS1"); exit(EXIT_FAILURE); } while(1) { char c; read(tty, &c, sizeof(c)); if(c == '\004') { // `C-d' // program skonci az prijme Ctrl-D close(tty); break; } else { putchar(c); // vyprazdni vystupni buffer // a zpusob tak zobrazeni znaku // i v nekanonickem modu terminalu fflush(stdout); } } close(tty); } int main(int argc, char *argv[]) { pthread_t thread1, thread2; char *parametr; parametr = argv[1]; // vlakno cte z daneho portu a vypisuje na terminal pthread_create( &thread1, NULL, readFromTERMINAL, parametr); pthread_join(thread1, NULL); printf("\nKonec\n"); return EXIT_SUCCESS; }
moje_skvela_utilita </dev/bagr/jahoda/konzole >/dev/bagr/jahoda/konzole
Tiskni Sdílej: