Sistema di algebra computazionale

Con il termine sistema di algebra computazionale (o anche con il termine inglese computer algebra system e con il suo acronimo CAS) si intende un sistema software in grado di facilitare l'esecuzione di elaborazioni simboliche. La funzionalità di base di un CAS è la manipolazione di espressioni matematiche in forma simbolica. Lo studio degli algoritmi e delle strutture informative concretamente utilizzabili per i sistemi CAS viene detto algebra computazionale o anche computer algebra.

Tipi di espressioni[modifica | modifica wikitesto]

Le espressioni che un CAS è in grado di manipolare tipicamente comprendono polinomi e funzioni razionali in una e più variabili; funzioni elementari standard (potenza, esponenziale, logaritmo, seno, coseno, tangente, varianti iperboliche, funzioni inverse, ...); varie funzioni speciali (gamma, zeta, erf, Bessel, ...); composizioni delle funzioni precedenti; derivate, integrali, somme, prodotti delle espressioni trattabili; serie troncate con coefficienti dati da espressioni, matrici di espressioni e così via. In modo più preciso l'insieme delle espressioni manipolabili da un CAS viene individuato da una definizione ricorsiva alla quale corrispondono i meccanismi interni per il riconoscimento delle espressioni e la determinazione degli schemi per le loro manipolazioni e valutazioni.

Manipolazioni simboliche eseguibili[modifica | modifica wikitesto]

Le manipolazioni simboliche supportate in genere comprendono

La parola "alcuni" in molte espressioni precedenti pone in rilievo che un sistema CAS è in grado di effettuare una data operazione solo su determinati insiemi di espressioni, ovvero solo su determinati insiemi di funzioni. Va rilevato che tutti i sistemi CAS che riescono a rimanere sul mercato vanno progressivamente ampliando questi insiemi.

Altre funzioni[modifica | modifica wikitesto]

Molti sistemi CAS consentono di effettuare operazioni numeriche:

Molti sistemi CAS dispongono anche di un proprio specifico linguaggio di programmazione di alto livello il quale consente agli utenti di implementare propri algoritmi e proprie funzioni. Talora questi linguaggi possono essere sviluppati in ambienti di sviluppo dotati di buoni strumenti per i programmatori.

Infine alcuni sistemi dispongono di strumenti per la gestione di files e archivi di dati da utilizzare nelle elaborazioni o prodotti dalle stesse.

I tempi di esecuzione dei programmi che richiedono prevalentemente operazioni numeriche implementati nei sistemi CAS sono normalmente superiori a quelli di programmi equivalenti che possono essere implementati in sistemi computazionali come MATLAB e GNU Octave oppure mediante linguaggi di livello medio-basso come Fortran e C, in quanto i CAS sono programmati per riuscire a governare elaborazioni simboliche di elevata generalità e tendenzialmente non sono in grado di far intervenire nel modo più diretto le operazioni numeriche di macchina per gran parte delle loro funzionalità.

Storia[modifica | modifica wikitesto]

I primi sistemi di algebra computazionale sono diventati disponibili nei primi anni 1970, anche come derivati dalla ricerca in intelligenza artificiale; i due settori dell'algebra computazionale e della intelligenza artificiale si sono però presto separati piuttosto nettamente. I primi sistemi a raggiungere la popolarità sono stati Reduce, Derive e Macsyma, tutti sistemi ancora commercialmente disponibili; una versione copyleft di Macsyma chiamata Maxima viene attivamente manutenuta. Gli attuali leader di mercato sono Mathematica e Maple; entrambi sono ampiamente utilizzati per ricerca e sviluppo da matematici, scienziati e ingegneri. Un altro diffuso sistema commerciale è MuPAD; esso è disponibile in una versione gratuita con una interfaccia con leggere limitazioni per usi di ricerca senza scopo di lucro e per attività didattiche. Sono inoltre disponibili molti altri sistemi di algebra computazionale, per esempio CoCoA, che concentrano le proprie prestazioni su aree computazionali specifiche; per taluni ristretti campi di applicazione spesso questi sistemi specializzati sono molto più efficienti di quelli di portata più generale, in quanto implementano algoritmi validi per situazioni molto particolari; questi sono tipicamente sviluppati in ambienti accademici e sono gratuiti.

Nozioni matematiche usate nei sistemi di algebra computazionale[modifica | modifica wikitesto]

Bibliografia[modifica | modifica wikitesto]

  • Richard J. Fateman (1972): "Essays in algebraic simplification". Technical report MIT-LCS-TR-095. (Rapporto tecnico di interesse storico per le prime direzioni della ricerca nell'algebra computazionale. accessibile nel sito di MIT LCS [1])

Voci correlate[modifica | modifica wikitesto]

  Portale Matematica: accedi alle voci di Wikipedia che trattano di matematica