Occasionalmente il model PN51T perde i settaggi come per esempio il Pin Code (con conseguente Led rosso in corrispondenza dell'icona all'estrema destra)
Per fare cio' si devono ricordare un po' di cose
L'IP e' fisso a 192.168.0.1 ed il Pin Code e' 0000
Se e' necessario inserire il Pin Code dalla Interfaccia Web compare un nuovo campo sotto quello della password dove mettere il Pin
La password di default e' admin (anche questa ogni tanto si perde)
La chiave WPA per l'accesso all'access point e' invece nascosta sotto il coperchio
In questo post viene descritto come disegnare un insieme di Mandelbrot utilizzando una Arduino Uno ed un display Nokia 5110
Il display, utilizzato per esempio nel telefono Nokia 3310, viene adesso venduto separatamente ed ha una risoluzione di 84x48 pixel monocromatici
Il mio vecchio Nokia 3310
Il modello usato nell'esempio e' stato acquistato per circa 5 euro da DealExtreme ed a differenza del display originale, connesso con un cavo flat, utilizzata una strip per connetterlo facilmente ad una breadboard
Per l'utilizzo si devono inserire le librerie Arduino per il controller 8544 e per la grafica
Attenzione che rispetto agli esempi riportati su Internet i nomi dei pin sono leggermente differenti e con un ordine differente tra quelli di Adafruit o Sparkfun e quello comprato su DealExtreme...comunque anche senza istruzioni si riesce a venirne a capo semplicemente
Usando una Arduino Uno e' importante inserire le resistenze (come indicato qui) in quanto la tensione di esercizio del display e' di 3.3 V
Di seguito lo script per la realizzazione di Mandelbrot
-------------------------------- #include <Adafruit_GFX.h> #include <Adafruit_PCD8544.h> // tempo di esecuzione // 1minuto e 15 secondi su Arduino Uno // aggiornando il display solo alla fine // 2 minuti ed 11 secondi aggiornando il display ogni pixel // 48 righe // 84 colonne #define SCREEN_WIDTH 84 #define SCREEN_HEIGHT 48 // pin 7 - Serial clock out (SCLK) // pin 6 - Serial data out (DIN) // pin 5 - Data/Command select (D/C) // pin 4 - LCD chip select (CS) // pin 3 - LCD reset (RST) Adafruit_PCD8544 display = Adafruit_PCD8544(7, 6, 5, 4, 3); float re_min = -2.0; float im_min = -1.2; float re_max = 1.0; float im_max = 1.2; int iterazioni = 1024; float a,b; float x,y,x_new,y_new; int test; int k,j,i; void setup() { display.begin(); display.setContrast(50); display.clearDisplay(); // clears the screen and buffer float re_factor = (re_max-re_min); float im_factor = (im_max-im_min); for (i=0;i<SCREEN_HEIGHT;i++) { for (j=0;j<SCREEN_WIDTH;j++) { a = re_min+(j*re_factor/SCREEN_WIDTH); b = im_min+(i*im_factor/SCREEN_HEIGHT); x = 0; y = 0; test = 0; for (k=0;k<iterazioni;k++) { x_new = (x*x)-(y*y)+a; y_new = (2*x*y)+b; if (((x_new*x_new)+(y_new*y_new))>4) { test = k; if (k%2 == 0) display.drawPixel(j, i, BLACK); display.display(); break; } x = x_new; y = y_new; } } } //altrimenti se si fa tutto alla fine e' molto piu' veloce display.display(); delay(2000); } void loop() { }
Recentemente mi sono trovato a soggiornare in (credo) uno dei pochi posti in Italia a scarsissima connettivita'. L'unica telefonia mobile funzionante era quella relativa a TIM mentre Wind e Vodafone erano completamente assenti (nonostante le due tacche il telefono riportava l'errore di rete non supportata)
La connesione mobile Internet di TIM andava solo in Edge ed a velocita' molto variabili (anche zero byte)
Per questo motivo il gestore del campeggio si e' attrezzato con un collegamento satellitare TooWay che a differenza delle prime connessione satellitare via Internet non ha bisogno di una linea telefonica di supporto in quanto sia la trasmissione che la ricezione avviene attraverso la parabola
La velocita' di trasferimento, nonostante la pubblicita' del sito, e' sconfortante ma del resto quando non si hanno alternative anche pochi kb al secondo possono essere utili per leggere la posta
In vena di ricordare il passato ho provato ad installare il compilatore Borland Turbo C++ sulla mia Debian Box.
Il primo tentativo e' stato utilizzando DosEmu ma per motivi non meglio chiariti (non vengono emessi segnali di errore) il programma tc non viene messo in esecuzione
Sono quindi passato a DosBox
Una volta scaricato il pacchetto di Turbo C++ da qualche sito internet (ne ve sono a bizzeffe) e spacchettato all'interno della propria home si puo' digitare
keyb it mount c: /home/luca c: cd \tc\bin tc
l'Ide si apre e si puo' iniziare a scrivere il programma. Il problema si pone quando si vuole mettere in esecuzione con la combinazione CTRL+F9 perche' la medesima combinazione chiude l'applicazione DosBox.
Si deve quindi premere CTRL+F1, selezionare ShutDown e cancellare questa combinazione di tasti
In conclusione comunque e' abbastanza inutile usare Turbo C++ quando si ha disposizione GCC perche' nel 1991, anno di uscita del compilatore Borland, non era stato ancora formalizzato lo standard ANSI. Inoltre al momento attuale il compilatore e' totalmente privo di supporto anche a causa della scomparsa di Borland
Con una leggera modifica al programma presentato a questo post e'possibile creare dei codici a barre in formato Code 39 usando la libreria ZXing in Java
Le modifiche sono evidenziate in giallo
Il risultato e' qualcosa di simile (il codice e' 003)
--------------------------------------- package qrcode; import com.google.zxing.EncodeHintType; import com.google.zxing.MultiFormatWriter; import com.google.zxing.common.BitMatrix; import java.io.File; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.nio.charset.CharacterCodingException; import java.nio.charset.Charset; import java.nio.charset.CharsetEncoder; import java.util.Hashtable; import com.google.zxing.client.j2se.MatrixToImageWriter; /** * * @author l.innocenti */ public class QrCode { public static void main(String[] args) { Charset charset = Charset.forName("UTF-8"); CharsetEncoder encoder = charset.newEncoder(); byte[] b = null; try { // Convert a string to UTF-8 bytes in a ByteBuffer ByteBuffer bbuf = encoder.encode(CharBuffer.wrap(args[0])); b = bbuf.array(); } catch (CharacterCodingException e) { System.out.println(e.getMessage()); } String data; try { data = new String(b, "UTF-8"); // get a byte matrix for the data BitMatrix matrix = null; int h = 100; int w = 300; com.google.zxing.Writer writer = new MultiFormatWriter(); try { Hashtable<EncodeHintType, String> hints = new Hashtable<EncodeHintType, String>(2); hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); matrix = writer.encode(data, com.google.zxing.BarcodeFormat.CODE_39, w, h, hints); } catch (com.google.zxing.WriterException e) { System.out.println(e.getMessage()); } // change this path to match yours (this is my mac home folder, you can use: c:\\qr_png.png if you are on windows) String filePath = args[0]+".png"; File file = new File(filePath); try { MatrixToImageWriter.writeToFile(matrix, "PNG", file); System.out.println("printing to " + file.getAbsolutePath()); } catch (IOException e) { System.out.println(e.getMessage()); } } catch (UnsupportedEncodingException e) { System.out.println(e.getMessage()); } } }
In attesa delle Qt 5.2, che porteranno un supporto ufficiale a Qt in Android, ho provato Necessitas, un sistema per creare applicazioni basate su Qt in Android
Necessitas viene distribuito come installer compilato sia per Windows che per Linux di circa 20 Mb che permette di scaricare tutto il pacchetto completo che e' sostanzialmente composto da QtCreator+Android SDK
Per Linux sono necessari
i pacchetti build-essential
JDK
Ant
ia32-libs-gtk
per eseguire l'ambiente di sviluppo NON si deve lanciare qtcreator bensi' QtCreator/bin/necessitas
Per Windows sono necessari
Ant
JDK
Inoltre sul telefono deve installata l'applicazione Ministro II. Questa applicazione monitora l'eventuale richiesta di una applicazione scritta in Qt e si incarica di scaricare le librerie necessarie. Per una applicazione base in genere si scaricano circa 10 Mb di file di librerie Qt che peraltro non possono essere spostati sulla scheda SD con ovvia occupazione di memoria
Da qui in poi si possono creare le applicazioni Android come se si scrivesse una normale applicazione desktop
La spiegazione di come deve essere interpretato il problema e' qui (francamente con il mio pessimo inglese non avevo ben capito il testo)
il programma e' il seguente
----------------------------------------------------------
#include <iostream> #include <stdlib.h> using namespace std; int main() { string numero = "7316717653133062491922511967442657474235534919493496983520312774506326239578318016984801869478851843858615607891129494954595017379583319528532088055111254069874715852386305071569329096329522744304355766896648950445244523161731856403098711121722383113622298934233803081353362766142828064444866452387493035890729629049156044077239071381051585930796086670172427121883998797908792274921901699720888093776657273330010533678812202354218097512545405947522435258490771167055601360483958644670632441572215539753697817977846174064955149290862569321978468622482839722413756570560574902614079729686524145351004748216637048440319989000889524345065854122758866688116427171479924442928230863465674813919123162824586178664583591245665294765456828489128831426076900422421902267105562632111110937054421750694165896040807198403850962455444362981230987879927244284909188845801561660979191338754992005240636899125607176060588611646710940507754100225698315520005593572972571636269561882670428252483600823257530420752963450"; int prodotto = 0; int massimo = 0; for (int t=0;t<997;t++) { prodotto = (int(numero[t])-48)*(int(numero[t+1])-48)*(int(numero[t+2])-48)*(int(numero[t+3])-48)*(int(numero[t+4])-48); if (prodotto > massimo) massimo = prodotto; } cout << massimo << endl; return 0; }