Avançar para o conteúdo principal

Conversão de ângulos e erro computacional.

Conversão de ângulos e erro computacional.


Como é sabido os computadores pelo seu modo de cálculo interno acumulam erros.

No caso de um programa que estou a desenvolver, é necessário converter ângulos entre diversos sistemas, em particular entre o sistema sexagesimal e o centesimal para graus.


Como dados de partida, os ângulos:

A = 60º 12'21.5"

B = 70º 35'51.7"


A conversão para centesimais feita pela linguagem de programação e por uma calculadora de bolso mostra-se a seguir:


A = 60.20603º   60.20597º

B = 70.59784º   70.59769º


Pode-se verificar que para o ângulo A, o valor obtido pela linguagem de programação é superior em 0.00006 graus. Já para o ângulo B o valor obtido pela linguagem de programação é superior em 0.00015 .


Podemos pensar que são diferenças muito pequenas, mas se tomarmos como exercício, o cálculo de um desvio em XX (por exemplo para Topografia), em que se medir uma distância de 1000 metros, o desvio deste ângulo A é de 1 mm, já o do ângulo B é de 2.6 mm. Ok continua a ser praticamente desprezável o erro de cálculo face por exemplo ao erro de observação.


E se em vez de Topografia considerarmos a disciplina de Astrofísica?


E se continuarmos na linguagem de programação com cálculos em cima de resultados assim obtidos... podemos imaginar que a magnitude deste erro aumenta.


Como resolver? Recorrendo se necessário a estratégias de cálculo, e/ou a linguagens de programação ou bibliotecas que permitam trabalhar com precisões de cálculo superiores.


Para o dia a dia, o que podemos esperar numa linguagem de programação é o suficiente em precisão, no entanto, atenção, se compararmos


if (60.20603 == 60.20597) obtemos um FALSE que para uma análise humana seria TRUE.

Comentários

Enviar um comentário

Obrigado pelo seu contacto.

Mensagens populares deste blogue

C# - Viadutos Excel - ISPOL

C# - Viadutos Excel - ISPOL Ler dados do Excel e passar a informação para o ISPOL é um ganho de produtividade e organização. Desta vez, apresento uma utilidade que lê um ficheiro Excel, e transforma os dados para o menu de estruturas do ISPOL. Partindo de um Excel organizado, por pks eixos e espessuras da estrutura etc... como o seguinte: Elaborei um programita em CSharp: Este programa funciona em modo "DOS" não tem uma interface gráfica de janelas: O programa cria os ficheiros necessários, o Excel pode estar organizado por eixos, e o programa guarda um ficheiro para cada eixo: O resultado depois de abrir o ficheiro em ISPOL é o seguinte: Com as alterações ao projecto pode-se manter um ficheiro de apresentação e controlo em Excel.

Politica de privacidade das aplicações colocadas na Play Store do Google

Politica de privacidade das aplicações colocadas na Play Store do Google. As aplicações não recolhem qualquer dado do utilizador nem a armazenam ou partilham com terceiros. Não recolhem a localização nem a armazenam ou partilham com terceiros. Alguma informação sobre os utilizadores que possa chegar ao programador por via da Play Store, será tratada de acordo com toda a confidencialidade, e não fornecida a terceiros. Obrigado.

ISPOL CAD CSharp - Fila de estratigrafia nos perfis longitudinais

ISPOL CAD CSharp - Fila de estratigrafia nos perfis longitudinais No corrente exercício, foi necessário agilizar o desenho do texto das camadas nos perfis. fonte : https://www.youtube.com/watch?v=PBEX1SFv8hk O modo de apresentação dos perfis quilométricos para a SCiT assim o requere. O trabalho de copiar a informação da tabela de geotécnia de Curva Masa para o desenho, se feito de forma manual consome bastante tempo. E como estas tabelas costumam sofrer alterações ao longo do projecto é um ponto a favor de alguma programação. Esta poderia ser apenas a transformação de dados do Excel para o ISPOL. O objectivo final é transformar a tabela acima, numa informação gráfica como o exemplo genérico seguinte: No menu de Tablas de Textos do ISPOL, encontrei uma limitação de número de caracteres, o que impede a copia directa de informação do Excel para o ISPOL. Assim pensei em adicionar algo mais ao planeado na programação. No ISPOL coloca-se um marcador para cada intervalo, que depois em CAD se