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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
subroutine cvdm(x,nx,m,n,maxc,mode,str,istr)
c
c ====================================================================
c scilab . librairie system
c ====================================================================
c
c cvdm transcrit une matrice reelle en une matrice de chaines
c de caracteres scilab
c
c ====================================================================
c
c subroutine cvdm(x,nx,m,n,maxc,mode,str,istr)
c
c double precision x(*)
c integer nx,m,n,maxc,mode,str(*),istr(m*n+1)
c
c x : tableau contenant les coefficients de la matrice x
c nx : entier definissant le rangement dans x
c m : nombre de ligne de la matrice
c n : nombre de colonnes de la matrice
c maxc : nombre de caracteres maximum autorise pour
c representer un nombre
c mode : si mode=1 representation variable
c si mode=0 representation d(maxc).(maxc-7)
c str : tableau contenant apres execution la suite des codes scilab
c des caracteres.taille >= m*n*maxc
c istr : tableau donnant la structure de str
c
c ================================== ( Inria ) =============
c
c Copyright INRIA
double precision x(*),a,eps,dlamch
integer maxc,mode,fl,typ
integer str(*),istr(*),ipt
character*256 cw
character*1 ii
character*10 form(2)
data ipt /46/
c
eps=dlamch('p')
write(form(1),130) maxc,maxc-7
c
lstr=1
istr(1)=1
lp=-nx
do 60 k=1,n
lp=lp+nx
do 50 l=1,m
c
c traitement du coeff (l,k)
a=x(lp+l)
if(m*n.gt.1.and.abs(a).lt.eps.and.mode.ne.0) a=0.0d+0
c determination du format devant representer a
typ=1
if(mode.eq.1) call fmt(abs(a),maxc,typ,n1,n2)
c
l1=1
l0=1
c
if(typ.eq.1) then
fl=maxc
write(cw(l1:l1+fl-1),form(1)) a
elseif(typ.eq.-1) then
c . Inf
if(a.lt.0.0d0) then
fl=4
cw(l1:l1+fl-1)='-Inf'
else
fl=3
cw(l1:l1+fl-1)='Inf'
endif
elseif(typ.eq.-2) then
c . Nan
fl=3
cw(l1:l1+fl-1)='Nan'
else
fl=n1
if(a.lt.0.0d0) fl=fl+1
write(form(2),120) fl,n2
write(cw(l1:l1+fl-1),form(2)) a
endif
c
l1=l1+fl
if(cw(l0:l0).eq.'+'.or.cw(l0:l0).eq.' ') l0=2
l1=l1+1
42 l1=l1-1
ii=cw(l1-1:l1-1)
if(ichar(ii).eq.ichar(' ')) goto 42
if(ichar(ii).eq.ipt) goto 42
call cvstr(l1-l0,str(lstr),cw(l0:l1-1),0)
lstr=lstr+l1-l0
istr((k-1)*m+l+1)=lstr
50 continue
60 continue
return
120 format('(f',i2,'.',i2,')')
130 format('(1pd',i2,'.',i2,')')
end
|