IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Fortran Discussion :

data file creation


Sujet :

Fortran

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 24
    Par défaut data file creation
    Bonjour,

    j'ai fait le programme suivant qui calcule des vitesses, puis des accélérations (par différentiation), mais je n'arrive pas à écrire correctement les vitesses dans velocity.dat : lorsque je veux afficher le contenu de velocity.dat par la commande linux "cat velocity.dat", l'écran m'affiche une série de caractères bizarres !

    voici mon programme :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    PROGRAM rocketlaunch
          IMPLICIT NONE
          INTEGER i,n,nl
    C n is the number of row in the data file
          OPEN (22,file='exo4data.dat',form='formatted',status='old')
          nl=0
          READ (22,*) n
          PRINT *, 'n=', n
          CALL matra(i,n)
          END
    C
    C this subroutine stores the data file into a matrix A :
    C
          SUBROUTINE matra(i,n)
          INTEGER i,n
          REAL A(n,2)
          DO i=1,n
          READ (22,*) (A(i,j),j=1,2)
          END DO
          PRINT *, 'A=',A
          CALL velocity(i,n,A)
          RETURN
          END
    C
    C this subroutine computes the estimated velocities and stores them
    C into the matrix C :
    C
          SUBROUTINE velocity(i,n,B)
          IMPLICIT NONE
          INTEGER  i,n
          REAL B(n,2),C(n+1)
          DO i=3,n
          C(i)=(B(i+1,2)-B(i-1,2))/(B(i+1,1)-B(i-1,1))
          END DO
          C(1)=n
          C(2)=(B(2,2)-B(1,2))/(B(2,1)-B(1,1))
          C(n)=(B(n,2)-B(n-1,2))/(B(n,1)-B(n-1,1))
          PRINT *, 'C=',C
          OPEN (unit=33,file='velocity.dat',form='unformatted',
         1  status='replace',action='write')
          WRITE (33) C
          CALL acceleration(i,n,B,C)
          RETURN
          END
    C
    C this subroutine computes the estimated accelerations and stores them
    C into the matrix G :
    C
          SUBROUTINE acceleration(i,n,E,F)
          IMPLICIT  NONE
          INTEGER i,n
          REAL E(n,2),F(n+1),G(n+1)
          DO i=3,n
          G(i)=(F(i+1)-F(i-1))/(E(i+1,1)-E(i-1,1))
          END DO
          G(1)=n
          G(2)=(F(2)-F(1))/(E(2,1)-E(1,1))
          G(n)=(F(n)-F(n-1))/(E(n,1)-E(n-1,1))
          PRINT *, 'G=',G
          RETURN
          END
    Merci d'avance pour votre aide,

    Nulysses

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    489
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 489
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
          OPEN (unit=33,file='velocity.dat',form='unformatted',
         1  status='replace',action='write')
          WRITE (33) C
    Tu utilises le format "unformatted"; les données sont écrites en binaire (en gros), et c'est sous cette forme (peu lisible pour un humain standard) que te l'affiche le "cat velocity.dat".

    Avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
          OPEN (unit=33,file='velocity.dat',form='formatted')
          WRITE (33,*) C
    Tu obtiendras un fichier plus lisible.

    Bonne continuation.

Discussions similaires

  1. Copie Data File Raw Device --> File en Aix 5.3 / 9i
    Par Merilka dans le forum Administration
    Réponses: 4
    Dernier message: 12/09/2007, 11h48
  2. [SQL Server] - Organisation des Data Files
    Par nicolas23 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/05/2007, 18h29
  3. ORA-01110: data file
    Par david_12 dans le forum Oracle
    Réponses: 2
    Dernier message: 02/04/2007, 16h53
  4. Réponses: 2
    Dernier message: 30/08/2005, 14h11
  5. Problème d'index avec load data file
    Par bruno782 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 09/03/2005, 12h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo