Controllare la tecnologia nell'era dell'Intelligenza Artificiale: una prospettiva dal lato del Software Libero
Miglioramenti tecnici, l'accumulo di un gran numero di dati dettagliati e l'avanzamento nelle prestazioni hardware dei computer hanno portato ad una rivoluzione dell'Intelligenza Artificiale (IA). Ad esempio, una grande progresso nella visione artificiale ha permesso di prendere decisioni automatiche sulla base di immagini e video, e la costruzione di un'ampia base dati e il miglioramento dell'analisi testuale combinate con la raccolta di dati personali hanno fatto nascere un'innumerevole quantità di applicazioni IA. Queste nuove applicazioni IA hanno portati molti benefici ai cittadini dell'Unione Europea (UE). Ma, data la sua insita complessità e i suoi requisiti a riguardo delle risorse e della conoscenza tecnica, l'IA può pregiudicare la nostra capacità di controllare la tecnologia e mette a rischio le libertà fondamentali. È quindi utile fissarsi come obiettivo quello di introdurre nuove leggi sull'IA.
Nel contesto di una nuova legislazione, questo articolo spiega come il rilascio delle applicazioni IA con licenze di Software Libero possa spianare la strada per una maggiore accessibilità, trasparenza ed imparzialità.
Cos'è il Software Libero?
Il Software Libero (conosciuto anche come Open Source) aiuta le persone a controllare la tecnologia garantendo ad ogni utente quattro libertà:
- La libertà di usare il software per ogni scopo, senza alcuna limitazione geografica.
- La libertà di studiare il software, senza accordi di non divulgazione.
- La libertà di condividere il software e copiarlo a costo zero.
- La libertà di perfezionare il software e di condividerne i miglioramenti.
Queste libertà sono garantite rilasciando il software con una licenza di Software Libero, i cui termini sono compatibili con le suddette libertà. Ci sono molteplici licenze di Software Libero per diversi scopi. Un software può essere rilasciato con più di una licenza. Per poter essere modificata liberamente, una IA richiede che venga fornito sia il codice di apprendimento che i dati, ed entrambi devono essere rilasciati con una licenza di Software Libero affinché l'IA venga considerata libera.
Accessibilità
L'accessibilità per l'IA significa renderla riutilizzabile, così che ciascuno possa personalizzarla, migliorarla e utilizzarla per i propri scopi. Per rendere l'IA riutilizzabile, occorre che venga rilasciata con una licenza di Software Libero. Sono moltissimi i vantaggi di questo approccio. Avendo delle basi legali aperte, una IA libera promuove l'innovazione, perché non si ha a che fare con restrizioni artificiose che impediscono alle persone di riutilizzare del lavoro già fatto. Rendere l'IA libera evita quindi dal dover reinventare ogni volta la ruota, permettendo allo stesso tempo ai ricercatori e agli sviluppatori di focalizzarsi nel creare software IA nuovo e migliore invece di ricostruire e ricreare ripetutamente i blocchi e il lavoro già fatto. In aggiunta al miglioramento dell'efficienza condividendo la competenza, le IA libere abbassano anche i costi di sviluppo risparmiando tempo ed eliminando i costi di licenza. Tutto questo migliora l'accessibilità dell'IA, che porta a soluzioni migliori e più democratiche dal momento che tutti possono parteciparvi.
Rendere l'IA riutilizzabile fa diventare anche più semplice costruire modelli IA specializzati partendo da quelli più generici. Se un modello IA generico venisse rilasciato come Software Libero, piuttosto che creare un nuovo modello da zero si potrebbe utilizzare il modello generico come punto di partenza per uno specifico compito base (downstream task) per la previsione. Ad esempio, si potrebbe utilizzare un modello generico di visione artificiale1,2 come punto di partenza per gestire l'infrastruttura pubblica che richiede elaborazioni di immagine specifici. Semplicemente come l'accessibilità in generale, questo approccio ha un vantaggio principale: i modelli generici con molti parametri ed addestrati su un grande insieme di dati potrebbero rendere il compito base più semplice da apprendere. Questo rende l'IA più accessibile abbassando la soglia di ingresso, rendendone più semplice il suo riutilizzo.
Rendere liberi sia il codice sorgente per addestrare l'IA che i dati corrispondenti potrebbe non essere sufficiente per rendere l'IA accessibile. L'IA richiede un enorme mole di dati per identificare gli schemi e le correlazioni che portano a delle corrette previsioni. Al contrario, non avere abbastanza dati reduce la sua capacità di capire il mondo circostante. Inoltre, insiemi di dati numerosi e la loro relativa complessità tendono ad ingigantire i modelli IA, rendendo il loro l'addestramento dispendioso in termini di tempo e di risorse. La complessità nel gestire i dati richiesti per addestrare i modelli IA, insieme alla conoscenza richiesta per svilupparli e la gestione delle capacità computazionali, richiede molto capitale umano. Può essere quindi difficile avvalersi delle libertà offerta da una IA libera, anche quando il codice sorgente e i dati per addestrarla venissero rilasciati come Software Libero. In questi casi, rilasciare i modelli già addestrati come Software Libero migliorerebbe di molto l'accessibilità.
Infine, occorrerebbe notare che, come ogni altra tecnologia, rendere l'IA riutilizzabile da chiunque può essere potenzialmente dannoso. Ad esempio, riutilizzare un rilevatore di volti rilasciato come Software Libero come parte di un software di riconoscimento facciale può causare problemi per i diritti umani. Questo è comunque vero a prescindere dalla tecnologia utilizzata. Se un utilizzo particolare di un software è ritenuto dannoso, dovrebbe essere proibito senza un'esplicita messa al bando della tecnologia IA.
Trasparenza
La trasparenza dell'IA può essere suddivisa in apertura e interpretabilità. In questo contesto, l'apertura è definita come il diritto di essere informati sul software IA, e l'interpretabilità è definita come essere in grado di capire come i dati in ingresso vengono processati in modo che si possano identificare i fattori presi in considerazione per fare le previsioni e la loro relativa importanza. In Europa, il diritto di essere informati sulle decisioni di un algoritmo è garantito dal considerando 71 del Regolamento Generale sulla Protezione dei Dati (GDPR) 2016/679: «In ogni caso, tale trattamento dovrebbe essere subordinato a garanzie adeguate, che dovrebbero comprendere la specifica informazione all'interessato e il diritto di ottenere l'intervento umano, di esprimere la propria opinione, di ottenere una spiegazione della decisione conseguita dopo tale valutazione e di contestare la decisione». La trasparenza può essere quindi definita come la capacità di capire da cosa sono guidate le previsioni.
L'IA ha bisogno di essere trasparente perché è utilizzata per questioni critiche. Ad esempio, è utilizzata per determinare la solvibilità3, nelle auto a guida autonoma4, nelle previsioni delle attività criminali5 o nell'assistenza sanitaria6. In questi contesti, è quindi fondamentale avere le informazioni su come queste previsioni sono fatte, e dovrebbero essere rese disponibili le informazioni sui dati utilizzati e come questi vengono processati dall'IA. In questo caso, la fiducia e l'adozione dell'IA sarebbero di conseguenza maggiori. Inoltre, le moderne tecnologie IA, come l'apprendimento profondo, non sono pensate per essere trasparenti, perché sono composte da milioni o miliardi di singoli parametri7, rendendole molto complesse e difficili da capire. In questo ambito è quindi dovuto l'utilizzo del Software Libero, attraverso il quale è possibile cercare di analizzare queste complessità.
Esistono già tecnologie rilasciate come Software Libero per rendere l'IA più trasparente. Ad esempio, Local Interpretable Model-Agnostic Explanations (LIME)8 è un pacchetto software che semplifica un modello di previsione complesso simulandolo con una versione più semplice e maggiormente interpretabile, e quindi permette agli utenti dell'IA di capire quali parametri giocano un ruolo nella previsione. La figura 1 mostra questo processo confrontando le previsioni fatte da due modelli diversi. Captum9 è una libreria rilasciata come Software Libero che fornisce un meccanismo di attribuzione per capire l'importanza relativa di ciascuna delle variabili di ingresso e di ogni parametro di un modello ad apprendimento profondo. È quindi fattibile rendere l'IA più trasparente.
Anche se una IA proprietaria può essere trasparente, il Software Libero aiuta questo processo rendendo la verifica e il controllo più semplici. Nonostante alcuni dati potrebbero essere troppo sensibili per essere rilasciati con una licenza di Software Libero, le proprietà statistiche dei dati possono essere pubblicate. Con il Software Libero, ognuno è in grado di far funzionare l'IA per capire come è fatta, e vedere i dati che vengono da essa elaborati. Occorre però notare che il modello IA, composto da milioni o miliardi di parametri, non è fatto per essere trasparente, ma, simulando il modello IA con uno molto più semplice, può essere più facile controllarlo.
Un altro beneficio del Software Libero in questo contesto è dato dal fatto che, dal momento che si ha il diritto di migliorare il software IA e condividere questi miglioramenti con altri, ciascuno può aumentarne la trasparenza, prevenendo pertanto la dipendenza dai fornitori dove si dovrebbe aspettare che chi fornisce il software renda l'IA più trasparente.
Imparzialità
Nell'ambito dell'intelligenza artificiale (IA), l'imparzialità è definita nel senso di rendere l'IA libera da pericolose discriminazioni basate sulle caratteristiche sensibili di un individuo, come il genere, l'etnia, la religione, le disabilità o l'orientamento sessuale. Dal momento che i modelli IA sono addestrati su insiemi di dati che contengono comportamenti e attività umane che possono non essere imparziali e che i modelli IA sono progettati per riconoscere e riprodurre schemi esistenti, è possibile creare discriminazioni dannose e violazioni dei diritti umani. Ad esempio, si è scoperto che (COMPAS)10, un algoritmo che attribuisce un punteggio che indica quanto sia probabile che una persona sia recidiva sul proprio crimine, non fosse imparziale verso gli afroamericani11, perché per essi il 44.9% dei casi erano falsi positivi. L'algoritmo attribuiva un'alta possibilità di recidiva nonostante gli accusati non reiterassero i crimini. Al contrario, il 47.7% dei casi per persone di razza bianca sono stati classificati a basso rischio di recidiva benché il crimine fosse poi stato reiterato. Una sospetta mancanza di imparzialità è stata trovata anche nell'assistenza sanitaria12, dove un algoritmo è stato utilizzato per attribuire un fattore di rischio ai pazienti, identificando di conseguenza il bisogno di assegnargli risorse curative aggiuntive. Per avere lo stesso fattore di rischio dei bianchi, le persone di colore dovevano essere in una situazione di salute peggiore, in termini di gravità nell'ipertensione, nel diabete, nell'anemia, nell'alto livello di colesterolo o nell'insufficienza renale. Esistono quindi problemi reali di imparzialità negli algoritmi IA. Per di più, da una prospettiva legale, il controllo di problematiche di imparzialità è indicato dal considerando 71 del GDPR, che richiede di «impedire tra l'altro effetti discriminatori nei confronti di persone fisiche sulla base della razza o dell'origine etnica, delle opinioni politiche, della religione o delle convinzioni personali, dell'appartenenza sindacale, dello status genetico, dello stato di salute o dell'orientamento sessuale, ovvero che comportano misure aventi tali effetti». Abbiamo quindi bisogno di soluzioni per identificare potenziali problemi di imparzialità nell'insieme dei dati utilizzato per addestrare l'IA, e correggerli nel caso dovessero insorgere.
Per determinare l'imparzialità, c'è bisogno di quantificarla. Ci sono molti modi per definire l'imparzialità nell'IA, che ricadono in due diversi tipi di approcci. Il primo verifica che raggruppamenti di persone secondo alcune caratteristiche sensibili vengano trattati in modo simile dall'algoritmo, ad esempio in termini di accuratezza, di tasso di veri positivi e di falsi positivi. Il secondo approccio misura l'imparzialità a livello individuale assicurandosi che persone simili siano trattate in modo simile dall'algoritmo13. Più formalmente, vengono confrontate la distanze misurate tra i campioni dell'insieme di dati e le distanze misurate tra le previsioni dell'algoritmo, per assicurarsi che il loro rapporto sia coerente. Purtroppo, soddisfare l'imparzialità di gruppo e l'imparzialità individuale allo stesso tempo potrebbe non essere possibile14. Ci sono tre metodi normalmente utilizzati per mitigare i problemi di imparzialità quando questi vengano riscontrati:
- Togliere gli attributi sensibili (ad esempio il genere, l'etnia, la religione, ecc.) dall'insieme dei dati. Questo approccio non funziona in uno scenario reale perché rimuovere gli attributi sensibili non è sufficiente per mascherarli completamente, dal momento che gli attributi sensibili sono spesso correlati con altri attributi dell'insieme dei dati. Eliminarli non è quindi sufficiente, e rimuovere tutti gli attributi correlati ad essi porta ad una perdita di informazioni troppo grande.
- Assicurarsi che l'insieme dei dati abbia una uguale rappresentazione delle persone se raggruppate da caratteristiche sensibili.
- Ottimizzare il modello IA sia per accuratezza che per imparzialità allo stesso tempo. Mentre l'algoritmo è addestrato su un esistente insieme di dati che contiene una non imparziale discriminazione, occorre considerare sia la sua accuratezza che la sua imparzialità15. In altre parole, occorre aggiungere l'imparzialità come obiettivo dell'algoritmo.
Se questi metodi vengono utilizzati, avere un algoritmo perfettamente accurato e imparziale è impossibile, ma se l'accuratezza è definita su un insieme di dati per il quale si sa che contiene un trattamento non imparziale di un gruppo particolare, allora può essere ritenuto accettabile avere un'accuratezza un po' meno che perfetta.
Dal momento che una IA rilasciata come Software Libero può essere utilizzata ed analizzata da chiunque, è più semplice verificare che essa sia priva di potenziali discriminazioni dannose rispetto ad una IA proprietaria. Inoltre, questo crea sinergia con la trasparenza dell'IA (vedi la sezione Transparenza), dal momento che una IA trasparente facilita la comprensione dei fattori presi in considerazione per fare le previsioni. Benché sia necessario, rilasciare l'IA come Software libero non la rende comunque imparziale, ma rende l'imparzialità più semplice da valutare e da far rispettare.
Conclusioni
In questo articolo, evidenziamo le potenziali problematiche sulla democratizzazione dell'intelligenza artificiale (IA) e le implicazioni per i diritti umani. Sono state presentate possibili soluzioni di Software Libero per affrontare queste problematiche. In particolare, abbiamo mostrato che l'IA ha bisogno di essere accessibile, trasparente e imparziale per poter essere utilizzabile. Se da una parte non è una soluzione sufficiente, rilasciare l'IA con licenze di Software Libero è necessario per l'uso diffuso che se ne fa nei nostri sistemi informativi, per poterla rendere più comprensibile, affidabile e sicura per tutti.
References
- K. He, X. Zhang, S. Ren, e J. Sun, “Deep Residual Learning for Image Recognition,” arXiv:1512.03385 [cs], Dic. 2015. ↩
- K. Simonyan e A. Zisserman, “Very Deep Convolutional Networks for Large-Scale Image Recognition,” arXiv:1409.1556 [cs], Apr. 2015. ↩
- X. Dastile, T. Celik, e M. Potsane, “Statistical and machine learning models in credit scoring: A systematic literature survey,” Applied Soft Computing, vol. 91, p. 106263, 2020, doi: 10.1016/j.asoc.2020.106263. ↩
- C. Badue et al., “Self-Driving Cars: A Survey,” arXiv:1901.04407 [cs], Oct. 2019. ↩
- D. Ensign, S. A. Friedler, S. Neville, C. Scheidegger, e S. Venkatasubramanian, “Runaway Feedback Loops in Predictive Policing,” in Conference on Fairness, Accountability and Transparency, Jan. 2018, pp. 160–171. ↩
- N. Schwalbe and B. Wahl, “Artificial intelligence and the future of global health,” The Lancet, vol. 395, no. 10236, pp. 1579–1586, Mag. 2020, doi: 10.1016/S0140-6736(20)30226-9. ↩
- A. Canziani, A. Paszke, e E. Culurciello, “An Analysis of Deep Neural Network Models for Practical Applications,” arXiv:1605.07678 [cs], Apr. 2017. ↩
- M. T. Ribeiro, S. Singh, e C. Guestrin, “"Why Should I Trust You?": Explaining the Predictions of Any Classifier,” arXiv:1602.04938 [cs, stat], Ago. 2016. ↩
- N. Kokhlikyan et al., Captum: A unified and generic model interpretability library for PyTorch. 2020. ↩
- “Practitioners Guide to COMPAS.” Northpointe, Mar. 2015. ↩
- L. K. Mattu Jeff Larson, “Machine Bias,” ProPublica. Mar. 2015. ↩
- Z. Obermeyer, B. Powers, C. Vogeli, e S. Mullainathan, “Dissecting racial bias in an algorithm used to manage the health of populations,” Science (New York, N.Y.), vol. 366, no. 6464, pp. 447–453, Ott. 2019, doi: 10.1126/science.aax2342. ↩
- C. Dwork, M. Hardt, T. Pitassi, O. Reingold, e R. Zemel, “Fairness Through Awareness,” arXiv:1104.3913 [cs], Nov. 2011. ↩
- J. Kleinberg, S. Mullainathan, and M. Raghavan, “Inherent Trade-Offs in the Fair Determination of Risk Scores,” arXiv:1609.05807 [cs, stat], Nov. 2016. ↩
- M. B. Zafar, I. Valera, M. G. Rodriguez, e K. P. Gummadi, “Fairness Beyond Disparate Treatment & Disparate Impact: Learning Classification without Disparate Mistreatment,” Proceedings of the 26th International Conference on World Wide Web, pp. 1171–1180, Apr. 2017, doi: 10.1145/3038912.3052660. ↩