Novità

SOM NNCLUST - chiarimenti.

Halmun

Advanced Member >PLATINUM<
chiariamo una volta per tutte un aspetto che 20 anni fa in questo forum fu messo in discussione da chi sosteneva Erroneamente che le Reti neurali SOM come NNCLUST o altre Reti di diverso tipo non utilizzano operatori matematici:
Tratto da domande e risposte con A.I. Gemini.

io:
.... capisco, ma un algoritmo di apprendimento utilizza comunque operatori matematici per giungere all'apprendimento. giusto?

Gemini:
Assolutamente sì! Un algoritmo di apprendimento, e in particolare quello di una rete neurale, si basa su una serie complessa di operazioni matematiche. Queste operazioni permettono alla rete di "imparare" dai dati, identificando pattern e relazioni nascoste.

Quali sono questi operatori matematici?

Somme pesate: Ogni neurone all'interno della rete riceve numerosi input, ciascuno moltiplicato per un peso specifico. Questi prodotti vengono poi sommati. I pesi sono i parametri che la rete "apprende" durante l'addestramento e determinano l'importanza relativa di ciascun input.
Funzioni di attivazione: Dopo la somma pesata, il risultato viene passato attraverso una funzione di attivazione non lineare (come la sigmoidale, la ReLU o la tanh). Queste funzioni introducono non linearità nella rete, permettendole di approssimare funzioni più complesse.
Calcolo dell'errore: L'errore viene calcolato come la differenza tra l'output previsto dalla rete e l'output reale. Questo errore viene poi utilizzato per aggiornare i pesi.
Discesa del gradiente: Questo è l'algoritmo più comunemente utilizzato per l'addestramento delle reti neurali. Calcola il gradiente della funzione di costo rispetto ai pesi e aggiorna i pesi in direzione opposta al gradiente, in modo da ridurre l'errore.
Moltiplicazione di matrici: Le reti neurali possono essere rappresentate come una serie di matrici, e le operazioni di propagazione in avanti e all'indietro coinvolgono moltiplicazioni di matrici.
Perché le operazioni matematiche sono fondamentali?

Rappresentazione: Le operazioni matematiche permettono di rappresentare in modo compatto e efficiente le relazioni tra i dati.
Apprendimento: Attraverso l'aggiornamento dei pesi, la rete può modificare la sua rappresentazione interna dei dati e adattarsi a nuovi esempi.
Generalizzazione: Le operazioni matematiche consentono alla rete di generalizzare a nuovi dati, ovvero di fare previsioni accurate su dati che non ha mai visto durante l'addestramento.
In sintesi

Le reti neurali utilizzano un linguaggio matematico sofisticato per apprendere dai dati. Le operazioni matematiche sono il fondamento su cui si basa il loro funzionamento. Comprendere queste operazioni è fondamentale per poter sfruttare al meglio le potenzialità delle reti neurali.


io:
e questo vale anche per le reti SOM?


Gemini:
Assolutamente sì, anche le reti SOM (Self-Organizing Maps) si basano su operazioni matematiche.

Sebbene le SOM presentino alcune differenze rispetto alle reti neurali artificiali tradizionali, come le MLP (Multi-Layer Perceptron), condividono con esse il fondamento matematico.

Come funzionano le operazioni matematiche nelle SOM?

Competizione tra neuroni: Ogni neurone della SOM compete per rispondere a un dato input. Il neurone vincente è quello i cui pesi sono più simili all'input.
Aggiornamento dei pesi: I pesi del neurone vincente e dei suoi vicini vengono aggiornati in modo da diventare più simili all'input. Questa operazione è basata su una funzione di vicinato e su un tasso di apprendimento.
Mappa topologica: La struttura della SOM è organizzata in una griglia bidimensionale. La vicinanza spaziale dei neuroni nella mappa riflette la similarità degli input che essi rappresentano.
Quali operazioni matematiche sono coinvolte?

Distanza euclidea: Viene utilizzata per calcolare la somiglianza tra l'input e i pesi di ciascun neurone.
Funzione di vicinato: Definisce l'ampiezza del vicinato del neurone vincente i cui pesi verranno aggiornati.
Tasso di apprendimento: Determina la velocità con cui i pesi vengono aggiornati.
Aggiornamento dei pesi: Questa operazione è solitamente implementata utilizzando una formula di aggiornamento simile a quella utilizzata nelle reti neurali tradizionali, ma adattata alla struttura della SOM.
In sintesi

Anche se le SOM hanno un approccio diverso all'apprendimento rispetto alle MLP, esse si basano su principi matematici ben definiti. La competizione tra neuroni, l'aggiornamento dei pesi e la formazione di una mappa topologica sono tutte operazioni che coinvolgono calcoli matematici.

Perché è importante conoscere le basi matematiche delle SOM?

Comprendere il funzionamento:
Conoscere le operazioni matematiche sottostanti ti permette di capire come la SOM apprende e organizza i dati.
Scegliere i parametri:
La scelta dei parametri (tasso di apprendimento, funzione di vicinato, ecc.) influisce significativamente sulle prestazioni della SOM.
Risolvere problemi:
Se incontri problemi durante l'utilizzo di una SOM, la conoscenza delle basi matematiche ti aiuterà a identificarne le cause e a trovare soluzioni.
Adattare la SOM:
Potresti voler adattare la SOM a un problema specifico. Conoscere le basi matematiche ti permetterà di modificare l'algoritmo in modo appropriato.
 
Ultima modifica:
io:
una SOM che analizza un dataset e viene configurata per una griglia di cluster ad esempio 6x6 distribuirà i punti ( numeri del dataset ) per gruppi, ognuno intorno ad un cluster specifico. questa distribuzione differenziata ( classi ) permette comunque tipi di previsione a breve termine in base ad ulteriori accorgimenti statistici che in questo caso saranno agevolati rispetto alla tradizionale analisi statistica sull'intera massa del dataset.

Gemini:
Assolutamente corretto! Hai colto un punto molto interessante e hai ragione a sottolineare come la distribuzione dei dati in una SOM possa facilitare le previsioni a breve termine.

Ecco come puoi sfruttare la SOM per le previsioni:

Identificazione di trend locali: Ogni cluster della SOM rappresenta una regione dello spazio dei dati con caratteristiche simili. Analizzando i trend temporali all'interno di ciascun cluster, puoi individuare pattern locali che potrebbero non essere evidenti analizzando l'intero dataset.
Rilevamento di anomalie: I punti che cadono lontani dai cluster possono rappresentare anomalie o valori outlier. Monitorando questi punti nel tempo, puoi individuare cambiamenti significativi nel comportamento dei dati.
Segmentazione dei dati: La SOM suddivide i dati in gruppi omogenei. Questa segmentazione può essere utilizzata per creare modelli di previsione separati per ciascun cluster, migliorando la precisione delle previsioni.
Feature engineering: Le coordinate dei neuroni vincenti nella SOM possono essere utilizzate come nuove feature per modelli di previsione più tradizionali, come le reti neurali o le regressioni lineari.
Accorgimenti statistici aggiuntivi:

Analisi temporale: Per le previsioni a breve termine, è fondamentale analizzare l'evoluzione temporale dei cluster. Puoi utilizzare tecniche come l'analisi delle serie temporali per individuare trend stagionali, ciclici e casuali all'interno di ciascun cluster.
Modelli di previsione specifici per cluster: Puoi adattare diversi modelli di previsione (ARIMA, modelli esponenziali, ecc.) a ciascun cluster, tenendo conto delle sue caratteristiche specifiche.
Valutazione della performance: È importante valutare la performance dei tuoi modelli di previsione utilizzando metriche appropriate, come il Mean Squared Error (MSE) o il Mean Absolute Error (MAE).
Vantaggi dell'utilizzo delle SOM per le previsioni:

Migliore interpretabilità: La visualizzazione della SOM permette di comprendere intuitivamente la struttura dei dati e le relazioni tra le variabili.
Gestione di dati non lineari: Le SOM sono in grado di catturare relazioni non lineari tra le variabili, cosa che potrebbe essere difficile da fare con modelli lineari.
Riduzione della dimensionalità: La SOM proietta i dati in uno spazio a bassa dimensionalità, semplificando l'analisi e la modellizzazione.
Limitazioni:

Dipendenza dalla configurazione: La scelta del numero di neuroni e della funzione di vicinato può influenzare significativamente i risultati.
Sensibilità ai dati iniziali: La SOM può essere sensibile all'ordine dei dati in ingresso.
Difficoltà nell'interpretare cluster complessi: In alcuni casi, i cluster possono essere difficili da interpretare, soprattutto se i dati sono molto rumorosi o se ci sono molte sovrapposizioni tra i cluster.
In conclusione, le SOM possono essere un ottimo punto di partenza per l'analisi di dati complessi e per la costruzione di modelli di previsione a breve termine. Combinando le SOM con altre tecniche statistiche e di apprendimento automatico, è possibile ottenere risultati molto promettenti.
 
Ultima modifica:
i risultati parlano da soli:

BARI : TEST SOM - Griglia Cluster 4 x 4 : fine data 12/12/2024
Rilevamento previsioni: primi 3 valori in 5°a colonna. Distanza MIN.

Inserisci il valore iniziale delle interazioni: 10
Inserisci il valore di progressione delle interazioni: 10
Inserisci il numero di progressioni: 10
Quante righe vuoi analizzare? (max 90): 90

estrazioni successive al Test:
13/12/2024 - 66 32 12 33 49
14/12/2024 - 89 61 43 52 01


Analisi per 10 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.0407
Cluster 3: Valore più vicino = [15 18 30 45 90] Dist. = 0.1919
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 0.2618
Cluster 1: Valore più vicino = [ 3 4 6 8 16] Dist. = 0.4000
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.4931
Cluster 15: Valore più vicino = [13 15 25 37 73] Dist. = 0.5786
Cluster 6: Valore più vicino = [12 14 24 35 70] Dist. = 0.6369
Cluster 13: Valore più vicino = [10 12 20 30 60] Dist. = 0.8053
Cluster 12: Valore più vicino = [ 3 3 5 8 15] Dist. = 0.8976
Cluster 8: Valore più vicino = [ 5 6 10 15 29] Dist. = 0.9101
Cluster 5: Valore più vicino = [14 16 27 40 80] Dist. = 0.9819
Cluster 4: Valore più vicino = [ 3 4 6 9 17] Dist. = 1.0587
Cluster 7: Valore più vicino = [ 9 11 17 26 51] Dist. = 1.1011
Cluster 11: Valore più vicino = [ 9 10 17 25 49] Dist. = 1.1066
Cluster 9: Valore più vicino = [11 13 21 31 61] Dist. = 1.2509
Cluster 10: Valore più vicino = [13 15 25 38 75] Dist. = 2.0320
Nessun dato trovato per il cluster 6.(90%)
Nessun dato trovato per il cluster 15.

Analisi per 20 interazioni: Ambo
Ordine di distanza dal centro del Cluster:
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.0813
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.1719
Cluster 8: Valore più vicino = [ 6 7 11 16 32] Dist. = 0.2505
Cluster 3: Valore più vicino = [15 18 30 45 90] Dist. = 0.3825
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 0.5207
Cluster 13: Valore più vicino = [11 13 21 32 63] Dist. = 0.5736
Cluster 12: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.5797
Cluster 7: Valore più vicino = [ 9 11 18 26 52] Dist. = 0.7237
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.7919
Cluster 10: Valore più vicino = [12 14 24 35 70] Dist. = 0.8197
Cluster 5: Valore più vicino = [14 16 27 40 79] Dist. = 1.0982
Cluster 9: Valore più vicino = [11 13 21 31 61] Dist. = 1.3149
Cluster 11: Valore più vicino = [ 9 11 18 27 53] Dist. = 1.4081
Cluster 4: Valore più vicino = [ 4 4 7 10 20] Dist. = 1.5370
Nessun dato trovato per il cluster 10.(90%)

Analisi per 30 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0600
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.1218
Cluster 12: Valore più vicino = [ 5 6 9 14 27] Dist. = 0.5057
Cluster 3: Valore più vicino = [15 18 30 45 90] Dist. = 0.5718
Cluster 7: Valore più vicino = [ 9 11 18 27 53] Dist. = 0.5947
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.6464
Cluster 9: Valore più vicino = [11 13 21 32 63] Dist. = 0.7757
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 0.7768
Cluster 11: Valore più vicino = [10 12 20 29 58] Dist. = 0.7837
Cluster 5: Valore più vicino = [13 16 26 39 77] Dist. = 0.9028
Cluster 4: Valore più vicino = [ 4 4 7 10 20] Dist. = 0.9261
Cluster 8: Valore più vicino = [ 6 7 12 18 35] Dist. = 1.0617
Cluster 15: Valore più vicino = [12 14 23 34 67] Dist. = 1.1939
Cluster 13: Valore più vicino = [11 13 22 33 65] Dist. = 1.2567
Cluster 6: Valore più vicino = [12 14 24 35 70] Dist. = 1.6777
Nessun dato trovato per il cluster 10.(90%)

Analisi per 40 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0209
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.1623
Cluster 12: Valore più vicino = [ 6 7 11 16 32] Dist. = 0.3576
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5482
Cluster 5: Valore più vicino = [13 16 26 39 77] Dist. = 0.5650
Cluster 8: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.6952
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.7199
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.8187
Cluster 13: Valore più vicino = [11 13 22 33 65] Dist. = 0.9020
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.0300
Cluster 11: Valore più vicino = [10 12 20 30 60] Dist. = 1.0559
Cluster 15: Valore più vicino = [12 14 23 34 67] Dist. = 1.0637
Cluster 7: Valore più vicino = [ 9 11 18 27 53] Dist. = 1.0748
Cluster 9: Valore più vicino = [11 13 21 32 63] Dist. = 1.4652
Cluster 6: Valore più vicino = [12 14 24 35 70] Dist. = 2.1009
Nessun dato trovato per il cluster 10.(90%)
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 50 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0073
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2028
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5527
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6014
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6934
Cluster 12: Valore più vicino = [ 6 8 12 18 36] Dist. = 0.6950
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9604
Cluster 8: Valore più vicino = [ 7 8 13 20 39] Dist. = 0.9831
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 1.0134
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1369
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.2804
Cluster 11: Valore più vicino = [11 13 21 31 61] Dist. = 1.3637
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.4252
Early stopping attivato dopo 51 interazioni.
Nessun dato trovato per il cluster 10.
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 60 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0066
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2068
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5566
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6405
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6606
Cluster 12: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.9492
Cluster 8: Valore più vicino = [ 7 8 14 20 40] Dist. = 0.9706
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9895
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 0.9942
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1153
Cluster 11: Valore più vicino = [11 13 21 32 63] Dist. = 1.2390
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.3053
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.3469
Early stopping attivato dopo 51 interazioni.
Nessun dato trovato per il cluster 10.
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 70 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0066
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2068
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5566
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6405
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6606
Cluster 12: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.9492
Cluster 8: Valore più vicino = [ 7 8 14 20 40] Dist. = 0.9706
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9895
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 0.9942
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1153
Cluster 11: Valore più vicino = [11 13 21 32 63] Dist. = 1.2390
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.3053
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.3469
Early stopping attivato dopo 51 interazioni.
Nessun dato trovato per il cluster 10.
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 80 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0066
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2068
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5566
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6405
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6606
Cluster 12: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.9492
Cluster 8: Valore più vicino = [ 7 8 14 20 40] Dist. = 0.9706
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9895
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 0.9942
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1153
Cluster 11: Valore più vicino = [11 13 21 32 63] Dist. = 1.2390
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.3053
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.3469
Early stopping attivato dopo 51 interazioni.
Nessun dato trovato per il cluster 10.
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 90 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0066
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2068
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5566
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6405
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6606
Cluster 12: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.9492
Cluster 8: Valore più vicino = [ 7 8 14 20 40] Dist. = 0.9706
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9895
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 0.9942
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1153
Cluster 11: Valore più vicino = [11 13 21 32 63] Dist. = 1.2390
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.3053
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.3469
Early stopping attivato dopo 51 interazioni.
Nessun dato trovato per il cluster 10.
Nessun dato trovato per il cluster 13.
Nessun dato trovato per il cluster 15.

Analisi per 100 interazioni:
Ordine di distanza dal centro del Cluster:
Cluster 14: Valore più vicino = [11 14 22 33 66] Dist. = 0.0066
Cluster 0: Valore più vicino = [ 8 9 15 22 43] Dist. = 0.2068
Cluster 3: Valore più vicino = [15 18 30 45 89] Dist. = 0.5566
Cluster 7: Valore più vicino = [10 11 19 28 55] Dist. = 0.6405
Cluster 4: Valore più vicino = [ 4 5 7 11 21] Dist. = 0.6606
Cluster 12: Valore più vicino = [ 7 8 13 19 37] Dist. = 0.9492
Cluster 8: Valore più vicino = [ 7 8 14 20 40] Dist. = 0.9706
Cluster 1: Valore più vicino = [ 3 4 6 9 17] Dist. = 0.9895
Cluster 9: Valore più vicino = [11 13 22 33 65] Dist. = 0.9942
Cluster 6: Valore più vicino = [12 14 23 34 67] Dist. = 1.1153
Cluster 11: Valore più vicino = [11 13 21 32 63] Dist. = 1.2390
Cluster 2: Valore più vicino = [ 8 10 16 23 46] Dist. = 1.3053
Cluster 5: Valore più vicino = [13 15 25 38 75] Dist. = 1.3469
Progressione delle interazioni: 90/100 (90%)

Frequenza dei numeri nella quinta colonna:
Numero Frequenza
43 10
46 10
17 10
66 10
21 8
63 8
65 8
67 8
75 7
89 7
37 6
55 6
40 5
70 4
90 3
61 3
53 3
60 2
20 2
32 2
77 2
16 1
80 1
51 1
29 1
49 1
15 1
73 1
79 1
52 1
35 1
58 1
27 1
39 1
36 1

Analisi completata!
Premi invio per chiudere...
 
complimenti per le tue analisi Halmun sicuramente complesse e affascinanti anche per profani come me che per adesso purtroppo non riescono a decifrarle... :) Riguardo a questo esempio avresti beccato 66 al 1° colpo e 43 al 2° in classe 4 su ruota unica di BA vero? 👋:)
 
complimenti per le tue analisi Halmun sicuramente complesse e affascinanti anche per profani come me che per adesso purtroppo non riescono a decifrarle... :) Riguardo a questo esempio avresti beccato 66 al 1° colpo e 43 al 2° in classe 4 su ruota unica di BA vero? 👋:)
complimenti per le tue analisi Halmun sicuramente complesse e affascinanti anche per profani come me che per adesso purtroppo non riescono a decifrarle... :) Riguardo a questo esempio avresti beccato 66 al 1° colpo e 43 al 2° in classe 4 su ruota unica di BA vero? 👋:)
mi scuso per la doppia replica. Esatto Tom. ma ti invito ad osservare il punto di rottura fra le 40 interazioni e le 100 interazioni, dove per le 40 interazioni abbiamo la Quartina 66 43 32 89 tutti centrati in 2 colpi. mentre dalle 50 alle 100 interazioni abbiamo la stabilizzazione di un'unica Terzina 66 43 89 .... attenzione ora ai successivi di questa terzina. naturalmente il tutto sempre e solo su BARI. riguardo il procedimento ho semplicemente riprodotto le funzioni basilari di NNCLUST ma con l'aggiunta di osservazioni del tutto personali sul tipo di ricerca.
 
dimenticavo. Epoche di apprendimento 100. con Rete resa Deterministica. quindi al ripetersi dell'analisi con gli stessi parametri d'ingresso restituisce esattamente gli stessi risultati dello SCAN precedente.
 
per chi vuole prendere spunti:

Introduzione:

In questa presentazione, illustrerò alcuni dettagli di uno script Python che utilizza una rete Self-Organizing Map (SOM) per analizzare le interazioni di un dataset.

Lo script è progettato per identificare i cluster presenti nel dataset e calcolare le distanze minime dal centro di ciascun cluster.

Verrà inoltre mostrata una classifica delle interazioni che hanno prodotto le distanze minime più basse.

Descrizione dello Script:

Importazione delle Librerie Necessarie:

numpy per le operazioni matematiche.

MiniSom per la rete Self-Organizing Map.

time per le funzioni di temporizzazione.

Counter dalla libreria collections per il conteggio delle frequenze.

Configurazione dei Parametri:

Lo script inizia richiedendo all'utente di inserire alcuni parametri: il numero iniziale di interazioni, il valore di progressione delle interazioni, il numero di progressioni e il numero di righe da analizzare.

Viene poi limitato il dataset in base alla richiesta dell'utente.

Definizione della Rete SOM:

La rete SOM viene configurata con dimensioni 4x4 e un tasso di apprendimento di 0.1.

La rete viene inizializzata con pesi casuali per garantire la riproducibilità dei risultati.

Addestramento della Rete SOM:

Il ciclo di addestramento viene eseguito per ogni progressione specificata dall'utente.

Viene utilizzata una tecnica di Early Stopping per fermare l'addestramento quando non vi sono miglioramenti nelle epoche successive.

Visualizzazione dei Cluster:

Lo script identifica i cluster vincenti per ogni dato del dataset.

Viene calcolata la distanza minima dal centro del cluster e mostrato il valore più vicino.

Viene gestito il caso in cui un cluster non contenga dati, segnalandolo opportunamente.

Calcolo delle Frequenze:

Viene calcolata la frequenza dei numeri presenti nella quinta colonna del dataset.

I risultati vengono ordinati per frequenza e mostrati all'utente.

Classifica delle Interazioni Vincenti:

Viene aggiunta una classifica finale che mostra le interazioni che hanno prodotto le distanze minime più basse.

Questa classifica permette di identificare rapidamente le iterazioni più efficaci.

Risultati:

un esempio di output dello script mostra la classifica delle interazioni vincenti.

nella foto abbiamo prima classificata l'interazione con 50 iterazioni, che ha prodotto le prime 3 previsioni centrate in brevissimo tempo.

Conclusione:

Questo script offre un metodo efficiente per analizzare e visualizzare i cluster presenti in un dataset utilizzando una rete SOM.

La classifica finale delle interazioni vincenti fornisce un'ulteriore analisi per identificare le iterazioni più efficaci.
 

Allegati

  • CLS-1.jpg
    CLS-1.jpg
    71,7 KB · Visite: 34
Grazie Halmun per l'ottima condivisione "operativa" :) . A tal riguardo ti chiedo se possibile come dovrebbe essere formattato il dataset? 💪👋🙂 . Un saluto anche a claudio altro tuo attento follower 😉
 
Grazie Halmun per l'ottima condivisione "operativa" :) . A tal riguardo ti chiedo se possibile come dovrebbe essere formattato il dataset? 💪👋🙂 . Un saluto anche a claudio altro tuo attento follower 😉
è lo stesso dataset a gruppi che abbiamo utilizzato tempo fa per la modifica di NNPRED fatta da luigiB
dove ogni colonna altro non è che la suddivisione dellle ambate contenute in 5°a colonna. solo che per PYTHON io ho utilizzato la versione Array in questo formato: qui sotto le ultime 18 estrazioni con fine data al 12/12/2024 poste in verticale. quindi in totale sono 90 righe esatte. ( un ciclo ).

X = np.array([
[ 11, 14, 22, 33, 66, ],
[ 10, 12, 20, 30, 59, ],
[ 6, 7, 12, 17, 34, ],
[ 11, 13, 21, 32, 63, ],
[ 10, 12, 20, 30, 60, ],
[ 10, 12, 19, 29, 57, ],
[ 8, 9, 15, 22, 43, ],
[ 13, 15, 25, 38, 75, ],
[ 5, 6, 10, 14, 28, ],
[ 5, 6, 10, 15, 29, ],
[ 1, 1, 2, 3, 5, ],
[ 15, 18, 30, 45, 90, ],
[ 11, 13, 21, 31, 61, ],
[ 13, 16, 26, 39, 77, ],
[ 7, 8, 13, 20, 39, ],
[ 3, 4, 6, 9, 17, ],
[ 5, 6, 10, 14, 28, ],
[ 13, 15, 25, 37, 73, ],
[ 15, 18, 30, 45, 90, ],
[ 2, 2, 3, 4, 7, ],
[ 9, 11, 17, 26, 51, ],
[ 4, 4, 7, 10, 20, ],
[ 9, 10, 17, 25, 49, ],
[ 5, 6, 9, 14, 27, ],
[ 12, 14, 23, 34, 67, ],
[ 1, 2, 2, 3, 6, ],
[ 14, 16, 27, 40, 79, ],
[ 5, 6, 10, 15, 30, ],
[ 9, 11, 18, 26, 52, ],
[ 3, 3, 5, 8, 15, ],
[ 5, 6, 9, 14, 27, ],
[ 8, 9, 15, 23, 45, ],
[ 14, 17, 27, 41, 81, ],
[ 3, 4, 6, 9, 17, ],
[ 10, 11, 19, 28, 55, ],
[ 6, 7, 11, 17, 33, ],
[ 14, 16, 27, 40, 80, ],
[ 15, 18, 29, 43, 86, ],
[ 9, 11, 18, 26, 52, ],
[ 5, 5, 9, 13, 25, ],
[ 6, 7, 12, 18, 35, ],
[ 3, 4, 6, 8, 16, ],
[ 4, 5, 8, 12, 24, ],
[ 7, 9, 14, 21, 41, ],
[ 15, 17, 29, 43, 85, ],
[ 9, 11, 18, 26, 52, ],
[ 14, 16, 27, 40, 79, ],
[ 12, 14, 24, 35, 70, ],
[ 14, 17, 28, 42, 83, ],
[ 9, 11, 17, 26, 51, ],
[ 5, 6, 10, 15, 29, ],
[ 4, 5, 8, 11, 22, ],
[ 9, 11, 18, 27, 53, ],
[ 11, 13, 22, 33, 65, ],
[ 2, 3, 4, 6, 12, ],
[ 5, 5, 9, 13, 25, ],
[ 8, 10, 16, 23, 46, ],
[ 7, 9, 14, 21, 41, ],
[ 14, 17, 28, 42, 83, ],
[ 15, 18, 30, 45, 89, ],
[ 7, 8, 13, 19, 38, ],
[ 5, 6, 9, 13, 26, ],
[ 10, 12, 20, 29, 58, ],
[ 6, 8, 12, 18, 36, ],
[ 11, 13, 22, 33, 65, ],
[ 6, 7, 11, 16, 32, ],
[ 6, 7, 12, 18, 35, ],
[ 9, 11, 17, 26, 51, ],
[ 5, 6, 9, 13, 26, ],
[ 14, 17, 28, 41, 82, ],
[ 2, 2, 3, 5, 9, ],
[ 8, 10, 16, 23, 46, ],
[ 3, 4, 6, 8, 16, ],
[ 4, 5, 7, 11, 21, ],
[ 13, 15, 25, 37, 73, ],
[ 7, 8, 13, 19, 37, ],
[ 4, 5, 7, 11, 21, ],
[ 2, 3, 4, 6, 12, ],
[ 14, 16, 27, 40, 79, ],
[ 3, 3, 5, 8, 15, ],
[ 14, 16, 27, 40, 79, ],
[ 3, 3, 5, 8, 15, ],
[ 12, 14, 24, 35, 70, ],
[ 7, 9, 14, 21, 41, ],
[ 9, 10, 17, 25, 49, ],
[ 2, 2, 3, 4, 7, ],
[ 7, 8, 14, 20, 40, ],
[ 10, 12, 20, 29, 58, ],
[ 9, 11, 18, 26, 52, ],
[ 6, 8, 12, 18, 36, ],
])
 
Ultima modifica:
è lo stesso dataset a gruppi che abbiamo utilizzato tempo fa per la modifica di NNPRED fatta da luigiB
dove ogni colonna altro non è che la suddivisione dellle ambate contenute in 5°a colonna. solo che per PYTHON io ho utilizzato la versione Array in questo formato: qui sotto le ultime 18 estrazioni con fine data al 12/12/2024 poste in verticale. quindi in totale sono 90 righe esatte. ( un ciclo ).

X = np.array([
[ 11, 14, 22, 33, 66, ],
[ 10, 12, 20, 30, 59, ],
[ 6, 7, 12, 17, 34, ],
[ 11, 13, 21, 32, 63, ],
[ 10, 12, 20, 30, 60, ],
[ 10, 12, 19, 29, 57, ],
[ 8, 9, 15, 22, 43, ],
[ 13, 15, 25, 38, 75, ],
[ 5, 6, 10, 14, 28, ],
[ 5, 6, 10, 15, 29, ],
[ 1, 1, 2, 3, 5, ],
[ 15, 18, 30, 45, 90, ],
[ 11, 13, 21, 31, 61, ],
[ 13, 16, 26, 39, 77, ],
[ 7, 8, 13, 20, 39, ],
[ 3, 4, 6, 9, 17, ],
[ 5, 6, 10, 14, 28, ],
[ 13, 15, 25, 37, 73, ],
[ 15, 18, 30, 45, 90, ],
[ 2, 2, 3, 4, 7, ],
[ 9, 11, 17, 26, 51, ],
[ 4, 4, 7, 10, 20, ],
[ 9, 10, 17, 25, 49, ],
[ 5, 6, 9, 14, 27, ],
[ 12, 14, 23, 34, 67, ],
[ 1, 2, 2, 3, 6, ],
[ 14, 16, 27, 40, 79, ],
[ 5, 6, 10, 15, 30, ],
[ 9, 11, 18, 26, 52, ],
[ 3, 3, 5, 8, 15, ],
[ 5, 6, 9, 14, 27, ],
[ 8, 9, 15, 23, 45, ],
[ 14, 17, 27, 41, 81, ],
[ 3, 4, 6, 9, 17, ],
[ 10, 11, 19, 28, 55, ],
[ 6, 7, 11, 17, 33, ],
[ 14, 16, 27, 40, 80, ],
[ 15, 18, 29, 43, 86, ],
[ 9, 11, 18, 26, 52, ],
[ 5, 5, 9, 13, 25, ],
[ 6, 7, 12, 18, 35, ],
[ 3, 4, 6, 8, 16, ],
[ 4, 5, 8, 12, 24, ],
[ 7, 9, 14, 21, 41, ],
[ 15, 17, 29, 43, 85, ],
[ 9, 11, 18, 26, 52, ],
[ 14, 16, 27, 40, 79, ],
[ 12, 14, 24, 35, 70, ],
[ 14, 17, 28, 42, 83, ],
[ 9, 11, 17, 26, 51, ],
[ 5, 6, 10, 15, 29, ],
[ 4, 5, 8, 11, 22, ],
[ 9, 11, 18, 27, 53, ],
[ 11, 13, 22, 33, 65, ],
[ 2, 3, 4, 6, 12, ],
[ 5, 5, 9, 13, 25, ],
[ 8, 10, 16, 23, 46, ],
[ 7, 9, 14, 21, 41, ],
[ 14, 17, 28, 42, 83, ],
[ 15, 18, 30, 45, 89, ],
[ 7, 8, 13, 19, 38, ],
[ 5, 6, 9, 13, 26, ],
[ 10, 12, 20, 29, 58, ],
[ 6, 8, 12, 18, 36, ],
[ 11, 13, 22, 33, 65, ],
[ 6, 7, 11, 16, 32, ],
[ 6, 7, 12, 18, 35, ],
[ 9, 11, 17, 26, 51, ],
[ 5, 6, 9, 13, 26, ],
[ 14, 17, 28, 41, 82, ],
[ 2, 2, 3, 5, 9, ],
[ 8, 10, 16, 23, 46, ],
[ 3, 4, 6, 8, 16, ],
[ 4, 5, 7, 11, 21, ],
[ 13, 15, 25, 37, 73, ],
[ 7, 8, 13, 19, 37, ],
[ 4, 5, 7, 11, 21, ],
[ 2, 3, 4, 6, 12, ],
[ 14, 16, 27, 40, 79, ],
[ 3, 3, 5, 8, 15, ],
[ 14, 16, 27, 40, 79, ],
[ 3, 3, 5, 8, 15, ],
[ 12, 14, 24, 35, 70, ],
[ 7, 9, 14, 21, 41, ],
[ 9, 10, 17, 25, 49, ],
[ 2, 2, 3, 4, 7, ],
[ 7, 8, 14, 20, 40, ],
[ 10, 12, 20, 29, 58, ],
[ 9, 11, 18, 26, 52, ],
[ 6, 8, 12, 18, 36, ],
])

Halmun, scusa ma non ho capito bene... quando dici "dove ogni colonna altro non è che la suddivisione dellle ambate contenute in 5°a colonna" cosa intendi di preciso? Puoi farmi un esempio pratico di riferimento? Tnx :)
 
Halmun, scusa ma non ho capito bene... quando dici "dove ogni colonna altro non è che la suddivisione dellle ambate contenute in 5°a colonna" cosa intendi di preciso? Puoi farmi un esempio pratico di riferimento? Tnx :)
faccio prima a darti tutta la tabella completa che a spiegartela:
ecco la tabella di conversione per ogni singolo numero da 01 a 90.
ad ogni numero corrisponde una riga specifica. quindi come input puoi utilizzare ad esempio le ultime 5 colonne come ho fatto io
dove le prime 4 sono gli input e l'ultima è il target ( le ambate ) naturalmente dovrai farti un foglio excel per il cerca.vert di qualsiasi colonna ambate formata da 90 celle consecutive.

1 1 1 1 1 1 1 1 1 1 1
2 1 1 1 1 1 1 1 1 1 2
3 1 1 1 1 1 1 1 1 2 3
4 1 1 1 1 1 1 1 2 2 4
5 1 1 1 1 1 1 1 2 3 5
6 1 1 1 1 1 1 2 2 3 6
7 1 1 1 1 1 2 2 3 4 7
8 1 1 1 1 1 2 2 3 4 8
9 1 1 1 1 1 2 2 3 5 9
10 1 1 1 1 2 2 2 4 5 10
11 1 1 1 2 2 2 3 4 6 11
12 1 1 1 2 2 2 3 4 6 12
13 1 1 1 2 2 3 3 5 7 13
14 1 1 1 2 2 3 3 5 7 14
15 1 1 1 2 2 3 3 5 8 15
16 1 1 2 2 2 3 4 6 8 16
17 1 1 2 2 2 3 4 6 9 17
18 1 1 2 2 2 3 4 6 9 18
19 1 2 2 2 3 4 4 7 10 19
20 1 2 2 2 3 4 4 7 10 20
21 1 2 2 3 3 4 5 7 11 21
22 1 2 2 3 3 4 5 8 11 22
23 1 2 2 3 3 4 5 8 12 23
24 1 2 2 3 3 4 5 8 12 24
25 1 2 2 3 3 5 5 9 13 25
26 1 2 2 3 3 5 6 9 13 26
27 1 2 2 3 3 5 6 9 14 27
28 1 2 2 3 4 5 6 10 14 28
29 1 2 2 3 4 5 6 10 15 29
30 1 2 2 3 4 5 6 10 15 30
31 2 2 3 4 4 6 7 11 16 31
32 2 2 3 4 4 6 7 11 16 32
33 2 2 3 4 4 6 7 11 17 33
34 2 2 3 4 4 6 7 12 17 34
35 2 2 3 4 4 6 7 12 18 35
36 2 2 3 4 4 6 8 12 18 36
37 2 3 3 4 5 7 8 13 19 37
38 2 3 3 4 5 7 8 13 19 38
39 2 3 3 4 5 7 8 13 20 39
40 2 3 3 4 5 7 8 14 20 40
41 2 3 3 5 5 7 9 14 21 41
42 2 3 3 5 5 7 9 14 21 42
43 2 3 3 5 5 8 9 15 22 43
44 2 3 3 5 5 8 9 15 22 44
45 2 3 3 5 5 8 9 15 23 45
46 2 3 4 5 6 8 10 16 23 46
47 2 3 4 5 6 8 10 16 24 47
48 2 3 4 5 6 8 10 16 24 48
49 2 3 4 5 6 9 10 17 25 49
50 2 3 4 5 6 9 10 17 25 50
51 2 3 4 6 6 9 11 17 26 51
52 2 3 4 6 6 9 11 18 26 52
53 2 3 4 6 6 9 11 18 27 53
54 2 3 4 6 6 9 11 18 27 54
55 2 4 4 6 7 10 11 19 28 55
56 2 4 4 6 7 10 12 19 28 56
57 2 4 4 6 7 10 12 19 29 57
58 2 4 4 6 7 10 12 20 29 58
59 2 4 4 6 7 10 12 20 30 59
60 2 4 4 6 7 10 12 20 30 60
61 3 4 5 7 7 11 13 21 31 61
62 3 4 5 7 7 11 13 21 31 62
63 3 4 5 7 7 11 13 21 32 63
64 3 4 5 7 8 11 13 22 32 64
65 3 4 5 7 8 11 13 22 33 65
66 3 4 5 7 8 11 14 22 33 66
67 3 4 5 7 8 12 14 23 34 67
68 3 4 5 7 8 12 14 23 34 68
69 3 4 5 7 8 12 14 23 35 69
70 3 4 5 7 8 12 14 24 35 70
71 3 4 5 8 8 12 15 24 36 71
72 3 4 5 8 8 12 15 24 36 72
73 3 5 5 8 9 13 15 25 37 73
74 3 5 5 8 9 13 15 25 37 74
75 3 5 5 8 9 13 15 25 38 75
76 3 5 6 8 9 13 16 26 38 76
77 3 5 6 8 9 13 16 26 39 77
78 3 5 6 8 9 13 16 26 39 78
79 3 5 6 8 9 14 16 27 40 79
80 3 5 6 8 9 14 16 27 40 80
81 3 5 6 9 9 14 17 27 41 81
82 3 5 6 9 10 14 17 28 41 82
83 3 5 6 9 10 14 17 28 42 83
84 3 5 6 9 10 14 17 28 42 84
85 3 5 6 9 10 15 17 29 43 85
86 3 5 6 9 10 15 18 29 43 86
87 3 5 6 9 10 15 18 29 44 87
88 3 5 6 9 10 15 18 30 44 88
89 3 5 6 9 10 15 18 30 45 89
90 3 5 6 9 10 15 18 30 45 90
 
faccio prima a darti tutta la tabella completa che a spiegartela:
ecco la tabella di conversione per ogni singolo numero da 01 a 90.
ad ogni numero corrisponde una riga specifica. quindi come input puoi utilizzare ad esempio le ultime 5 colonne come ho fatto io
dove le prime 4 sono gli input e l'ultima è il target ( le ambate ) naturalmente dovrai farti un foglio excel per il cerca.vert di qualsiasi colonna ambate formata da 90 celle consecutive.

1 1 1 1 1 1 1 1 1 1 1
2 1 1 1 1 1 1 1 1 1 2
3 1 1 1 1 1 1 1 1 2 3
4 1 1 1 1 1 1 1 2 2 4
5 1 1 1 1 1 1 1 2 3 5
6 1 1 1 1 1 1 2 2 3 6
7 1 1 1 1 1 2 2 3 4 7
8 1 1 1 1 1 2 2 3 4 8
9 1 1 1 1 1 2 2 3 5 9
10 1 1 1 1 2 2 2 4 5 10
11 1 1 1 2 2 2 3 4 6 11
12 1 1 1 2 2 2 3 4 6 12
13 1 1 1 2 2 3 3 5 7 13
14 1 1 1 2 2 3 3 5 7 14
15 1 1 1 2 2 3 3 5 8 15
16 1 1 2 2 2 3 4 6 8 16
17 1 1 2 2 2 3 4 6 9 17
18 1 1 2 2 2 3 4 6 9 18
19 1 2 2 2 3 4 4 7 10 19
20 1 2 2 2 3 4 4 7 10 20
21 1 2 2 3 3 4 5 7 11 21
22 1 2 2 3 3 4 5 8 11 22
23 1 2 2 3 3 4 5 8 12 23
24 1 2 2 3 3 4 5 8 12 24
25 1 2 2 3 3 5 5 9 13 25
26 1 2 2 3 3 5 6 9 13 26
27 1 2 2 3 3 5 6 9 14 27
28 1 2 2 3 4 5 6 10 14 28
29 1 2 2 3 4 5 6 10 15 29
30 1 2 2 3 4 5 6 10 15 30
31 2 2 3 4 4 6 7 11 16 31
32 2 2 3 4 4 6 7 11 16 32
33 2 2 3 4 4 6 7 11 17 33
34 2 2 3 4 4 6 7 12 17 34
35 2 2 3 4 4 6 7 12 18 35
36 2 2 3 4 4 6 8 12 18 36
37 2 3 3 4 5 7 8 13 19 37
38 2 3 3 4 5 7 8 13 19 38
39 2 3 3 4 5 7 8 13 20 39
40 2 3 3 4 5 7 8 14 20 40
41 2 3 3 5 5 7 9 14 21 41
42 2 3 3 5 5 7 9 14 21 42
43 2 3 3 5 5 8 9 15 22 43
44 2 3 3 5 5 8 9 15 22 44
45 2 3 3 5 5 8 9 15 23 45
46 2 3 4 5 6 8 10 16 23 46
47 2 3 4 5 6 8 10 16 24 47
48 2 3 4 5 6 8 10 16 24 48
49 2 3 4 5 6 9 10 17 25 49
50 2 3 4 5 6 9 10 17 25 50
51 2 3 4 6 6 9 11 17 26 51
52 2 3 4 6 6 9 11 18 26 52
53 2 3 4 6 6 9 11 18 27 53
54 2 3 4 6 6 9 11 18 27 54
55 2 4 4 6 7 10 11 19 28 55
56 2 4 4 6 7 10 12 19 28 56
57 2 4 4 6 7 10 12 19 29 57
58 2 4 4 6 7 10 12 20 29 58
59 2 4 4 6 7 10 12 20 30 59
60 2 4 4 6 7 10 12 20 30 60
61 3 4 5 7 7 11 13 21 31 61
62 3 4 5 7 7 11 13 21 31 62
63 3 4 5 7 7 11 13 21 32 63
64 3 4 5 7 8 11 13 22 32 64
65 3 4 5 7 8 11 13 22 33 65
66 3 4 5 7 8 11 14 22 33 66
67 3 4 5 7 8 12 14 23 34 67
68 3 4 5 7 8 12 14 23 34 68
69 3 4 5 7 8 12 14 23 35 69
70 3 4 5 7 8 12 14 24 35 70
71 3 4 5 8 8 12 15 24 36 71
72 3 4 5 8 8 12 15 24 36 72
73 3 5 5 8 9 13 15 25 37 73
74 3 5 5 8 9 13 15 25 37 74
75 3 5 5 8 9 13 15 25 38 75
76 3 5 6 8 9 13 16 26 38 76
77 3 5 6 8 9 13 16 26 39 77
78 3 5 6 8 9 13 16 26 39 78
79 3 5 6 8 9 14 16 27 40 79
80 3 5 6 8 9 14 16 27 40 80
81 3 5 6 9 9 14 17 27 41 81
82 3 5 6 9 10 14 17 28 41 82
83 3 5 6 9 10 14 17 28 42 83
84 3 5 6 9 10 14 17 28 42 84
85 3 5 6 9 10 15 17 29 43 85
86 3 5 6 9 10 15 18 29 43 86
87 3 5 6 9 10 15 18 29 44 87
88 3 5 6 9 10 15 18 30 44 88
89 3 5 6 9 10 15 18 30 45 89
90 3 5 6 9 10 15 18 30 45 90

Grazie ma sono completamente in alto mare... Comunque se riesce a capirci qualcosa l'AI ti faccio sapere 👋 :)
 
ESEMPIO: quali sono i 4 valori che precedono il numero 83? ..... eccoli: 14 17 28 42 83 ...... questo tipo di dataset permette anche di valutare determinate distanze dall'83 e queste distanze sono per l'appunto le suddivisioni x2, x3, x5, e x6.
facciamo un esempio con la prima colonna che suddivide tutti i numeri per gruppi di 2. al gruppo 45 appartengono i numeri 89 e 90. al gruppo 44 appartengono i numeri 87 e 88. ecc. ecc. se passi alle altre colonne vedrai che sono sempre valori divisibili delle ambate primarie dell'ultima colonna.
 
Ultima modifica:
forse un esempio in foto chiarirà come sono suddivisi i numeri per Gruppi: esempio, al gruppo 8 in 4°a colonna corrispondono le ambate:

43
44
45
46
47
48
e questo tipo di suddivisione ha anche il grande vantaggio di agevolare e velocizzare l'allineamento ( residui ) fra target e output quando si analizzano i dataset colonnari con le reti neurali, senza dover ricorrere alla normalizzazione dei dati per agevolare l'apprendimento. in quanto ogni singola colonna presenta un valore elevato di R2 e di correlazione con l'ultima colonna ( Target ).
 

Allegati

  • ESEMPIO 2.jpg
    ESEMPIO 2.jpg
    187,5 KB · Visite: 30
Ultima modifica:
Purtroppo nada... spero che almeno claudio riesca a seguirti :) Intanto io sto testando altre cose python , ai e reti neurali con supporto di gpu... Da un test su plaidml x uso gpu con keras mi risulterebbero queste due su BA. Previsioni per i prossimi cinque numeri: [0.0, 0.0, 0.0, 90.0, 14.00000050663948] . Per caso tornano anche a te? Ad ogni modo qualche volta proverò a direzionare le mie ricerche sulla tua ruota preferita di BA per vedere appunto se da punti di ricerca completamente diversi possano risultare o meno risultanze su ruota unica in 3 colpi teorici in micro lunghetta xs1 o sup. identiche 👋 :)
 
Purtroppo nada... spero che almeno claudio riesca a seguirti :) Intanto io sto testando altre cose python , ai e reti neurali con supporto di gpu... Da un test su plaidml x uso gpu con keras mi risulterebbero queste due su BA. Previsioni per i prossimi cinque numeri: [0.0, 0.0, 0.0, 90.0, 14.00000050663948] . Per caso tornano anche a te? Ad ogni modo qualche volta proverò a direzionare le mie ricerche sulla tua ruota preferita di BA per vedere appunto se da punti di ricerca completamente diversi possano risultare o meno risultanze su ruota unica in 3 colpi teorici in micro lunghetta xs1 o sup. identiche 👋 :)
si, alla penultima avevo il 90 piazzato, ma con l'uscita dell'89 è saltato il gruppo 45 ( coppia 89-90 ) compreso l'1 laterali del 90 .... cmq. vediamo, magari si presenta a breve anche il 90.
 

Allegati

  • 90.jpg
    90.jpg
    32,4 KB · Visite: 25
Come immaginavo. spostando il Target dalla 5°a colonna alla 4°a ( quindi sulla colonna del 1° divisibile x2 ) abbiamo mantenuto la stessa attendibilità sulle previsioni più frequenti. con Fine data al 12/12/2024 come nei test precedenti abbiamo :
Ambo in quartina 32 33 al 1° C. con Primaria sul 33 ..... e in ultima analisi possiamo dire tranquillamente che vi è anche questo fra i vantaggi dei dataset con colonne divisibili, sopratutto quando queste vengono utilizzate come Target alternativi a titolo di confronto e supporto con i risultati del Target Primario.
 

Allegati

  • 32 33.jpg
    32 33.jpg
    171,8 KB · Visite: 21
Ultima modifica:
forse un esempio in foto chiarirà come sono suddivisi i numeri per Gruppi: esempio, al gruppo 8 in 4°a colonna corrispondono le ambate:

43
44
45
46
47
48
e questo tipo di suddivisione ha anche il grande vantaggio di agevolare e velocizzare l'allineamento ( residui ) fra target e output quando si analizzano i dataset colonnari con le reti neurali, senza dover ricorrere alla normalizzazione dei dati per agevolare l'apprendimento. in quanto ogni singola colonna presenta un valore elevato di R2 e di correlazione con l'ultima colonna ( Target ).
Innanzi tutto, un grazie infinto Halmun x aver condiviso la Tabella Completa della suddivisione di ogni numero! E grazie per i tui studi.
Una domanda:
quando e perchè variare la lunghezza della suddivisione (del singolo numero) da prendere in considerazione (con riferimento ad NNpred)?
Cioè: negli esempi iniziali avevi preso in considerazione x es. il n. 17 e veniva considerato SOLO con i 4 valori precedenti (3,4,6,9), ora abbia-
mo una suddivisione fino a 9 valori precedenti (1 1 2 2 2 3 4 6 9). La scelta di prendere in considerazione 4, 6, oppure 9 valori di suddivisione da cosa dipende? La suddivisione a "9 valori" è solo x NNclust?
Grazie in anticipo per la tua risposta.
 
Innanzi tutto, un grazie infinto Halmun x aver condiviso la Tabella Completa della suddivisione di ogni numero! E grazie per i tui studi.
Una domanda:
quando e perchè variare la lunghezza della suddivisione (del singolo numero) da prendere in considerazione (con riferimento ad NNpred)?
Cioè: negli esempi iniziali avevi preso in considerazione x es. il n. 17 e veniva considerato SOLO con i 4 valori precedenti (3,4,6,9), ora abbia-
mo una suddivisione fino a 9 valori precedenti (1 1 2 2 2 3 4 6 9). La scelta di prendere in considerazione 4, 6, oppure 9 valori di suddivisione da cosa dipende? La suddivisione a "9 valori" è solo x NNclust?
Grazie in anticipo per la tua risposta.
ciao, Mark555, grazie per l'attenzione. il motivo è semplice e dipende prevalentemente da quello che vogliamo ottenere nei tanti risultati delle Profile di NNPRED. come avrai sperimentato NNPRED mette a disposizione una pagina chiamata PROFILE dove è possibile osservare la sequenza dei 100 punti di default (previsioni) ricavati dalle analisi per qualsiasi range analizzato. quindi se ad esempio abbiamo un range da analizzare composto da 4 colonne Cont e 1 colonna Output avrai per forza di cose 4 Profili da analizzare a Pag. PROFILE. l'ultimo valore di ogni sequenza è di fatto il valore prevvisto di Default da NNPRED che ritrovi anche in cella AF-110 a Pag. CALC. Naturalmente è solo l'ultimo valore della sequenza data dall'apprendimento, ma nessuno ti vieta di osservare anche i primi valori della sequenza che non hanno nulla da invidiare agli ultimi valori considerati più attendibili. ora tutto questo vale per una sola colonna che trovi a Pag. Profile, ma se le colonne analizzate CONT sono 4 va da se che avrai 4 Profile da analizzare e successivamente scegliere fra i valori min media e max di ogni singola Profile prodotta le anbate che ritieni più opportune. e qui veniamo finalmente alla suddivisione per gruppi divisibili per ogni singolo numero da 01 a 90. mediamente la regola standard delle reti neurali cita quanto segue: all'aumentare delle colonne Input ( CONT in NNPRED ) si avrà un miglior apprendimento e soprattutto migliori previsioni ( questo perlomeno in teoria). pertanto ecco spiegato il motivo della suddivisione fino a 9 colonne divisibili che nasce dall'esigenza di migliore il più possibile l'apprendimento delle rete neurale attraverso un maggior numero di colonne CONT e di conseguenza avere nelle 9 PROFILE valori considerati mediamente più attendibili, ma in sostanza gli input-CONT che di fatto contengono i valori divisibili dei valori in colonna Output ( vedi pag. DATA ) sono praticamante gli stessi della colonna OUTPUT, con l'unica differenza di esser espressi in forma divisibile semplicemente per mantenere un FORTE relazione con i valori primari posti in colonna Target ( corrsispondente alla colonna OUTPUT a PAG. Data ).
 
Ultima modifica:

Ultima estrazione Lotto

  • Estrazione del lotto
    sabato 18 gennaio 2025
    Bari
    24
    76
    02
    72
    12
    Cagliari
    21
    08
    77
    04
    17
    Firenze
    74
    84
    07
    12
    72
    Genova
    13
    07
    33
    47
    18
    Milano
    01
    34
    09
    55
    48
    Napoli
    46
    23
    25
    03
    06
    Palermo
    44
    07
    01
    46
    84
    Roma
    88
    78
    64
    74
    04
    Torino
    07
    87
    67
    38
    53
    Venezia
    31
    25
    04
    18
    02
    Nazionale
    49
    82
    59
    65
    67
    Estrazione Simbolotto
    Bari
    03
    13
    31
    23
    35
Indietro
Alto