Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-10-2003, 10:38   #1
gokan
Senior Member
 
L'Avatar di gokan
 
Iscritto dal: Apr 2002
Città: Palermo
Messaggi: 4913
Difficile:algoritmi genetici

Salve a tutti, so che l’argomento qui sotto trattato non è molto comune, quindi è ben accetto qualsiasi suggerimento. Sono alle prese con algoritmi genetici e devo dire sebbene abbia una “discreta” conoscenza di programmazione sto avendo qualche difficoltà con questi nuovi argomenti. Assumerò che abbiate qualche conoscenza di quello che sto scrivendo.Introduco prima un po’ di codice:
Codice:
%Dobbiamo trovare lo zero di questa funzione
function y=funzione(x)
y=0.3*(x-305)^3-30.7*(x+51)^2-x+105;
%%% 0.3*(x^2-330.354*x+41687.5)*(x-686.98)

%Questa funzione prende in ingresso i due cromosomi genitori, il punto di taglio dei cromosomi e %restituisce i cromosomi figli.
function [c3,c4]=crossover(c1,c2,t)
c3=bitor(bitshift(bitshift(c1,-t),t),bitshift(bitshift(c2,53-t),t-53));
c4=bitor(bitshift(bitshift(c2,-t),t),bitshift(bitshift(c1,53-t),t-53));

%Questa funzione compie la mutazione del cromosoma “c” nella posizione iesima.
%Esempio c=0110 vogliamo mutare il gene sottolineato, quindi diventa c=0100
function x=mutation(c,i)
x=bitxor(c,bitset(0,i));

%Serve ad ottenere valori tra 0 e 2^28-1
function t=decodifica(c)
t=c/134217.7275-1000;

%Restituisce la “bontà” di un cromosoma
function t=fitness(c)
t=abs(funzione(decodifica(c)));
In pratica, dovrei trovare lo zero della funzione y=….. (ossia 686.98). Tutto questo facendo uso delle varie tecniche di crossover e mutazione. Ho commentato la funzione primo nei passaggi che ho compreso, ci sono alcuni punti invece che sono poco chiari.
Codice:
function primo(nc, ni, pc, pm)
Cr=round(rand(nc, 1)*(2^28-1));     %%% genera nc cromosomi di 28 bit
mc=fix(nc/2); Fn=[]; Fm=[]; Fs=[];   %Inizializziamo alcune variabili
%Il ciclo for serve a calcolare la fitness degli nc cromosomi, ed inserire ogni singola fitness in un %vettore Fn
for i=1:nc,
  Fn=[Fn; fitness(Cr(i))];
end;
Fm=[Fm, mean(Fn)];  %media
Fs=[Fs, std(Fn)];        %deviazione standard

for n=1:ni,
%generiamo una permutazione casuale di nc numeri e riarrangiamo i cromosomi con le rispetive fitness 
r=randperm(nc); Cr=Cr(r); Fn=Fn(r); 
  for i=1:mc,
    if rand<pc
% esclude tagli banali, (a e b sono i figli che verranno fuori dal crossover)
      [a, b]=crossover(Cr(i), Cr(mc+i), round(rand*26+1));
% t1 dovrebbe contenere le fitness ordinate, t2 contiene gli indici corrispondenti alle varie fitness %ordinate, ([Fn([i, mc+i]) è la fitness dei genitori, fitness(a) e fitness(b) è quella dei figli. 
      [t1, t2]=sortrows([Fn([i, mc+i]); fitness(a); fitness(b)]);
%La fitness dei genitori la sostituiamo con la fitness dei primi 2 cromosomi (che 
%dovrebbe essere quella più bassa)
      Fn([i, mc+i])=t1([1, 2]);
%Queste istruzioni sotto non le ho capite
      t=[Cr([i, mc+i]); a; b]; Cr([i, mc+i])=t(t2([1, 2]));
    end;
  end;
%Si fa la mutazione
  for i=1:nc,
    if rand<pm
      Cr(i)=mutation(Cr(i), round(rand*27)+1);
      Fn(i)=fitness(Cr(i));
    end;
  end;

  Fm=[Fm, mean(Fn)]; %Aggiorniamo la fitness media
  Fs=[Fs, std(Fn)];       %--------------------- dev. standard

end;
%Cr' ci consente di visualizzare tutti i cromosomi in un vettore riga (prima erano in 
%colonna), stampiamo la Fm, la Fs. decodifica(Cr)'==>??
Cr, Fm, Fs, decodifica(Cr)
-------------------------------------------------------------------------------------------------
dove
nc= # cromosomi; ni= # interazioni; pc= probabilità di crossover;
pm= prob. di mutazione; Fm= fitness media; Fs= fitness della dev. standard
Fn= vettore colonna contenente la fitness dei cromosomi;
Cr=--------------------------------- nc cromosomi di 28 bit

Fornendo in input dei valori simili:
>>primo(100,60,0.5,0.01)
ottengo l’output allegato.
Mi rendo conto che l’argomento trattato non è tra i più semplici (a parte il fatto che bisogna conoscere un po’ di Matlab) quindi ogni suggerimento è ben accetto. Mi piacerebbe sapere pure se conoscete qualche buon libro di testo in italiano che tratti argomentazioni simili. A noi il professore ha suggerito:
Zbigniew Michalewicz, Genetic Algorithms + Data Structure = Evolution Programs, Springer, 1996
Un conto è leggere qualche paginetta per capire il senso generale di un testo inglese, un’altra cosa è studiare su un testo inglese.
Grazie comunque.
Allegati
File Type: zip out.zip (1.0 KB, 8 visite)
__________________
Sun Certified Java Programmer - Sun Certified Web Component Developer - Sun Certified Business Component Developer
gokan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Apple prepara l'addio al notch su smartp...
Linux cresce grazie all'addio a Windows ...
Forza un ufficio, smonta le memorie dal ...
Bentornati nel 2007: le memorie DDR3 rin...
Stellantis aderisce ad AI4I e Fondazione...
Google Pixel 10a: prime conferme sul pre...
ISRO potrebbe lanciare la capsula Gagany...
Un nuovo leak conferma dimensioni e novi...
Steam Machine: requisiti Verified piu' s...
NVIDIA GeForce RTX 5070 Ti fuori produzi...
Sony ha annunciato i nuovi giochi che en...
IBM Sovereign Core: la sovranità ...
Cerchi un'asciugatrice conveniente su Am...
Ayaneo Pocket Play arriverà in ri...
iPad Pro 11'' con chip M4 scende a 949€ ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 08:31.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v