𝖂𝖎ƙ𝖎𝖊

Ciência da computação: mudanças entre as edições

Sem resumo de edição
imported>Gremista.32
m (Foram revertidas as edições de Kendo89 para a última revisão de Gremista.32, de 22h23min de 28 de novembro de 2021 (UTC))
 
(39 revisões intermediárias por 27 usuários não estão sendo mostradas)
Linha 1: Linha 1:
{{Ver desambig|a ramificação da Ciência da Computação|Teoria da computação|prefixo=Se procura|o termo geral|Computação|}}
{{Ver desambig|a ramificação da Ciência da Computação|Teoria da computação|prefixo=Se procura|o termo geral|Computação|}}
{{Mais notas|data=novembro de 2010}}
<div class="thumb tright">
<div class="thumb tright">
<div class="thumbinner" style="width:200px;">
<div class="thumbinner" style="width:200px;">
Linha 13: Linha 12:
<div class="thumbcaption">A Ciência da Computação lida com fundamentos teóricos da informação, computação, e técnicas práticas para suas implementações e aplicações.</div>
<div class="thumbcaption">A Ciência da Computação lida com fundamentos teóricos da informação, computação, e técnicas práticas para suas implementações e aplicações.</div>
</div>
</div>
</div>'''Ciência da computação''' é a ciência que estuda as técnicas, metodologias e instrumentos computacionais, que automatiza processos e desenvolve soluções baseadas no uso do processamento de dados. Não se restringe apenas ao estudo dos [[algoritmo]]s, suas aplicações e implementação na forma de ''[[software]]'', extrapolando para todo e qualquer conhecimento pautado no computador, que envolve também a telecomunicação, o banco de dados e as aplicações tecnológicas que possibilitam atingir o tratamento de dados de entrada e saída, de forma que se transforme em informação. Assim, a Ciência da Computação também abrange as técnicas de modelagem de dados e os protocolos de comunicação, além de princípios que abrangem outras especializações da área.
</div>'''Ciência da computação''' é a ciência que estuda as técnicas, metodologias, instrumentos computacionais e aplicações tecnológicas, que informatizem os processos e desenvolvam soluções de processamento de dados de entrada e saída pautados no computador. Não se restringindo apenas ao estudo dos [[algoritmo]]s, suas aplicações e implementação na forma de ''[[software]]''. Assim, a Ciência da Computação também abrange as técnicas de modelagem de dados e gerenciamento de [[banco de dados]], envolvendo também a [[telecomunicação]] e os protocolos de comunicação, além de princípios que abrangem outras especializações da área.<ref>BROOKSHEAR, J. Gleen. Ciência da Computação: uma visão abrangente - 11º ed. Porto Alegre: Bookman, 2013.</ref>


Enquanto ciência, classifica-se como ciência exata, apesar de herdar elementos da lógica filosófica aristotélica, tendo por isto um papel importante na formalização matemática de algoritmos, como forma de representar problemas decidíveis, i.e., os que são susceptíveis de redução a operações elementares básicas, capazes de serem reproduzidas através de um qualquer dispositivo qualquer capaz de armazenar e manipular dados. Um destes dispositivos é o [[computador digital]], de uso generalizado, nos dias de hoje. Também de fundamental importância para a área de Ciência da Computação são as metodologias e técnicas ligadas à implementação de software que abordam a especificação, modelagem, codificação, teste e avaliação de sistemas de software.
Enquanto ciência, classifica-se como ciência exata, apesar de herdar elementos da lógica filosófica aristotélica, tendo por isto um papel importante na formalização matemática de algoritmos, como forma de representar problemas decidíveis, i.e., os que são susceptíveis de redução a operações elementares básicas, capazes de serem reproduzidas através de um dispositivo qualquer capaz de armazenar e manipular dados. Um destes dispositivos é o [[computador digital]], de uso generalizado, nos dias de hoje. Também de fundamental importância para a área de Ciência da Computação são as metodologias e técnicas ligadas à implementação de software que abordam a especificação, modelagem, codificação, teste e avaliação de sistemas de software.


Os estudos oriundos da Ciência da Computação podem ser aplicados em qualquer área do [[conhecimento humano]] em que seja possível definir métodos de resolução de problemas baseados em repetições previamente observadas. Avanços recentes na Ciência da Computação tem impactado fortemente a sociedade contemporânea, em particular as aplicações relacionadas às áreas de redes de computadores, Internet, Web e computação móvel que têm sido utilizadas por bilhões de pessoas ao redor do globo.
Os estudos oriundos da Ciência da Computação podem ser aplicados em qualquer área do [[conhecimento humano]] em que seja possível definir métodos de resolução de problemas baseados em repetições previamente observadas. Avanços recentes na Ciência da Computação têm impactado fortemente a sociedade contemporânea, em particular as aplicações relacionadas às áreas de redes de computadores, Internet, Web, ciência de dados e computação móvel, que têm sido utilizadas por bilhões de pessoas ao redor do globo.<ref>FEDELI, R.; POLLONI, E.; PERES, F. Introdução à Ciência da Computação. 2 ed. São Paulo: Cengage Learning, 2009.</ref>


== História da Computação ==
== História da Computação ==
{{Artigo principal|História da computação}}
{{Artigo principal|História da computação}}
[[Imagem:Kugleramme.jpg|thumb|direita|150px|O [[ábaco]], primeira ferramenta de computação, em sua forma moderna.]]
[[Imagem:Kugleramme.jpg|thumb|direita|215x215px|O [[ábaco]], primeira ferramenta de computação, em sua forma moderna.]]
A primeira ferramenta conhecida para a computação foi o [[ábaco]]<ref name=ifrah>{{Citar livro|url= |autor=IFRAH, Georges|título=The Universal History of Computing|subtítulo= |idioma=inglês |edição= |local=Nova York |editora=John Wiley & Sons|ano=2001|páginas=|volumes= |volume= |id=ISBN 0-471-39671-0}}</ref>, cuja invenção é atribuída a habitantes da [[Mesopotâmia]], em torno de [[2700 a.C.|2700]]–[[2300 a.C.]]. Seu uso original era desenhar linhas na [[areia]] com rochas. Versões mais modernas do ábaco ainda são usadas como instrumento de cálculo.
A primeira ferramenta conhecida para a computação foi o [[ábaco]],<ref name=ifrah>{{Citar livro|url= |autor=IFRAH, Georges|título=The Universal History of Computing|subtítulo= |idioma=inglês |edição= |local=Nova York |editora=John Wiley & Sons|ano=2001|páginas=|volumes= |volume= |id=ISBN 0-471-39671-0}}</ref> cuja invenção é atribuída a habitantes da [[Mesopotâmia]], em torno de [[2700 a.C.|2700]]–[[2300 a.C.]]. Seu uso original era desenhar linhas na [[areia]] com rochas. Versões mais modernas do ábaco ainda são usadas como instrumento de cálculo.


No século VII a.C., na [[história da Índia|antiga Índia]], o gramático [[Pānini]] formulou a gramática de [[Sânscrito]] usando 3959 regras conhecidas como [[Ashtadhyāyi]], de forma bastante sistemática e técnica. Pānini usou transformações e recursividade com tamanha sofisticação que sua gramática possuía o poder computacional teórico tal qual a [[Máquina de Turing]].
No século VII a.C., na [[história da Índia|antiga Índia]], o gramático [[Pānini]] formulou a gramática de [[Sânscrito]] usando 3959 regras conhecidas como [[Ashtadhyāyi]], de forma bastante sistemática e técnica. Pānini usou transformações e recursividade com tamanha sofisticação que sua gramática possuía o poder computacional teórico tal qual a [[Máquina de Turing]].


Entre [[200 a.C.]] e [[400]], os indianos também inventaram o [[logaritmo]], e partir do [[século XIII]] tabelas logarítmicas eram produzidas por matemáticos [[Islão|islâmicos]]. Quando [[John Napier]] descobriu os logaritmos para uso computacional no [[século XVI]]<ref name=ifrah />, seguiu-se um período de considerável progresso na construção de ferramentas de cálculo.
Entre [[200 a.C.]] e [[400]], os indianos também inventaram o [[logaritmo]], e a partir do [[século XIII]] tabelas logarítmicas eram produzidas por matemáticos [[Islão|islâmicos]]. Quando [[John Napier]] descobriu os logaritmos para uso computacional no [[século XVI]],<ref name=ifrah /> seguiu-se um período de considerável progresso na construção de ferramentas de cálculo.


[[Imagem:Al-Khwarizmi.jpg|thumb|[[Al-Khwarizmi]].]]
[[Imagem:Al-Khwarizmi.jpg|thumb|[[Al-Khwarizmi]].|414x414px]]


=== Algoritmos ===
=== Algoritmos ===
No século VII, o matemático indiano Brahmagupta explicou pela primeira vez o sistema de numeração hindu-arábico e o uso do [[0 (número)|0]]. Aproximadamente em 825, o matemático persa [[al-Khwarizmi]] escreveu o livro ''Calculando com numerais hindus'', responsável pela difusão do sistema de numeração hindu-arábico no Oriente Médio, e posteriormente na Europa. Por volta do século XII houve uma tradução do mesmo livro para o latim: ''Algoritmi de numero Indorum''. Tais livros apresentaram novos conceitos para definir sequências de passos para completar tarefas, como aplicações de aritmética e álgebra. Por derivação do nome do matemático,actualmente usa-se o termo algoritmo.
No século VII, o matemático indiano Brahmagupta explicou pela primeira vez o sistema de numeração hindu-arábico e o uso do [[0 (número)|0]]. Aproximadamente em 825, o matemático persa [[al-Khwarizmi]] escreveu o livro ''Calculando com numerais hindus'', responsável pela difusão do sistema de numeração hindu-arábico no Oriente Médio, e posteriormente na Europa. Por volta do século XII houve uma tradução do mesmo livro para o latim: ''Algoritmi de numero Indorum''. Tais livros apresentaram novos conceitos para definir sequências de passos para completar tarefas, como aplicações de aritmética e álgebra. Por derivação do nome do matemático, atualmente usa-se o termo algoritmo.


=== Lógica binária ===
=== Lógica binária ===
Por volta do século III a.C., o matemático indiano [[Pingala]] inventou o [[Sistema binário (matemática)|sistema de numeração binário]]. Ainda usado atualmente no processamento de todos computadores modernos, o sistema estabelece que sequências específicas de uns e zeros podem representar qualquer informação.
Por volta do século III a.C., o matemático indiano [[Pingala]] inventou o [[Sistema binário (matemática)|sistema de numeração binário]]. Ainda usado atualmente no processamento de todos os computadores modernos, o sistema estabelece que sequências específicas de uns e zeros podem representar qualquer informação.


Em [[1703]] [[Gottfried Leibniz]] desenvolveu a [[lógica matemática|lógica]] em um sentido formal e matemático, utilizando o sistema binário. Em seu sistema, uns e zeros também representam conceitos como verdadeiro e falso, ligado e desligado, válido e inválido. Mais de um século depois, [[George Boole]] publicou a [[álgebra booleana]] (em [[1854]]), com um sistema completo que permitia a construção de modelos matemáticos para o processamento computacional. Em [[1801]], apareceu o [[tear]] controlado por [[cartão perfurado]], invenção de [[Joseph Marie Jacquard]], no qual buracos indicavam os uns e, áreas não furadas, indicavam os zeros. O sistema está longe de ser um computador, mas ilustrou que as máquinas poderiam ser controladas pelo sistema binário.
Em [[1703]] [[Gottfried Leibniz]] desenvolveu a [[lógica matemática|lógica]] em um sentido formal e matemático, utilizando o sistema binário. Em seu sistema, uns e zeros também representam conceitos como verdadeiro e falso, ligado e desligado, válido e inválido. Mais de um século depois, [[George Boole]] publicou a [[álgebra booleana]] (em [[1854]]), com um sistema completo que permitia a construção de modelos matemáticos para o processamento computacional. Em [[1801]], apareceu o [[tear]] controlado por [[cartão perfurado]], invenção de [[Joseph Marie Jacquard]], no qual buracos indicavam os uns e áreas não furadas indicavam os zeros. O sistema está longe de ser um computador, mas ilustrou que as máquinas poderiam ser controladas pelo sistema binário.


=== Engenho analítico ===
=== Engenho analítico ===
[[Imagem:Ada Lovelace.jpg|thumb|direita|150px|[[Ada Lovelace]], primeira [[programador]]a.]]
[[Imagem:Ada Lovelace.jpg|thumb|direita|318x318px|[[Ada Lovelace]], primeira [[programador]]a.]]
Foi com [[Charles Babbage]] que o computador moderno começou a ganhar forma, através de seu trabalho no [[engenho analítico]]. O equipamento descrito originalmente em [[1837]], mais de um século antes de seu sucessor, nunca foi construído com sucesso, mas possuía todas as funções de um computador moderno. O dispositivo de Babbage se diferenciava por ser programável, algo imprescindível para qualquer computador moderno.
Foi com [[Charles Babbage]] que o computador moderno começou a ganhar forma, através de seu trabalho no [[engenho analítico]]. O equipamento descrito originalmente em [[1837]], mais de um século antes de seu sucessor, nunca foi construído com sucesso, mas possuía todas as funções de um computador moderno. O dispositivo de Babbage se diferenciava por ser programável, algo imprescindível para qualquer computador moderno.


Durante sua colaboração, a matemática [[Ada Lovelace]] publicou os primeiros [[programa de computador|programas de computador]] em uma série de notas para o engenho analítico<ref>{{citar jornal | ultimo = Huskey | primeiro = Velma R. | coautores = Huskey, Harry D. | ano = 1980 | mes = Outubro | titulo = Lady Lovelace and Charles Babbage | jornal = Annals of The History of Computing | volume = 2 | número = 4 | paginas = 384 | editora = American Federation of Information Processing Societies | local = Arlington, VA | issn = 1058-6180  | idioma = inglês }}</ref>. Por isso, Lovelace é popularmente considerada como a primeira [[programador]]a.
Durante sua colaboração, a matemática [[Ada Lovelace]] publicou os primeiros [[programa de computador|programas de computador]] em uma série de notas para o engenho analítico.<ref>{{citar jornal | ultimo = Huskey | primeiro = Velma R. | coautores = Huskey, Harry D. | ano = 1980 | mes = Outubro | titulo = Lady Lovelace and Charles Babbage | jornal = Annals of The History of Computing | volume = 2 | número = 4 | paginas = 384 | editora = American Federation of Information Processing Societies | local = Arlington, VA | issn = 1058-6180  | idioma = inglês }}</ref> Por isso, Lovelace é popularmente considerada como a primeira [[programador]]a.


=== Nascimento da Ciência da Computação ===
=== Nascimento da Ciência da Computação ===
Linha 55: Linha 54:


[[Imagem:Turing Machine.png|thumb|esquerda|150px|Representação visual da [[Máquina de Turing]]]]
[[Imagem:Turing Machine.png|thumb|esquerda|150px|Representação visual da [[Máquina de Turing]]]]
Turing também incluiu na tese uma descrição da [[Máquina de Turing]], que possui uma fita de tamanho infinito e um cabeçote para leitura e escrita que move-se pela fita. Devido ao seu caráter infinito, tal máquina não pode ser construída, mas tal modelo pode simular a computação de qualquer algoritmo executado em um computador moderno. Turing é bastante importante para a Ciência da Computação, tanto que seu nome é usado para o [[Prêmio Turing]] e o [[teste de Turing]]. Ele contribuiu para a quebra do código da Alemanha pela [[Grã-Bretanha]]<ref name=good>{{Citar livro|url= |autor=METROPOLIS, N. (ed.);HOWLETT, J.(ed.);ROTA, Gian-Carlo(ed.);GOOD, I. J.(Contribuidor)|título=A History of Computing in the Twentieth Century|subtítulo= |capítulo=Pioneering Work on Computer at Bletchley |idioma=inglês |edição= |local=Nova York |editora=Academic Press|ano=1980|páginas=31-45|volumes= |volume= |id=ISBN 0-12-491650-3}}</ref> na [[Segunda Guerra Mundial]], e continuou a projetar computadores e programas de computador pela [[década de 1940]]; cometeu suicídio em [[1954]].<ref>{{Citar livro|autor=COPELAND, B. Jack (Editor)|título=The Essential Turing|subtítulo=The Ideas that Gave Birth to the Computer Age|idioma=|edição=|local=Oxford|editora=Clarendon Press, Oxford|ano=2004|páginas=613|volumes=|volume=|ID={{ISBN|0-19-825079-7}}}}</ref><ref>{{Citar livro|autor=STRATHERN, Paul|título=The Big Idea: Turing & the Computer|subtítulo=|idioma=|edição=|local=London|editora=Arrow|ano=1997|páginas=95|volumes=|volume=|ID={{ISBN|0-09-923782-2}}}}</ref>.
Turing também incluiu na tese uma descrição da [[Máquina de Turing]], que possui uma fita de tamanho infinito e um cabeçote para leitura e escrita que move-se pela fita. Devido ao seu caráter infinito, tal máquina não pode ser construída, mas tal modelo pode simular a computação de qualquer algoritmo executado em um computador moderno. Turing é bastante importante para a Ciência da Computação, tanto que seu nome é usado para o [[Prêmio Turing]] e o [[teste de Turing]]. Ele contribuiu para a quebra do código da Alemanha pela [[Grã-Bretanha]]<ref name=good>{{Citar livro|url= |autor=METROPOLIS, N. (ed.);HOWLETT, J.(ed.);ROTA, Gian-Carlo(ed.);GOOD, I. J.(Contribuidor)|título=A History of Computing in the Twentieth Century|subtítulo= |capítulo=Pioneering Work on Computer at Bletchley |idioma=inglês |edição= |local=Nova York |editora=Academic Press|ano=1980|páginas=31-45|volumes= |volume= |id=ISBN 0-12-491650-3}}</ref> na [[Segunda Guerra Mundial]], e continuou a projetar computadores e programas de computador pela [[década de 1940]]; cometeu suicídio em [[1954]].<ref>{{Citar livro|autor=COPELAND, B. Jack (Editor)|título=The Essential Turing|subtítulo=The Ideas that Gave Birth to the Computer Age|idioma=|edição=|local=Oxford|editora=Clarendon Press, Oxford|ano=2004|páginas=613|volumes=|volume=|ID={{ISBN|0-19-825079-7}}}}</ref><ref>{{Citar livro|autor=STRATHERN, Paul|título=The Big Idea: Turing & the Computer|subtítulo=|idioma=|edição=|local=London|editora=Arrow|ano=1997|páginas=95|volumes=|volume=|ID={{ISBN|0-09-923782-2}}}}</ref>


=== Shannon e a teoria da informação ===
=== Shannon e a teoria da informação ===
Até a [[década de 1930]], engenheiros eletricistas podiam construir circuitos eletrônicos para resolver problemas lógicos e matemáticos, mas a maioria o fazia sem qualquer processo, de forma particular, sem rigor teórico para tal. Isso mudou com a tese de mestrado de [[Claude Shannon]] de 1937, ''A Symbolic Analysis of Relay and Switching Circuits''. Enquanto tomava aulas de Filosofia, Shannon foi exposto ao trabalho de George Boole, e percebeu que poderia aplicar esse aprendizado em conjuntos eletro-mecânicos para resolver problemas. Shannon desenvolveu a [[teoria da informação]] no artigo de [[1948]]: ''A Mathematical Theory of Communication''<ref name=shannon>{{Citar livro|url= |autor=SHANNON, Claude E.; WEAVER, Warren |título=The Mathematical Theory of Communication|subtítulo= |idioma=inglês |edição= |local=Illinois |editora=The University of Illinois Press (Illini books)|ano=1949 |páginas=3-91 |volumes= |volume= |id=Library of Congress Catalog Card Nº 49-11922}}</ref>, cujo conteúdo serve como fundamento para áreas como [[compressão de dados]] e [[criptografia]].<ref name=breton>{{Citar livro|url= |autor=BRETON, Philippe|titulo=História da Informática|subtítulo= |idioma= |edição= |local=São Paulo |editora=UNESP|ano=1991 |páginas=52-55 |volumes= |volume= |id=ISBN 85-7139-021-5}}</ref>
Até a [[década de 1930]], engenheiros eletricistas podiam construir circuitos eletrônicos para resolver problemas lógicos e matemáticos, mas a maioria o fazia sem qualquer processo, de forma particular, sem rigor teórico para tal. Isso mudou com a tese de mestrado de [[Claude Shannon]] de 1937, ''A Symbolic Analysis of Relay and Switching Circuits''. Enquanto tomava aulas de Filosofia, Shannon foi exposto ao trabalho de George Boole, e percebeu que poderia aplicar esse aprendizado em conjuntos eletro-mecânicos para resolver problemas. Shannon desenvolveu a [[teoria da informação]] no artigo de [[1948]]: ''A Mathematical Theory of Communication,''<ref name=shannon>{{Citar livro|url= |autor=SHANNON, Claude E.; WEAVER, Warren |título=The Mathematical Theory of Communication|subtítulo= |idioma=inglês |edição= |local=Illinois |editora=The University of Illinois Press (Illini books)|ano=1949 |páginas=3-91 |volumes= |volume= |id=Library of Congress Catalog Card Nº 49-11922}}</ref> cujo conteúdo serve como fundamento para áreas como [[compressão de dados]] e [[criptografia]].<ref name=breton>{{Citar livro|url= |autor=BRETON, Philippe|titulo=História da Informática|subtítulo= |idioma= |edição= |local=São Paulo |editora=UNESP|ano=1991 |páginas=52-55 |volumes= |volume= |id=ISBN 85-7139-021-5}}</ref>


== Realizações para a sociedade ==
== Contribuição social ==
Apesar de sua pequena história enquanto uma disciplina acadêmica, a Ciência da Computação deu origem a diversas contribuições fundamentais para a [[ciência]] e para a [[sociedade]]. Esta ciência foi responsável pela definição formal de [[computação]] e [[computabilidade]], e pela prova da existência de [[Problema da parada|problemas insolúveis]] ou intratáveis computacionalmente.
Apesar de sua pequena história enquanto uma disciplina acadêmica, a Ciência da Computação deu origem a diversas contribuições fundamentais para a [[ciência]] e para a [[sociedade]]. Esta ciência foi responsável pela definição formal de [[computação]] e [[computabilidade]], e pela prova da existência de [[Problema da parada|problemas insolúveis]] ou intratáveis computacionalmente.


Linha 81: Linha 80:
}}</ref>
}}</ref>


Para outros campos científicos e para a sociedade de forma geral, a Ciência da Computação forneceu suporte para a [[Revolução Digital]], dando origem a [[Era da Informação]].<ref name="realizações e desafios" /> A computação científica é uma área da computação que permite o avanço de estudos como o mapeamento do genoma humano (ver [[Projeto Genoma Humano]]).
Para outros campos científicos e para a sociedade de forma geral, a Ciência da Computação forneceu suporte para a [[Revolução Digital]], dando origem a [[Era da Informação]].<ref name="realizações e desafios" /> A computação científica é uma área da computação que permite o avanço de estudos como o mapeamento do genoma humano (ver [[Projeto Genoma Humano]]).{{quote|Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio, a biologia com o microscópio, ou a química com os tubos de ensaio. A ciência não estuda ferramentas, mas o que fazemos e o que descobrimos com elas.|Citação atribuída a [[Edsger Dijkstra]]}}
 
== Pessoas notáveis ==
== Pessoas notáveis ==
Algumas das pessoas mais importantes da computação foram agraciadas com o [[Prêmio Turing]].
Algumas das pessoas mais importantes da computação foram agraciadas com o [[Prêmio Turing]].
Linha 91: Linha 89:
* [[Ada Lovelace]], considerada a primeira pessoa programadora, deu nome a [[Ada (linguagem de programação)|uma linguagem de programação]];
* [[Ada Lovelace]], considerada a primeira pessoa programadora, deu nome a [[Ada (linguagem de programação)|uma linguagem de programação]];


=== Pioneiros ===
* [[Alan Turing]], participou do projeto [[Colossus (computador)|Colossus]] e foi um dos cérebros que decifra a [[Enigma (máquina)|Enigma]]. Também inventou um tipo teórico de máquina super-simples capaz de realizar qualquer cálculo de um computador digital, a [[Máquina de Turing]];
{{quote2|Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio, a biologia com o microscópio, ou a química com os tubos de ensaio. A ciência não estuda ferramentas, mas o que fazemos e o que descobrimos com elas.|citação atribuída a [[Edsger Dijkstra]]}}
* [[John von Neumann]], descreveu o computador que utiliza um programa armazenado em [[memória de computador|memória]], a [[Arquitetura de von Neumann]], que é a base da arquitetura dos computadores atuais;
* [[Alan Turing]], participou do projeto [[Colossus (computador)|Colossus]] e foi um dos cérebros que decifra a [[Enigma (máquina)|Enigma]]. Também inventou um tipo teórico de máquina super-simples capaz de realizar qualquer cálculo de um computador digital, a [[Máquina de Turing]]
* [[John Backus]], líder da equipe que criou o [[Fortran]] e criou a notação [[Formalismo de Backus-Naur|BNF]];
* [[John von Neumann]], descreveu o computador que utiliza um programa armazenado em [[memória de computador|memória]], a [[Arquitetura de von Neumann]], que é a base da arquitetura dos computadores atuais
* [[Maurice V. Wilkes|Maurice Vicent Wilkes]], inventor do somador binário;
* [[John Backus]], líder da equipe que criou o [[Fortran]] e criou a notação [[Formalismo de Backus-Naur|BNF]]
* [[Howard Aiken]], inventor do [[Harvard Mark I|Mark I]];
* [[Maurice V. Wilkes|Maurice Vicent. Wilkes]], inventor do somador binário
* [[Walter H. Brattain]], inventor do [[transístor]];
* [[Howard Aiken]], inventor do [[Harvard Mark I|Mark I]]
* [[William Shockley]], inventor do [[transístor]];
* [[Walter H. Brattain]], inventor do [[transístor]]
* [[John Bardeen]], inventor do [[transístor]];
* [[William Shockley]], inventor do [[transístor]]
* [[Fred Williams]], inventor da [[memória RAM]];
* [[John Bardeen]], inventor do [[transístor]]
* [[Tom Kilburn]], inventor da [[memória RAM]];
* [[Fred Williams]], inventor da [[memória RAM]]
* [[Konrad Zuse]], inventor independente do computador digital e de linguagens de programação na [[Alemanha nazista]];
* [[Tom Kilburn]], inventor da [[memória RAM]]
* [[John Atanasoff]], inventor do primeiro computador digital, o [[Atanasoff–Berry Computer]], ABC;
* [[Konrad Zuse]], inventor independente do computador digital e de linguagens de programação na [[Alemanha nazista]]
* [[Clifford Berry]], assistente de Atanasoff;
* [[John Atanasoff]], inventor do primeiro computador digital, o [[Atanasoff–Berry Computer]], ABC
* Almirante [[Grace Hopper]], programadora do Mark I, desenvolveu o primeiro [[compilador]]; primeira mulher a receber um [[Ph.D.]] em matemática;
* [[Clifford Berry]], assistente de Atanasoff
* [[Edsger Dijkstra]], líder do [[ALGOL 60]], publicou o artigo original sobre [[programação estruturada]];
* Almirante [[Grace Hopper]], programadora do Mark I, desenvolveu o primeiro [[compilador]]; primeira mulher a receber um [[Ph.D.]] em matemática
* [[J. Presper Eckert]], criador do [[ENIAC]];
* [[Edsger Dijkstra]], líder do [[ALGOL 60]], publicou o artigo original sobre [[programação estruturada]]
* [[John William Mauchly]], criador do [[ENIAC]].
* [[J. Presper Eckert]], criador do [[ENIAC]]
* [[John William Mauchly]], criador do [[ENIAC]]


=== Personalidades influentes ===
=== Personalidades influentes ===
* [[Andrew Stuart Tanenbaum]], pesquisador na área de [[sistemas operacionais]], inventor do [[MINIX]]; seus livros-texto são dos mais referenciados na área
* [[Andrew Stuart Tanenbaum]], pesquisador na área de [[sistemas operacionais]], inventor do [[MINIX]]; seus livros-texto são dos mais referenciados na área;
* [[Edgar Frank Codd]], inventor de [[Banco de dados relacional|Banco de dados relacionais]]
* [[Edgar Frank Codd]], inventor de [[Banco de dados relacional|Banco de dados relacionais]];
* [[Brian Kernighan]], inventor da [[linguagem de programação]] [[C (linguagem de programação)|C]]
* [[Brian Kernighan]], inventor da [[linguagem de programação]] [[C (linguagem de programação)|C]];
* [[Dennis Ritchie]], inventor da [[linguagem de programação]] [[C (linguagem de programação)|C]] e do [[Unix]]
* [[Dennis Ritchie]], inventor da [[linguagem de programação]] [[C (linguagem de programação)|C]] e do [[Unix]];
* [[Bjarne Stroustrup]], inventor da [[linguagem de programação]] [[C++]]
* [[Bjarne Stroustrup]], inventor da [[linguagem de programação]] [[C++]];
* [[Ken Thompson]], inventor do [[Unix]] e da [[codificação de caracteres]] [[UTF-8]]
* [[Ken Thompson]], inventor do [[Unix]] e da [[codificação de caracteres]] [[UTF-8]];
* [[Peter Chen]], inventor do [[Modelo de entidades e relacionamentos]]
* [[Peter Chen]], inventor do [[Modelo de entidades e relacionamentos]];
* [[Donald Knuth|Donald Ervin Knuth]], criador do [[TeX]], da [[programação literária]] e da influente série (inacabada em 2011) sobre algoritmos ''[[The Art of Computer Programming]]''
* [[Donald Knuth|Donald Ervin Knuth]], criador do [[TeX]], da [[programação literária]] e da influente série (inacabada em 2011) sobre algoritmos ''[[The Art of Computer Programming]];''
* [[Richard Stallman]], fundador do projeto [[GNU]] e idealizador da licença de [[software livre]] [[GNU General Public License|GPL]]
* [[Richard Stallman]], fundador do projeto [[GNU]] e idealizador da licença de [[software livre]] [[GNU General Public License|GPL]];
* [[Linus Torvalds]], criador do núcleo [[Linux (núcleo)|Linux]]
* [[Linus Torvalds]], criador do núcleo [[Linux (núcleo)|Linux]];
* [[Alan Kay]], um dos inventores da [[orientação a objeto]], também concebeu o [[laptop]] e a [[interface gráfica do utilizador]]
* [[Alan Kay]], um dos inventores da [[orientação a objeto]], também concebeu o [[laptop]] e a [[interface gráfica do utilizador]];
* [[Steve Wozniak]] e [[Steve Jobs]], criadores da [[Apple Inc.]], e do primeiro computador pessoal, o [[Apple I]]
* [[Steve Wozniak]] e [[Steve Jobs]], criadores da [[Apple Inc.]], e do primeiro computador pessoal, o [[Apple I]];
* [[Bill Gates]] e [[Paul Allen]], criadores da [[Microsoft]], a empresa que criou o [[Windows]]
* [[Bill Gates]] e [[Paul Allen]], criadores da [[Microsoft]], a empresa que criou o [[Windows]];
*James Gosling, criador da linguagem Java
* [[James Gosling]], criador da linguagem [[Java (linguagem de programação)|Java]];
* [[Guido van Rossum]], criador da linguagem [[Python]];
* [[Tim Berners-Lee]], criador da [[World Wide Web]] e do [[HTML]];
* [[Brendan Eich]], criador do [[JavaScript]].


== Áreas de pesquisa ==
== Áreas de pesquisa ==
Linha 213: Linha 212:
Por ser uma disciplina recente, existem várias definições alternativas para a Ciência da Computação. Ela pode ser vista como uma forma de ciência, uma forma de matemática ou uma nova disciplina que não pode ser categorizada seguindo os modelos atuais. Várias pessoas que estudam a Ciência da Computação o fazem para tornarem-se programadores, levando alguns a acreditarem que seu estudo é sobre o software e a programação. Apesar disso, a maioria dos cientistas da computação são interessados na inovação ou em aspectos teóricos que vão muito além de somente a programação, mais relacionados com a [[computabilidade]].
Por ser uma disciplina recente, existem várias definições alternativas para a Ciência da Computação. Ela pode ser vista como uma forma de ciência, uma forma de matemática ou uma nova disciplina que não pode ser categorizada seguindo os modelos atuais. Várias pessoas que estudam a Ciência da Computação o fazem para tornarem-se programadores, levando alguns a acreditarem que seu estudo é sobre o software e a programação. Apesar disso, a maioria dos cientistas da computação são interessados na inovação ou em aspectos teóricos que vão muito além de somente a programação, mais relacionados com a [[computabilidade]].


Apesar do nome, muito da Ciência da Computação não envolve o estudo dos computadores por si próprios. De fato, o conhecido cientista da computação [[Edsger Dijkstra]] é considerado autor da frase ''"Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio […]"''. O projeto e desenvolvimento de computadores e sistemas computacionais são geralmente considerados disciplinas fora do contexto da Ciência da Computação. Por exemplo, o estudo do [[hardware]] é geralmente considerado parte da [[engenharia da computação]], enquanto o estudo de sistemas computacionais comerciais são geralmente parte da [[tecnologia da informação]] ou [[sistemas de informação]].
Apesar do nome, muito da Ciência da Computação não envolve o estudo dos computadores por si próprios. De fato, o conhecido cientista da computação [[Edsger Dijkstra]] é considerado autor da frase ''"Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio […]"''. O projeto e desenvolvimento de computadores e sistemas computacionais são geralmente considerados disciplinas fora do contexto da Ciência da Computação. Por exemplo, o estudo do [[hardware]] é geralmente considerado parte da [[engenharia de computação]], enquanto o estudo de sistemas computacionais comerciais são geralmente parte da [[tecnologia da informação]] ou [[sistemas de informação]].


Por vezes a Ciência da Computação também é criticada por não ser suficientemente científica, como exposto na frase ''"Ciência é para a Ciência da Computação assim como a hidrodinâmica é para a construção de encanamentos"'', credita a [[Stan Kelly-Bootle]].<ref>''Computer Language'', outubro de [[1990]]</ref> Apesar disso, seu estudo frequentemente cruza outros campos de pesquisa, tais como a [[inteligência artifical]], [[física]] e [[linguística]].
Por vezes a Ciência da Computação também é criticada por não ser suficientemente científica, como exposto na frase ''"Ciência é para a Ciência da Computação assim como a hidrodinâmica é para a construção de encanamentos"'', credita a [[Stan Kelly-Bootle]].<ref>''Computer Language'', outubro de [[1990]]</ref> Apesar disso, seu estudo frequentemente cruza outros campos de pesquisa, tais como a [[inteligência artifical]], [[física]] e [[linguística]].
Linha 245: Linha 244:
* [[Análise de sistemas e tecnologia da informação]]
* [[Análise de sistemas e tecnologia da informação]]
* [[Lista de termos de computação]]
* [[Lista de termos de computação]]
* [[Engenharia da computação]]
* [[Engenharia de computação]]
* [[Engenharia Informática]]
* [[Engenharia Informática]]
* [[Sistema de informação]]
* [[Sistema de informação]]
Linha 252: Linha 251:
* [[Computação afetiva]]
* [[Computação afetiva]]


{{portal|Portal=[[Portal:Tecnologias de informação|Portal das tecnologias de informação]]}}


{{Ciência_da_computação}}
{{Computação}}
{{Computação}}
{{Engenharia de software}}
{{Engenharia de software}}


[[Categoria:Ciência da computação| ]]
[[Categoria:Ciência da computação| ]]
[[Categoria:Ciências exatas]]
{{Portal3|ti}}
{{Controle de autoridade}}

Edição atual tal como às 22h45min de 28 de novembro de 2021

Disambig grey.svg Nota: Se procura a ramificação da Ciência da Computação, veja Teoria da computação. Se procura o termo geral, veja Computação.
Lambda maiúscila Algoritmo de ordenação QuickSort
Utah teapot representing computer graphics Mouse Microsoft Tastenmaus representando a interação humano-computador
A Ciência da Computação lida com fundamentos teóricos da informação, computação, e técnicas práticas para suas implementações e aplicações.

Ciência da computação é a ciência que estuda as técnicas, metodologias, instrumentos computacionais e aplicações tecnológicas, que informatizem os processos e desenvolvam soluções de processamento de dados de entrada e saída pautados no computador. Não se restringindo apenas ao estudo dos algoritmos, suas aplicações e implementação na forma de software. Assim, a Ciência da Computação também abrange as técnicas de modelagem de dados e gerenciamento de banco de dados, envolvendo também a telecomunicação e os protocolos de comunicação, além de princípios que abrangem outras especializações da área.[1]

Enquanto ciência, classifica-se como ciência exata, apesar de herdar elementos da lógica filosófica aristotélica, tendo por isto um papel importante na formalização matemática de algoritmos, como forma de representar problemas decidíveis, i.e., os que são susceptíveis de redução a operações elementares básicas, capazes de serem reproduzidas através de um dispositivo qualquer capaz de armazenar e manipular dados. Um destes dispositivos é o computador digital, de uso generalizado, nos dias de hoje. Também de fundamental importância para a área de Ciência da Computação são as metodologias e técnicas ligadas à implementação de software que abordam a especificação, modelagem, codificação, teste e avaliação de sistemas de software.

Os estudos oriundos da Ciência da Computação podem ser aplicados em qualquer área do conhecimento humano em que seja possível definir métodos de resolução de problemas baseados em repetições previamente observadas. Avanços recentes na Ciência da Computação têm impactado fortemente a sociedade contemporânea, em particular as aplicações relacionadas às áreas de redes de computadores, Internet, Web, ciência de dados e computação móvel, que têm sido utilizadas por bilhões de pessoas ao redor do globo.[2]

História da Computação

Ver artigo principal: História da computação
O ábaco, primeira ferramenta de computação, em sua forma moderna.

A primeira ferramenta conhecida para a computação foi o ábaco,[3] cuja invenção é atribuída a habitantes da Mesopotâmia, em torno de 27002300 a.C.. Seu uso original era desenhar linhas na areia com rochas. Versões mais modernas do ábaco ainda são usadas como instrumento de cálculo.

No século VII a.C., na antiga Índia, o gramático Pānini formulou a gramática de Sânscrito usando 3959 regras conhecidas como Ashtadhyāyi, de forma bastante sistemática e técnica. Pānini usou transformações e recursividade com tamanha sofisticação que sua gramática possuía o poder computacional teórico tal qual a Máquina de Turing.

Entre 200 a.C. e 400, os indianos também inventaram o logaritmo, e a partir do século XIII tabelas logarítmicas eram produzidas por matemáticos islâmicos. Quando John Napier descobriu os logaritmos para uso computacional no século XVI,[3] seguiu-se um período de considerável progresso na construção de ferramentas de cálculo.

Algoritmos

No século VII, o matemático indiano Brahmagupta explicou pela primeira vez o sistema de numeração hindu-arábico e o uso do 0. Aproximadamente em 825, o matemático persa al-Khwarizmi escreveu o livro Calculando com numerais hindus, responsável pela difusão do sistema de numeração hindu-arábico no Oriente Médio, e posteriormente na Europa. Por volta do século XII houve uma tradução do mesmo livro para o latim: Algoritmi de numero Indorum. Tais livros apresentaram novos conceitos para definir sequências de passos para completar tarefas, como aplicações de aritmética e álgebra. Por derivação do nome do matemático, atualmente usa-se o termo algoritmo.

Lógica binária

Por volta do século III a.C., o matemático indiano Pingala inventou o sistema de numeração binário. Ainda usado atualmente no processamento de todos os computadores modernos, o sistema estabelece que sequências específicas de uns e zeros podem representar qualquer informação.

Em 1703 Gottfried Leibniz desenvolveu a lógica em um sentido formal e matemático, utilizando o sistema binário. Em seu sistema, uns e zeros também representam conceitos como verdadeiro e falso, ligado e desligado, válido e inválido. Mais de um século depois, George Boole publicou a álgebra booleana (em 1854), com um sistema completo que permitia a construção de modelos matemáticos para o processamento computacional. Em 1801, apareceu o tear controlado por cartão perfurado, invenção de Joseph Marie Jacquard, no qual buracos indicavam os uns e áreas não furadas indicavam os zeros. O sistema está longe de ser um computador, mas ilustrou que as máquinas poderiam ser controladas pelo sistema binário.

Engenho analítico

Foi com Charles Babbage que o computador moderno começou a ganhar forma, através de seu trabalho no engenho analítico. O equipamento descrito originalmente em 1837, mais de um século antes de seu sucessor, nunca foi construído com sucesso, mas possuía todas as funções de um computador moderno. O dispositivo de Babbage se diferenciava por ser programável, algo imprescindível para qualquer computador moderno.

Durante sua colaboração, a matemática Ada Lovelace publicou os primeiros programas de computador em uma série de notas para o engenho analítico.[4] Por isso, Lovelace é popularmente considerada como a primeira programadora.

Nascimento da Ciência da Computação

Antes da década de 1920, computador era um termo associado a pessoas que realizavam cálculos, geralmente liderados por físicos. Milhares de computadores eram empregados em projetos no comércio, governo e sítios de pesquisa. Após a década de 1920, a expressão máquina computacional começou a ser usada para referir-se a qualquer máquina que realize o trabalho de um profissional, especialmente aquelas de acordo com os métodos da Tese de Church-Turing.

O termo máquina computacional acabou perdendo espaço para o termo reduzido computador no final da década de 1940, com as máquinas digitais cada vez mais difundidas. Alan Turing, conhecido como pai da Ciência da Computação, inventou a Máquina de Turing, que posteriormente evoluiu para o computador moderno.

Trabalho teórico

Os fundamentos matemáticos da Ciência da Computação moderna começaram a ser definidos por Kurt Gödel com seu teorema da incompletude (1931). Essa teoria mostra que existem limites no que pode ser provado ou desaprovado em um sistema formal; isso levou a trabalhos posteriores por Gödel e outros teóricos para definir e descrever tais sistemas formais, incluindo conceitos como recursividade e cálculo lambda.

Em 1936 Alan Turing e Alonzo Church independentemente, e também juntos, introduziram a formalização de um algoritmo, definindo os limites do que pode ser computador e um modelo puramente mecânico para a computação. Tais tópicos são abordados no que atualmente chama-se Tese de Church-Turing, uma hipótese sobre a natureza de dispositivos mecânicos de cálculo. Essa tese define que qualquer cálculo possível pode ser realizado por um algoritmo sendo executado em um computador, desde que haja tempo e armazenamento suficiente para tal.

Representação visual da Máquina de Turing

Turing também incluiu na tese uma descrição da Máquina de Turing, que possui uma fita de tamanho infinito e um cabeçote para leitura e escrita que move-se pela fita. Devido ao seu caráter infinito, tal máquina não pode ser construída, mas tal modelo pode simular a computação de qualquer algoritmo executado em um computador moderno. Turing é bastante importante para a Ciência da Computação, tanto que seu nome é usado para o Prêmio Turing e o teste de Turing. Ele contribuiu para a quebra do código da Alemanha pela Grã-Bretanha[5] na Segunda Guerra Mundial, e continuou a projetar computadores e programas de computador pela década de 1940; cometeu suicídio em 1954.[6][7]

Shannon e a teoria da informação

Até a década de 1930, engenheiros eletricistas podiam construir circuitos eletrônicos para resolver problemas lógicos e matemáticos, mas a maioria o fazia sem qualquer processo, de forma particular, sem rigor teórico para tal. Isso mudou com a tese de mestrado de Claude Shannon de 1937, A Symbolic Analysis of Relay and Switching Circuits. Enquanto tomava aulas de Filosofia, Shannon foi exposto ao trabalho de George Boole, e percebeu que poderia aplicar esse aprendizado em conjuntos eletro-mecânicos para resolver problemas. Shannon desenvolveu a teoria da informação no artigo de 1948: A Mathematical Theory of Communication,[8] cujo conteúdo serve como fundamento para áreas como compressão de dados e criptografia.[9]

Contribuição social

Apesar de sua pequena história enquanto uma disciplina acadêmica, a Ciência da Computação deu origem a diversas contribuições fundamentais para a ciência e para a sociedade. Esta ciência foi responsável pela definição formal de computação e computabilidade, e pela prova da existência de problemas insolúveis ou intratáveis computacionalmente.

[10] Também foi possível a construção e formalização do conceito de linguagem de computador, sobretudo linguagem de programação, uma ferramenta para a expressão precisa de informação metodológica flexível o suficiente para ser representada em diversos níveis de abstração.[11]

Para outros campos científicos e para a sociedade de forma geral, a Ciência da Computação forneceu suporte para a Revolução Digital, dando origem a Era da Informação.[10] A computação científica é uma área da computação que permite o avanço de estudos como o mapeamento do genoma humano (ver Projeto Genoma Humano).Página Predefinição:Quote/styles.css não tem conteúdo.

Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio, a biologia com o microscópio, ou a química com os tubos de ensaio. A ciência não estuda ferramentas, mas o que fazemos e o que descobrimos com elas.
— Citação atribuída a Edsger Dijkstra

Pessoas notáveis

Algumas das pessoas mais importantes da computação foram agraciadas com o Prêmio Turing.

Precursores

Personalidades influentes

Áreas de pesquisa

Relacionamento com outros campos

Por ser uma disciplina recente, existem várias definições alternativas para a Ciência da Computação. Ela pode ser vista como uma forma de ciência, uma forma de matemática ou uma nova disciplina que não pode ser categorizada seguindo os modelos atuais. Várias pessoas que estudam a Ciência da Computação o fazem para tornarem-se programadores, levando alguns a acreditarem que seu estudo é sobre o software e a programação. Apesar disso, a maioria dos cientistas da computação são interessados na inovação ou em aspectos teóricos que vão muito além de somente a programação, mais relacionados com a computabilidade.

Apesar do nome, muito da Ciência da Computação não envolve o estudo dos computadores por si próprios. De fato, o conhecido cientista da computação Edsger Dijkstra é considerado autor da frase "Ciência da Computação tem tanto a ver com o computador como a astronomia com o telescópio […]". O projeto e desenvolvimento de computadores e sistemas computacionais são geralmente considerados disciplinas fora do contexto da Ciência da Computação. Por exemplo, o estudo do hardware é geralmente considerado parte da engenharia de computação, enquanto o estudo de sistemas computacionais comerciais são geralmente parte da tecnologia da informação ou sistemas de informação.

Por vezes a Ciência da Computação também é criticada por não ser suficientemente científica, como exposto na frase "Ciência é para a Ciência da Computação assim como a hidrodinâmica é para a construção de encanamentos", credita a Stan Kelly-Bootle.[13] Apesar disso, seu estudo frequentemente cruza outros campos de pesquisa, tais como a inteligência artifical, física e linguística.

Ela é considerada por alguns por ter um grande relacionamento com a matemática, maior que em outras disciplinas. Isso é evidenciado pelo fato que os primeiros trabalhos na área eram fortemente influenciados por matemáticos como Kurt Gödel e Alan Turing; o campo continua sendo útil para o intercâmbio de informação com áreas como lógica matemática, teoria das categorias e álgebra. Apesar disso, diferente da matemática, a Ciência da Computação é considerada uma disciplina mais experimental que teórica.

Várias alternativas para o nome da disciplina já foram cogitadas. Em francês ela é chamada informatique, em alemão Informatik, em espanhol informática, em holandês, italiano e romeno informatica, em polonês informatyka, em russo информатика e em grego Πληροφορική. Apesar disso, tanto em inglês quanto em português informática não é diretamente um sinônimo para a Ciência da Computação; o termo é usado para definir o estudo de sistemas artificiais e naturais que armazenam processos e comunicam informação, e refere-se a um conjunto de ciências da informação que engloba a Ciência da Computação. Em Portugal, no entanto, apesar de a palavra estar dicionarizada com esse sentido amplo, o termo é usado como sinónimo de Ciência da Computação.

Profissão

De forma geral, cientistas da computação estudam os fundamentos teóricos da computação, de onde outros campos derivam, como as áreas de pesquisa supracitadas. Como o nome implica, a Ciência da Computação é uma ciência pura, não aplicada. Entretanto, o profissional dessa área pode seguir aplicações mais práticas de seu conhecimento, atuando em áreas como desenvolvimento de software, telecomunicação, consultoria, análise de sistemas, segurança em TI, governança em TI, análise de negócios e tecnologia da informação. O profissional de computação precisa ter muita determinação na apreensão tecnológica, uma vez que esta área sofre contínuas transformações, modificando rapidamente paradigmas.

Ver também

Referências

  1. BROOKSHEAR, J. Gleen. Ciência da Computação: uma visão abrangente - 11º ed. Porto Alegre: Bookman, 2013.
  2. FEDELI, R.; POLLONI, E.; PERES, F. Introdução à Ciência da Computação. 2 ed. São Paulo: Cengage Learning, 2009.
  3. 3,0 3,1 IFRAH, Georges (2001). The Universal History of Computing (em inglês). Nova York: John Wiley & Sons. ISBN 0-471-39671-0 
  4. Huskey, Velma R.; Huskey, Harry D. (1980). «Lady Lovelace and Charles Babbage». Annals of The History of Computing (em inglês). 2 (4). Arlington, VA: American Federation of Information Processing Societies. 384 páginas. ISSN 1058-6180 
  5. METROPOLIS, N. (ed.);HOWLETT, J.(ed.);ROTA, Gian-Carlo(ed.);GOOD, I. J.(Contribuidor) (1980). «Pioneering Work on Computer at Bletchley». A History of Computing in the Twentieth Century (em inglês). Nova York: Academic Press. pp. 31–45. ISBN 0-12-491650-3 
  6. COPELAND, B. Jack (Editor) (2004). The Essential Turing. The Ideas that Gave Birth to the Computer Age. Oxford: Clarendon Press, Oxford. 613 páginas. ISBN 0-19-825079-7 
  7. STRATHERN, Paul (1997). The Big Idea: Turing & the Computer. London: Arrow. 95 páginas. ISBN 0-09-923782-2 
  8. SHANNON, Claude E.; WEAVER, Warren (1949). The Mathematical Theory of Communication (em inglês). Illinois: The University of Illinois Press (Illini books). pp. 3–91. Library of Congress Catalog Card Nº 49-11922 
  9. BRETON, Philippe (1991). História da Informática. São Paulo: UNESP. pp. 52–55. ISBN 85-7139-021-5 
  10. 10,0 10,1 «Computer Science: Achievements and Challenges circa 2000» (PDF) (em inglês). Março de 2000 
  11. Hal Abelson, G.J. Sussman, J.Sussman (1996). Structure and Interpretation of Computer Programs 2 ed. [S.l.]: MIT Press. ISBN 0-262-01153-0 
  12. Ghallab, M., Nau, D. S., and Traverso, P. (2004). Automated Planning: Theory and Practice. ISBN 1-55860-856-7
  13. Computer Language, outubro de 1990

Ligações externas

Outros projetos Wikimedia também contêm material sobre este tema:
Wikilivros Livros e manuais no Wikilivros
Commons Categoria no Commons
Wikiversidade Cursos na Wikiversidade


Predefinição:Ciência da computação

Predefinição:Engenharia de software

talvez você goste