# # # # Check support for LambertW if (!strstrt(GPVAL_COMPILE_OPTIONS, "+COMPLEX_FUNC")) { print "This copy of gnuplot does not support complex LambertW" exit # return to caller } # # Complex Lambert W function # I = {0,1} e = exp(1.0) set title "real-valued range of Lambert W function for branches k=0 k=-1" set xrange [-1:3] set yrange [-4:2] set samples 1000 set xzeroaxis set yzeroaxis set xtics 0, 0.5 set xtics add ("-1/e" -exp(-1)) set arrow 1 from -1/e, graph 0 to -1/e, LambertW(-exp(-1),0) nohead lt 0 plot sample [x = -1./e : 4.] LambertW(x, 0) lw 2, [x = -1./e : 0] LambertW(x,-1) lw 2 |
set border -1 front lt black linewidth 1.000 dashtype solid unset key unset arrow 1 set xtics 0.5 unset colorbox set view 42, 23, 0.928406, 1.65 set isosamples 30, 30 set style func lines set contour base set cntrparam levels 11 set cntrparam levels incremental -1,0.2 set cntrparam firstlinetype 101 set for [l=2:7] linetype l+99 lc l lw 2 set xyplane at -2 set title offset character 15 set xrange [ -2.000 : 1.000 ] set yrange [ -1.000 : 1.000 ] set zrange [ -2.000 : 1.800 ] set title "real( LambertW( x + iy, 0 ) )" splot real(LambertW( x + I*y, 0 )) lc "plum" |
set title "imag( LambertW( x + iy, 0 ) )" set key splot imag(LambertW( x + I*y, 0 )) lc "cyan" title "" |
set view 75, 281, 1.11607, 1.33952 set isosamples 30, 30 set style data lines set xyplane at 0 set title font ",15" set xrange [ -10.00 : 10.00 ] set yrange [ -8.00 : 12.00 ] set zrange [ 0.00 : * ] noextend set ytics offset 0,-1 scale 3.0 set xtics offset 0,-0.5 set pm3d depthorder set pm3d border lt black linewidth 0.25 unset colorbox set title "LambertW( x+{/:Italic i}y, k )" splot for [k=0:4] abs(LambertW(x+y*{0,1}, k)) with pm3d lc k title sprintf(" k = %d",k) at end |
|