Télécharger inctyp.eso

Retour à la liste

Numérotation des lignes :

inctyp
  1. C INCTYP SOURCE CB215821 20/11/25 13:30:19 10792
  2. SUBROUTINE INCTYP(MATRIK,
  3. $ ATYP,
  4. $ IMPR,IRET)
  5. IMPLICIT INTEGER(I-N)
  6. IMPLICIT REAL*8 (A-H,O-Z)
  7. C***********************************************************************
  8. C NOM : INCTYP
  9. C DESCRIPTION :
  10. C Ce sp initialise le vecteur inconnue primale
  11. C (i.e. x de Ax=b) avec un chpoint d'inconnues primales.
  12. C On a en vue une méthode itérative de résolution.
  13. C
  14. C Ce sp est quasiment identique à mesmbr.eso.
  15. C C'est une interface à ch2vec.
  16. C
  17. C
  18. C LANGAGE : ESOPE
  19. C AUTEUR : Stéphane GOUNAND (CEA/DRN/DMT/SEMT/TTMF)
  20. C mél : gounand@semt2.smts.cea.fr
  21. C***********************************************************************
  22. C APPELE : CH2VEC
  23. C***********************************************************************
  24. C ENTREES : MATRIK, MCHINI, IMPR
  25. C ENTREES/SORTIES : -
  26. C SORTIES : INCX, IRET
  27. C CODE RETOUR (IRET) : 0 si ok
  28. C <0 si problème
  29. C MATRIK : pointeur sur segment MATRIK de l'include SMMATRIK
  30. C on pioche dedans les informations nécessaires
  31. C (numérotations, inconnues, support géométriques)
  32. C pour effectuer la conversion MCHINI->INCX.
  33. C MCHINI : pointeur sur segment MCHPOI de l'include SMCHPOI
  34. C chpoint d'initialisation du vecteur INCX
  35. C IMPR : niveau d'impression
  36. C INCX : pointeur sur segment IZA de l'include SMMATRIK
  37. C vecteur x initial pour la résolution de Ax=b.
  38. C Il est initialisé à 0 si MCHINI est nul
  39. C sinon les valeurs non nulles de MCHINI
  40. C correspondant à des inconnues primales sont
  41. C chargées dans INCX.
  42. C Les valeurs non nulles de MCHINI NE correspondant
  43. C PAS à des inconnues primales donnent lieu à
  44. C l'émission d'un warning (cf. CH2VEC).
  45. C***********************************************************************
  46. C VERSION : v1, 01/04/98, version initiale
  47. C HISTORIQUE : v1, 01/04/98, création
  48. C HISTORIQUE :
  49. C HISTORIQUE :
  50. C***********************************************************************
  51. C Prière de PRENDRE LE TEMPS de compléter les commentaires
  52. C en cas de modification de ce sous-programme afin de faciliter
  53. C la maintenance !
  54. C***********************************************************************
  55.  
  56. -INC PPARAM
  57. -INC CCOPTIO
  58. POINTEUR INCX.IZA
  59. -INC SMLENTI
  60. POINTEUR ATYP.MLENTI
  61. C
  62. IRET=0
  63. SEGACT MATRIK
  64. C Initialisation de l'inconnue à 0
  65. JG=KNTTP
  66. SEGINI ATYP
  67. NBVA=KNTTP
  68. MINC=KMINCP
  69. SEGACT MINC
  70. NBI=LISINC(/2)
  71. NPT=NPOS(/1)-1
  72. IDMAT=KIDMAT(1)
  73. SEGACT IDMAT
  74. DO IBI=1,NBI
  75. DO IPT=1,NPT
  76. IF (MPOS(IPT,IBI).NE.0) THEN
  77. ATYP.LECT(NUAN(NPOS(IPT)+
  78. $ MPOS(IPT,IBI)-1))=IBI
  79. ENDIF
  80. ENDDO
  81. ENDDO
  82. SEGDES IDMAT
  83. SEGDES MINC
  84. C
  85. IF (IMPR.GT.5) THEN
  86. WRITE(IOIMP,*) 'inctyp.eso : création du pointeur ATYP=',ATYP
  87. IF (IMPR.GT.7) THEN
  88. WRITE(IOIMP,*) 'ATYP(1..',JG,')= '
  89. WRITE(IOIMP,1002)(ATYP.LECT(II),II=1,JG)
  90. ENDIF
  91. ENDIF
  92. C
  93. SEGDES ATYP
  94. SEGDES MATRIK
  95. *
  96. * Normal termination
  97. *
  98. RETURN
  99. *
  100. * Format handling
  101. *
  102. 1002 FORMAT(10(1X,I7))
  103. *
  104. * Error handling
  105. *
  106. 9999 CONTINUE
  107. WRITE(IOIMP,*) 'An error was detected in inctyp.eso'
  108. RETURN
  109. *
  110. * End of INCTYP
  111. *
  112. END
  113.  
  114.  
  115.  
  116.  
  117.  
  118.  
  119.  
  120.  
  121.  
  122.  
  123.  
  124.  
  125.  
  126.  
  127.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales