Um exemplo de derivação automática com alguns comentários. O projeto COMPLETO, desenvolvido em Compaq Visual Fortran 6.6, pode ser baixado AQUI.
São três arquivos diferentes denominados no meu projeto como sendo: MAIN.F90, que contem o código PROGRAM TEST dado abaixo, FUNCOES.F90, que contem o módulo FUNCOES, também dado abaixo, e DERIV_CLASS.F90, o módulo de derivação cujo link está disponível no post Derivação Automática.
----------------- CÓDIGO PARA O MAIN.F90 ----------------------
PROGRAM TEST
USE DERIV_CLASS ! torna o módulo de derivação disponível
USE FUNCOES
INTEGER, PARAMETER :: TAM_X=3 !tamanho do vetor x
REAL*8 :: F_, X_(TAM_X), DF(TAM_X) !variáveis p/ armazenar valores de f, x e derivada
REAL*8 :: DDF(TAM_X * (TAM_X + 1) / 2) !variável p/ armazenar valor da 2a derivada
TYPE (FUNC) :: X(TAM_X), F !Para usar o módulo é preciso utilizar estes tipos
!Valores de X para os quais se deseja calcular a derivada
X_(1) = 1.0D0
X_(2) = 1.3D0
X_(3) = 1.8D0
! Zerando o valor da derivada até então
DF = 0.0D0
CALL DERIVATIVE(2) !declara a ordem da derivada - 2 indica 1a e 2a derivadas
! DECLARAR AS VARIÁVEIS INDEPENDENTES(X) E SEUS VALORES (X_)
CALL INDEPENDENT(1, X(1), X_(1)) !primeira variável independente
CALL INDEPENDENT(2, X(2), X_(2)) !segunda variável independente
CALL INDEPENDENT(3, X(3), X_(3)) !terceira variável independente
F = F1(X,TAM_X) !definindo q a função é calculada pela função f1, presente no módulo funcoes
!Extraindo valores das derivadas e mostrando os mesmo na tela.
CALL EXTRACT(F, DF, DDF)
WRITE(*, *) 'DF',DF
WRITE(*, *) 'DDF',DDF
END PROGRAM TEST
----------------- CÓDIGO PARA O MÓDULO FUNCOES ----------------------
MODULE FUNCOES
USE DERIV_CLASS
CONTAINS
FUNCTION F1(X,TAM_X) RESULT(Y)
INTEGER :: TAM_X
TYPE (FUNC) :: X(TAM_X), Y
!AQUI PODE SER ESCRITA QUALQUER FUNÇÃO DE X(TAM_X)
Y = 2*X(1)**2 + X(2)**3 + COS(X(3))
END FUNCTION
END MODULE FUNCOES
-------------------------MUITO IMPORTANTE -----------------------------------
----------------- ALTERAÇÃO NO MÓDULO DERIV_CLASS ----------------------
MODULE deriv_class IMPLICIT NONE
PRIVATE
INTEGER, PARAMETER :: n = 3 ! <<< AQUI precisa-se colocar o valor de tam_x
------------------------------------------------------------------------------------
Como o código é aberto, podem ser feitas as alterações que o usuário achar necessário. Por exemplo, pode-se colocar o parâmetro n do módulo Deriv_class em função do TAM_X já declarado anteriormente.
Até mais.
sexta-feira, 5 de junho de 2009
Assinar:
Postar comentários (Atom)
Como eu faco para criar o arquivo deriv_class.mod para ser chamdo por USE deriv_class?
ResponderExcluirVocê não precisa criá-lo. Ele é criado automaticamente durante a compilação, a partir do arquivo deriv_class.f90.
ResponderExcluirBom dia!
ResponderExcluirEstou escrevendo um artigo sobre cinética química e estou com dificuldade em fazer a modelagem, estou fazendo em matlab, porem gostaria de fazer em fortran, qual edição do fortran vc pode me recomendar?
"Por exemplo, pode-se colocar o parâmetro n do módulo Deriv_class em função do TAM_X já declarado anteriormente."
ResponderExcluirBem, de acordo com algumas fontes, inclusive tentativas minhas, não é possível colocar N em função do TAM_X. O que pode ser possível é colocar um N bem grande, podendo derivar qualquer função que tenha o número de variáveis menor ou igual ao N grande. Cuidado com estouros de memória...
Pessoal, uma ajuda. Possuo um aquivo em .txt muito extenso onde há duas colunas, sendo que preciso multiplicar apenas uma coluna por uma constante. Como eu faço ?
ResponderExcluir