File: MacCmplx.sci

package info (click to toggle)
scilab 4.0-12
  • links: PTS
  • area: non-free
  • in suites: etch, etch-m68k
  • size: 100,640 kB
  • ctags: 57,333
  • sloc: ansic: 377,889; fortran: 242,862; xml: 179,819; tcl: 42,062; sh: 10,593; ml: 9,441; makefile: 4,377; cpp: 1,354; java: 621; csh: 260; yacc: 247; perl: 130; lex: 126; asm: 72; lisp: 30
file content (116 lines) | stat: -rw-r--r-- 4,064 bytes parent folder | download | duplicates (2)
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
function []=TitleWithSelectedFont(titre,ftype,fsize)
   // To draw a title with a selected font without
   // change the current font
   // Bruno (10/10/2001): macros for the complex function dem
   savefont = xget("font")
   xset("font",ftype,fsize)
   xtitle(titre)
   xset("font",savefont(1),savefont(2))
endfunction

function [xr,yr,zr,xi,yi,zi] = CmplxFacets(R,e,TypeDomain,TypeCut,n,StrFunc)
  //
  //  A function to compute the facets for drawing a complex function
  //  on a square or a disk with branch(es) cut(s) on Ox or Oy
  //
  //  TypeDomain : "Square" or "Disk"
  //     TypeCut : "Ox" or "Oy"
  //           R : length of half a side of the square or radius of the disk
  //           e : thin layer to avoid the branch(es) cut(s)
  //           n : a scalar (for Square) or a 2-vector = [ntheta, nr]
  //               (for Disk) for discretization
  //     StrFunc : the string which names the complex function (this is
  //               because primitive don't pass as function argument)
  //
  // Bruno (10/10/2001): macros for the complex function dem
  if TypeDomain == "Square" then
     if TypeCut == "Ox" then
       x1 = linspace(-R, R, n);
       y1 = linspace( e, R, n/2);
     else  // for TypeCut = "Oy" ...
       x1 = linspace( e, R, n/2);
       y1 = linspace(-R, R, n);
     end
     X1 = ones(y1')*x1 ; Y1 = y1'*ones(x1);
  else // for TypeDomain = "Disk"
     r = linspace(0,R, n(2));
     if TypeCut == "Ox" then
        theta = linspace(0,%pi,n(1))';
	X1 =     cos(theta)*r
	Y1 = e + sin(theta)*r
     else // for TypeCut = "Oy"
        theta = linspace(-%pi/2,%pi/2,n(1))';
	X1 = e + cos(theta)*r
	Y1 =     sin(theta)*r
     end
  end
  X2 = -X1 ; Y2 = -Y1;
  Z1 = evstr(StrFunc+"(X1 + %i*Y1)");
  Z2 = evstr(StrFunc+"(X2 + %i*Y2)");
  [xr1,yr1,zr1]=nf3d(X1,Y1,real(Z1));
  [xr2,yr2,zr2]=nf3d(X2,Y2,real(Z2));
  xr = [xr1 xr2]; yr = [yr1 yr2]; zr = [zr1 zr2];
  [xi1,yi1,zi1]=nf3d(X1,Y1,imag(Z1));
  [xi2,yi2,zi2]=nf3d(X2,Y2,imag(Z2));
  xi = [xi1 xi2]; yi = [yi1 yi2]; zi = [zi1 zi2];
endfunction 


function []=PlotCmplxFunc(R,e,TypeDomain,TypeCut,n,StrFunc,theta,alpha,DomReal)

  //  A function to draw on a square or a disk a complex function 
  //  with branch(es) cut(s) on Ox or Oy
  //
  //  TypeDomain : "Square" or "Disk"
  //     TypeCut : "Ox" or "Oy"
  //           R : length of half a side of the square or radius of the disk
  //           e : thin layer to avoid the branch(es) cut(s)
  //           n : a scalar (for Square) or a 2-vector = [ntheta, nr]
  //               (for Disk) for discretization
  //     StrFunc : the string which names the complex function (this is
  //               because primitive don't pass as function argument)
  // theta,alpha : usual parameters for plot3d
  //     DomReal : interval for which the real restriction is drawn

  // Bruno (10/10/2001): macros for the complex function dem
      
  // computes the facets
  [xr,yr,zr,xi,yi,zi] = CmplxFacets(R,e,TypeDomain,TypeCut,n,StrFunc)

  // draw
  xbasc()
  xsetech([0,0,1,1],[0,0,1,1])
   
  Rs = string(R);
  if TypeDomain == "Square" then
     end_title = " Function on [-"+Rs+","+Rs+"]x[-"+Rs+","+Rs+"]"
  else
     end_title = " Function on D(0,R="+Rs+")"
  end
  if StrFunc == "f" then
     the_title = "Your Custom (named f) Complex" + end_title
  else
     the_title = "The Complex "+StrFunc+ end_title
  end
  TitleWithSelectedFont(the_title,4,3)
  if DomReal(2) > DomReal(1) then
     xstring(0.1,-0.15," In yellow : the real "+StrFunc+" function")
  end
  
  // plot Im(z)
  xsetech([0.5,0.05,0.5,0.95])
  plot3d(xi,yi,zi,theta,alpha,"Re(z)@Im(z)@",[2 6 4])
  TitleWithSelectedFont("Im("+StrFunc+"(z))",2,2)

  // plot Re(z) + the real restriction
  xsetech([0,0.05,0.5,0.95])
  plot3d(xr,yr,zr,theta,alpha,"Re(z)@Im(z)@",[ 2 6 4])
  TitleWithSelectedFont("Re("+StrFunc+"(z))",2,2)
  if DomReal(2) > DomReal(1) then
     xx = linspace(DomReal(1),DomReal(2),40)';
     yy = zeros(xx);
     zz = evstr(StrFunc+"(xx)");
     param3d1(xx,yy,list(zz,32),theta,alpha,flag=[0,0])
  end
  xselect()
endfunction