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
|
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
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 20 k=1,n
lp=lp+nx
do 20 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)
if(typ.ne.2) then
nf=1
fl=maxc
else
fl=n1
nf=2
write(form(nf),120) fl,n2
endif
c
l1=1
l0=1
c
41 write(cw(l1:l1+fl-1),form(nf)) a
l1=l1+fl
if(cw(l0:l0).eq.'+'.or.cw(l0:l0).eq.' ') l0=2
c if(a.ge.0.0d+0) 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
c if(n2.eq.0) l1=l1-1
call cvstr(l1-l0,str(lstr),cw(l0:l1-1),0)
lstr=lstr+l1-l0
istr((k-1)*m+l+1)=lstr
20 continue
return
120 format('(f',i2,'.',i2,')')
130 format('(1pd',i2,'.',i2,')')
end
|