mirror of
git://projects.qi-hardware.com/openwrt-packages.git
synced 2024-11-22 18:57:31 +02:00
add some lua-plplot-examples
This commit is contained in:
parent
0308bbce47
commit
d3bb3a95be
@ -0,0 +1,12 @@
|
|||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
if string.sub(_VERSION,1,7)=='Lua 5.0' then
|
||||||
|
lib=loadlib('/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/plplotluac.so','luaopen_plplotluac') or
|
||||||
|
loadlib('/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/plplotluac.dll','luaopen_plplotluac') or
|
||||||
|
loadlib('/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/plplotluac.dylib','luaopen_plplotluac')
|
||||||
|
assert(lib)()
|
||||||
|
else
|
||||||
|
package.cpath = '/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/?.so;' ..
|
||||||
|
'/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/?.dll;' ..
|
||||||
|
'/home/pub/spock/src/qi/openwrt-xburst/build_dir/target-mipsel_uClibc-0.9.30.1/plplot-5.9.7/bindings/lua/?.dylib;' ..package.cpath
|
||||||
|
require('plplotluac')
|
||||||
|
end
|
210
nanonote-example-files/files/lua-plplot-examples/x01.lua
Normal file
210
nanonote-example-files/files/lua-plplot-examples/x01.lua
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
--[[ $Id: x01.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Simple line plot and multiple windows demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
-- Variables and data arrays used by plot generators
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
xs = {}
|
||||||
|
ys = {}
|
||||||
|
|
||||||
|
fontset = 1
|
||||||
|
f_name = ""
|
||||||
|
|
||||||
|
|
||||||
|
function plot1(do_test)
|
||||||
|
for i = 1, 60 do
|
||||||
|
x[i] = xoff + xscale * (i) / 60
|
||||||
|
y[i] = yoff + yscale * x[i]^2
|
||||||
|
end
|
||||||
|
|
||||||
|
xmin = x[1]
|
||||||
|
xmax = x[60]
|
||||||
|
ymin = y[1]
|
||||||
|
ymax = y[60]
|
||||||
|
|
||||||
|
for i = 1, 6 do
|
||||||
|
xs[i] = x[(i-1) * 10 + 4]
|
||||||
|
ys[i] = y[(i-1) * 10 + 4]
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up the viewport and window using PLENV. The range in X is
|
||||||
|
-- 0.0 to 6.0, and the range in Y is 0.0 to 30.0. The axes are
|
||||||
|
-- scaled separately (just = 0), and we just draw a labelled
|
||||||
|
-- box (axis = 0).
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("(x)", "(y)", "#frPLplot Example 1 - y=x#u2")
|
||||||
|
|
||||||
|
-- Plot the data points
|
||||||
|
pl.col0(4)
|
||||||
|
pl.poin(xs, ys, 9)
|
||||||
|
|
||||||
|
-- Draw the line through the data
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(x, y)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot2()
|
||||||
|
-- Set up the viewport and window using PLENV. The range in X is -2.0 to
|
||||||
|
-- 10.0, and the range in Y is -0.4 to 2.0. The axes are scaled separately
|
||||||
|
--(just = 0), and we draw a box with axes (axis = 1).
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(-2, 10, -0.4, 1.2, 0, 1)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("(x)", "sin(x)/x", "#frPLplot Example 1 - Sinc Function")
|
||||||
|
|
||||||
|
-- Fill up the arrays
|
||||||
|
for i=1, 100 do
|
||||||
|
x[i] = (i - 20) / 6
|
||||||
|
y[i] = 1
|
||||||
|
if x[i] ~= 0 then y[i] = math.sin(x[i])/x[i] end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw the line
|
||||||
|
pl.col0(3)
|
||||||
|
pl.wid(2)
|
||||||
|
pl.line(x, y)
|
||||||
|
pl.wid(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot3()
|
||||||
|
space0 = { }
|
||||||
|
mark0 = { }
|
||||||
|
space1 = { 1500 }
|
||||||
|
mark1 = { 1500 }
|
||||||
|
|
||||||
|
-- For the final graph we wish to override the default tick intervals, and
|
||||||
|
--so do not use plenv().
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Use standard viewport, and define X range from 0 to 360 degrees, Y range
|
||||||
|
--from -1.2 to 1.2.
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(0, 360, -1.2, 1.2)
|
||||||
|
|
||||||
|
-- Draw a box with ticks spaced 60 degrees apart in X, and 0.2 in Y.
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 60, 2, "bcnstv", 0.2, 2)
|
||||||
|
|
||||||
|
-- Superimpose a dashed line grid, with 1.5 mm marks and spaces.
|
||||||
|
-- plstyl expects a pointer!
|
||||||
|
pl.styl(mark1, space1)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box("g", 30, 0, "g", 0.2, 0)
|
||||||
|
pl.styl(mark0, space0)
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lab("Angle (degrees)", "sine", "#frPLplot Example 1 - Sine function")
|
||||||
|
|
||||||
|
for i=1, 101 do
|
||||||
|
x[i] = 3.6*(i-1)
|
||||||
|
y[i] = math.sin(x[i]*math.pi/180)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
pl.line(x, y)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Generates several simple line plots. Demonstrates:
|
||||||
|
-- - subwindow capability
|
||||||
|
-- - setting up the window, drawing plot, and labelling
|
||||||
|
-- - changing the color
|
||||||
|
-- - automatic axis rescaling to exponential notation
|
||||||
|
-- - placing the axes in the middle of the box
|
||||||
|
-- - gridded coordinate axes
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- plplot initialization
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Get version number, just for kicks
|
||||||
|
ver=pl.gver()
|
||||||
|
print("PLplot library version: " .. ver)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
-- Divide page into 2x2 plots
|
||||||
|
-- Note: calling plstar replaces separate calls to plssub and plinit
|
||||||
|
pl.star(2,2)
|
||||||
|
|
||||||
|
-- Select font set as per input flag
|
||||||
|
if fontset ~= 0 then
|
||||||
|
pl.fontld(1)
|
||||||
|
else
|
||||||
|
pl.fontld(0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up the data
|
||||||
|
-- Original case
|
||||||
|
xscale = 6
|
||||||
|
yscale = 1
|
||||||
|
xoff = 0
|
||||||
|
yoff = 0
|
||||||
|
|
||||||
|
-- Do a plot
|
||||||
|
plot1(0)
|
||||||
|
|
||||||
|
-- Set up the data
|
||||||
|
xscale = 1
|
||||||
|
yscale = 0.0014
|
||||||
|
yoff = 0.0185
|
||||||
|
|
||||||
|
-- Do a plot
|
||||||
|
digmax = 5
|
||||||
|
pl.syax(digmax, 0)
|
||||||
|
|
||||||
|
plot1(1)
|
||||||
|
plot2()
|
||||||
|
plot3()
|
||||||
|
|
||||||
|
-- Show how to save a plot:
|
||||||
|
-- Open a new device, make it current, copy parameters,
|
||||||
|
-- and replay the plot buffer
|
||||||
|
if f_name~="" then -- command line option '-save filename'
|
||||||
|
print("The current plot was saved in color Postscript under the name " .. f_name .. ".\n")
|
||||||
|
cur_strm = pl.gstrm() -- get current stream
|
||||||
|
new_strm = pl.mkstrm() -- create a new one
|
||||||
|
|
||||||
|
pl.sfnam(f_name) -- file name
|
||||||
|
pl.sdev("psc") -- device type
|
||||||
|
|
||||||
|
pl.cpstrm(cur_strm, 0) -- copy old stream parameters to new stream
|
||||||
|
pl.replot() -- do the save by replaying the plot buffer
|
||||||
|
pl.plend1() -- finish the device
|
||||||
|
|
||||||
|
pl.sstrm(cur_strm) -- return to previous stream
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Don't forget to call plend() to finish off!
|
||||||
|
pl.plend()
|
152
nanonote-example-files/files/lua-plplot-examples/x02.lua
Normal file
152
nanonote-example-files/files/lua-plplot-examples/x02.lua
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
--[[ $Id: x02.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Multiple window and color map 0 demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- draw_windows
|
||||||
|
--
|
||||||
|
-- Draws a set of numbered boxes with colors according to cmap0 entry.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function draw_windows(nw, cmap0_offset)
|
||||||
|
pl.schr(0, 3.5)
|
||||||
|
pl.font(4)
|
||||||
|
|
||||||
|
for i = 0, nw-1 do
|
||||||
|
pl.col0(i+cmap0_offset)
|
||||||
|
pl.adv(0)
|
||||||
|
vmin = 0.1
|
||||||
|
vmax = 0.9
|
||||||
|
for j = 0, 2 do
|
||||||
|
pl.wid(j + 1)
|
||||||
|
pl.vpor(vmin, vmax, vmin, vmax)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
pl.box("bc", 0, 0, "bc", 0, 0)
|
||||||
|
vmin = vmin + 0.1
|
||||||
|
vmax = vmax - 0.1
|
||||||
|
end
|
||||||
|
pl.wid(1)
|
||||||
|
pl.ptex(0.5, 0.5, 1, 0, 0.5, tostring(i))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- demo1
|
||||||
|
--
|
||||||
|
-- Demonstrates multipl.e windows and default color map 0 palette.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function demo1()
|
||||||
|
pl.bop()
|
||||||
|
|
||||||
|
-- Divide screen into 16 regions
|
||||||
|
pl.ssub(4, 4)
|
||||||
|
|
||||||
|
draw_windows(16, 0)
|
||||||
|
|
||||||
|
pl.eop()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- demo2
|
||||||
|
--
|
||||||
|
-- Demonstrates multipl.e windows, user-modified color map 0 palette, and
|
||||||
|
-- HLS -> RGB translation.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function demo2()
|
||||||
|
-- Set up cmap0
|
||||||
|
-- Use 100 custom colors in addition to base 16
|
||||||
|
r = {}
|
||||||
|
g = {}
|
||||||
|
b = {}
|
||||||
|
|
||||||
|
-- Min & max lightness values
|
||||||
|
lmin = 0.15
|
||||||
|
lmax = 0.85
|
||||||
|
|
||||||
|
pl.bop()
|
||||||
|
|
||||||
|
-- Divide screen into 100 regions
|
||||||
|
|
||||||
|
pl.ssub(10, 10)
|
||||||
|
|
||||||
|
for i = 0, 99 do
|
||||||
|
-- Bounds on HLS, from pl.hlsrgb() commentary --
|
||||||
|
-- hue [0., 360.] degrees
|
||||||
|
-- lightness [0., 1.] magnitude
|
||||||
|
-- saturation [0., 1.] magnitude
|
||||||
|
|
||||||
|
-- Vary hue uniformly from left to right
|
||||||
|
h = (360/10) * math.mod(i, 10)
|
||||||
|
|
||||||
|
-- Vary lightness uniformly from top to bottom, between min & max
|
||||||
|
l = lmin + (lmax - lmin) * math.floor(i/10)/9
|
||||||
|
|
||||||
|
-- Use max saturation
|
||||||
|
s = 1
|
||||||
|
|
||||||
|
r1, g1, b1 = pl.hlsrgb(h, l, s)
|
||||||
|
|
||||||
|
-- Use 255.001 to avoid close truncation decisions in this example.
|
||||||
|
r[i+1+16] = r1 * 255.001
|
||||||
|
g[i+1+16] = g1 * 255.001
|
||||||
|
b[i+1+16] = b1 * 255.001
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Load default cmap0 colors into our custom set
|
||||||
|
for i = 0, 15 do
|
||||||
|
r[i+1], g[i+1], b[i+1] = pl.gcol0(i)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Now set cmap0 all at once (faster, since fewer driver calls)
|
||||||
|
pl.scmap0(r, g, b)
|
||||||
|
|
||||||
|
draw_windows(100, 16)
|
||||||
|
|
||||||
|
pl.eop()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Demonstrates multipl.e windows and color map 0 palette, both default and
|
||||||
|
-- user-modified.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize pl.pl.ot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Run demos
|
||||||
|
demo1()
|
||||||
|
demo2()
|
||||||
|
|
||||||
|
pl.plend()
|
105
nanonote-example-files/files/lua-plplot-examples/x03.lua
Normal file
105
nanonote-example-files/files/lua-plplot-examples/x03.lua
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
--[[ $Id: x03.lua 10613 2009-11-19 12:05:09Z andrewross $
|
||||||
|
|
||||||
|
Polar plot demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Generates polar plot, with 1-1 scaling.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
x0 = {}
|
||||||
|
y0 = {}
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
dtr = math.pi/180
|
||||||
|
for i = 1, 361 do
|
||||||
|
x0[i] = math.cos(dtr * (i-1))
|
||||||
|
y0[i] = math.sin(dtr * (i-1))
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Set orientation to portrait - note not all device drivers
|
||||||
|
-- support this, in particular most interactive drivers do not
|
||||||
|
pl.sori(1)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Set up viewport and window, but do not draw box
|
||||||
|
pl.env(-1.3, 1.3, -1.3, 1.3, 1, -2)
|
||||||
|
|
||||||
|
-- Draw circles for polar grid
|
||||||
|
for i = 1, 10 do
|
||||||
|
pl.arc(0, 0, 0.1*i, 0.1*i, 0, 360, 0);
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
for i=1, 12 do
|
||||||
|
theta = 30 * (i-1)
|
||||||
|
dx = math.cos(dtr * theta)
|
||||||
|
dy = math.sin(dtr * theta)
|
||||||
|
|
||||||
|
-- Draw radial spokes for polar grid
|
||||||
|
|
||||||
|
pl.join(0, 0, dx, dy)
|
||||||
|
|
||||||
|
-- Write labels for angle
|
||||||
|
if theta < 9.99 then
|
||||||
|
offset = 0.45
|
||||||
|
else
|
||||||
|
if theta < 99.9 then
|
||||||
|
offset = 0.30
|
||||||
|
else
|
||||||
|
offset = 0.15
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Slightly off zero to avoid floating point logic flips at 90 and 270 deg.
|
||||||
|
if dx >= -0.00001 then
|
||||||
|
pl.ptex(dx, dy, dx, dy, -offset, tostring(math.floor(theta)))
|
||||||
|
else
|
||||||
|
pl.ptex(dx, dy, -dx, -dy, 1.+offset, tostring(math.floor(theta)))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw the graph
|
||||||
|
for i=1, 361 do
|
||||||
|
r = math.sin(dtr * (5*(i-1)))
|
||||||
|
x[i] = x0[i] * r
|
||||||
|
y[i] = y0[i] * r
|
||||||
|
end
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(x, y)
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
pl.mtex("t", 2, 0.5, 0.5, "#frPLplot Example 3 - r(#gh)=sin 5#gh")
|
||||||
|
|
||||||
|
-- Close the plot at end
|
||||||
|
pl.plend()
|
106
nanonote-example-files/files/lua-plplot-examples/x04.lua
Normal file
106
nanonote-example-files/files/lua-plplot-examples/x04.lua
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
--[[ $Id: x04.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Log plot demo.
|
||||||
|
Simple line plot and multiple windows demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- plot1
|
||||||
|
--
|
||||||
|
-- Log-linear plot.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function plot1(type)
|
||||||
|
freql = {}
|
||||||
|
ampl = {}
|
||||||
|
phase = {}
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Set up data for log plot
|
||||||
|
f0 = 1
|
||||||
|
for i=1, 101 do
|
||||||
|
freql[i] = -2 + (i-1) / 20
|
||||||
|
freq = 10^freql[i]
|
||||||
|
ampl[i] = 20 * math.log10(1 / math.sqrt(1 + (freq / f0)^2))
|
||||||
|
phase[i] = -(180 / math.pi) * math.atan(freq / f0)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.vpor(0.15, 0.85, 0.1, 0.9)
|
||||||
|
pl.wind(-2, 3, -80, 0)
|
||||||
|
|
||||||
|
-- Try different axis and labelling styles.
|
||||||
|
pl.col0(1)
|
||||||
|
if type == 0 then
|
||||||
|
pl.box("bclnst", 0, 0, "bnstv", 0, 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
if type == 1 then
|
||||||
|
pl.box("bcfghlnst", 0, 0, "bcghnstv", 0, 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Plot ampl vs freq
|
||||||
|
pl.col0(2)
|
||||||
|
pl.line(freql, ampl)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.ptex(1.6, -30, 1, -20, 0.5, "-20 dB/decade")
|
||||||
|
|
||||||
|
-- Put labels on
|
||||||
|
pl.col0(1)
|
||||||
|
pl.mtex("b", 3.2, 0.5, 0.5, "Frequency")
|
||||||
|
pl.mtex("t", 2, 0.5, 0.5, "Single Pole Low-Pass Filter")
|
||||||
|
pl.col0(2)
|
||||||
|
pl.mtex("l", 5, 0.5, 0.5, "Amplitude (dB)")
|
||||||
|
|
||||||
|
-- For the gridless case, put phase vs freq on same plot
|
||||||
|
if type == 0 then
|
||||||
|
pl.col0(1)
|
||||||
|
pl.wind(-2, 3, -100, 0)
|
||||||
|
pl.box("", 0, 0, "cmstv", 30, 3)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(freql, phase)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("r", 5, 0.5, 0.5, "Phase shift (degrees)")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Illustration of logarithmic axes, and redefinition of window.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
pl.font(2)
|
||||||
|
|
||||||
|
-- Make log plots using two different styles.
|
||||||
|
plot1(0)
|
||||||
|
plot1(1)
|
||||||
|
|
||||||
|
pl.plend()
|
54
nanonote-example-files/files/lua-plplot-examples/x05.lua
Normal file
54
nanonote-example-files/files/lua-plplot-examples/x05.lua
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
--[[ $Id: x05.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Histogram demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Draws a histogram from sample data.
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
NPTS=2047
|
||||||
|
data = {}
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL);
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Fill up data points
|
||||||
|
delta = 2.0*math.pi/NPTS
|
||||||
|
for i=1, NPTS do
|
||||||
|
data[i] = math.sin((i-1)*delta)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.hist(data, -1.1, 1.1, 44, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("#frValue", "#frFrequency",
|
||||||
|
"#frPLplot Example 5 - Probability function of Oscillator")
|
||||||
|
|
||||||
|
pl.plend()
|
90
nanonote-example-files/files/lua-plplot-examples/x06.lua
Normal file
90
nanonote-example-files/files/lua-plplot-examples/x06.lua
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
--[[ $Id: x06.lua 11032 2010-05-27 22:34:40Z andrewross $
|
||||||
|
|
||||||
|
Font demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Displays the entire "plpoin" symbol (font) set.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
for kind_font = 0,1 do
|
||||||
|
pl.fontld( kind_font )
|
||||||
|
if kind_font == 0 then
|
||||||
|
maxfont = 1
|
||||||
|
else
|
||||||
|
maxfont = 4
|
||||||
|
end
|
||||||
|
|
||||||
|
for font = 1,maxfont do
|
||||||
|
pl.font( font )
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Set up viewport and window
|
||||||
|
pl.col0(2)
|
||||||
|
pl.vpor(0.1, 1, 0.1, 0.9)
|
||||||
|
pl.wind(0, 1, 0, 1.3)
|
||||||
|
|
||||||
|
-- Draw the grid using plbox
|
||||||
|
pl.box("bcg", 0.1, 0, "bcg", 0.1, 0)
|
||||||
|
|
||||||
|
-- Write the digits below the frame
|
||||||
|
pl.col0(15)
|
||||||
|
for i=0, 9 do
|
||||||
|
pl.mtex("b", 1.5, (0.1 * i + 0.05), 0.5, tostring(i))
|
||||||
|
end
|
||||||
|
|
||||||
|
k = 0
|
||||||
|
x = {}
|
||||||
|
y ={}
|
||||||
|
for i = 0, 12 do
|
||||||
|
-- Write the digits to the left of the frame
|
||||||
|
pl.mtex("lv", 1, (1 - (2 * i + 1) / 26), 1, tostring(10*i))
|
||||||
|
for j = 0, 9 do
|
||||||
|
x[1] = 0.1 * j + 0.05
|
||||||
|
y[1] = 1.25 - 0.1 * i
|
||||||
|
|
||||||
|
-- Display the symbols
|
||||||
|
if k < 128 then
|
||||||
|
pl.poin(x, y, k)
|
||||||
|
end
|
||||||
|
k = k + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if kind_font == 0 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "PLplot Example 6 - plpoin symbols (compact)")
|
||||||
|
else
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "PLplot Example 6 - plpoin symbols (extended)")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
pl.plend()
|
90
nanonote-example-files/files/lua-plplot-examples/x07.lua
Normal file
90
nanonote-example-files/files/lua-plplot-examples/x07.lua
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
--[[ $Id: x07.lua 11032 2010-05-27 22:34:40Z andrewross $
|
||||||
|
|
||||||
|
Font demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
base = { 0, 100, 0, 100, 200, 500, 600, 700, 800, 900,
|
||||||
|
2000, 2100, 2200, 2300, 2400, 2500,
|
||||||
|
2600, 2700, 2800, 2900 }
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Displays the entire "plsym" symbol (font) set.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.fontld(0)
|
||||||
|
for l = 1, 20 do
|
||||||
|
|
||||||
|
if l == 3 then
|
||||||
|
pl.fontld(1)
|
||||||
|
end
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Set up viewport and window
|
||||||
|
pl.col0(2)
|
||||||
|
pl.vpor(0.15, 0.95, 0.1, 0.9)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
|
||||||
|
-- Draw the grid using plbox
|
||||||
|
|
||||||
|
pl.box("bcg", 0.1, 0, "bcg", 0.1, 0)
|
||||||
|
|
||||||
|
-- Write the digits below the frame
|
||||||
|
|
||||||
|
pl.col0(15)
|
||||||
|
for i = 0, 9 do
|
||||||
|
pl.mtex("b", 1.5, (0.1 * i + 0.05), 0.5, tostring(i))
|
||||||
|
end
|
||||||
|
|
||||||
|
k = 0
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
for i = 0, 9 do
|
||||||
|
-- Write the digits to the left of the frame
|
||||||
|
pl.mtex("lv", 1.0, (0.95 - 0.1 * i), 1.0, tostring(base[l] + 10 * i))
|
||||||
|
for j=0, 9 do
|
||||||
|
x[1] = 0.1 * j + 0.05
|
||||||
|
y[1] = 0.95 - 0.1 * i
|
||||||
|
|
||||||
|
-- Display the symbols
|
||||||
|
pl.sym(x, y, base[l] + k)
|
||||||
|
k = k + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if l <= 2 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "PLplot Example 7 - PLSYM symbols (compact)")
|
||||||
|
else
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "PLplot Example 7 - PLSYM symbols (extended)")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
189
nanonote-example-files/files/lua-plplot-examples/x08.lua
Normal file
189
nanonote-example-files/files/lua-plplot-examples/x08.lua
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
--[[ $Id: x08.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
3-d plot demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
|
||||||
|
-- bitwise or operator from http://lua-users.org/wiki/BaseSixtyFour
|
||||||
|
-- (c) 2006-2008 by Alex Kloss
|
||||||
|
-- licensed under the terms of the LGPL2
|
||||||
|
|
||||||
|
-- return single bit (for OR)
|
||||||
|
function bit(x,b)
|
||||||
|
return (math.mod(x, 2^b) - math.mod(x,2^(b-1)) > 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- logic OR for number values
|
||||||
|
function lor(x,y)
|
||||||
|
result = 0
|
||||||
|
for p=1,8 do result = result + (((bit(x,p) or bit(y,p)) == true) and 2^(p-1) or 0) end
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- cmap1_init1
|
||||||
|
--
|
||||||
|
-- Initializes color map 1 in HLS space.
|
||||||
|
-- Basic grayscale variation from half-dark (which makes more interesting
|
||||||
|
-- looking plot compared to dark) to light.
|
||||||
|
-- An interesting variation on this:
|
||||||
|
-- s[1] = 1.0
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function cmap1_init(gray)
|
||||||
|
i = { 0, 1 } -- left and right boundary
|
||||||
|
|
||||||
|
if gray ~= 0 then
|
||||||
|
h = { 0, 0 } -- hue -- low: red (arbitrary if s=0), high: red (arbitrary if s=0)
|
||||||
|
l = { 0.5, 1 } -- lightness -- low: half-dark, high: light
|
||||||
|
s = { 0, 0 } -- minimum saturation
|
||||||
|
else
|
||||||
|
h = { 240, 0 } -- blue -> green -> yellow -> red
|
||||||
|
l = { 0.6, 0.6 }
|
||||||
|
s = { 0.8, 0.8 }
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.scmap1n(256)
|
||||||
|
pl.scmap1l(0, i, h, l, s)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a series of 3-d plots for a given data set, with different
|
||||||
|
-- viewing options in each plot.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
XPTS = 35 -- Data points in x
|
||||||
|
YPTS = 46 -- Data points in y
|
||||||
|
LEVELS = 10
|
||||||
|
|
||||||
|
alt = { 60, 20 }
|
||||||
|
az = { 30, 60 }
|
||||||
|
|
||||||
|
title = {
|
||||||
|
"#frPLplot Example 8 - Alt=60, Az=30",
|
||||||
|
"#frPLplot Example 8 - Alt=20, Az=60"
|
||||||
|
}
|
||||||
|
|
||||||
|
clevel = {}
|
||||||
|
nlevel = LEVELS
|
||||||
|
rosen = 1
|
||||||
|
sombrero = 0
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
if sombrero ~= 0 then rosen=0 end
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Allocate data structures
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
for i=1, XPTS do
|
||||||
|
x[i] = (i-1-math.floor(XPTS/2)) / math.floor(XPTS/2)
|
||||||
|
if rosen~=0 then x[i]=x[i]*1.5 end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1, YPTS do
|
||||||
|
y[i] = (i-1-math.floor(YPTS/2)) / math.floor(YPTS/2)
|
||||||
|
if rosen~=0 then y[i]=y[i]+0.5 end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1, XPTS do
|
||||||
|
xx = x[i]
|
||||||
|
z[i]= {}
|
||||||
|
for j=1, YPTS do
|
||||||
|
yy = y[j]
|
||||||
|
if rosen~=0 then
|
||||||
|
z[i][j] = (1-xx)^2 + 100*(yy-xx^2)^2
|
||||||
|
-- The log argument may be zero for just the right grid.
|
||||||
|
if z[i][j] > 0 then
|
||||||
|
z[i][j] = math.log(z[i][j])
|
||||||
|
else
|
||||||
|
z[i][j] = -5 -- MAXFLOAT would mess-up up the scale
|
||||||
|
end
|
||||||
|
else
|
||||||
|
r = math.sqrt(xx^2 + yy^2)
|
||||||
|
z[i][j] = math.exp(-r^2) * math.cos(2*math.pi*r)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
zmax, zmin = pl.MinMax2dGrid(z)
|
||||||
|
step = (zmax-zmin)/(nlevel+1)
|
||||||
|
for i=1, nlevel do
|
||||||
|
clevel[i] = zmin + step + step*(i-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.lightsource(1, 1, 1)
|
||||||
|
|
||||||
|
for k=1, 2 do
|
||||||
|
for ifshade = 1, 4 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 0.9)
|
||||||
|
pl.wind(-1, 1, -0.9, 1.1)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("t", 1, 0.5, 0.5, title[k])
|
||||||
|
pl.col0(1)
|
||||||
|
if rosen~=0 then
|
||||||
|
pl.w3d(1, 1, 1, -1.5, 1.5, -0.5, 1.5, zmin, zmax, alt[k], az[k])
|
||||||
|
else
|
||||||
|
pl.w3d(1, 1, 1, -1, 1, -1, 1, zmin, zmax, alt[k], az[k])
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.box3("bnstu", "x axis", 0, 0,
|
||||||
|
"bnstu", "y axis", 0, 0,
|
||||||
|
"bcdmnstuv", "z axis", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
if ifshade==1 then -- diffuse light surface plot
|
||||||
|
cmap1_init(1)
|
||||||
|
pl.surf3d(x, y, z, 0, clevel)
|
||||||
|
end
|
||||||
|
|
||||||
|
if ifshade==2 then -- magnitude colored plot
|
||||||
|
cmap1_init(0)
|
||||||
|
pl.surf3d(x, y, z, pl.MAG_COLOR, {})
|
||||||
|
end
|
||||||
|
|
||||||
|
if ifshade==3 then -- magnitude colored plot with faceted squares
|
||||||
|
cmap1_init(0)
|
||||||
|
pl.surf3d(x, y, z, lor(pl.MAG_COLOR, pl.FACETED), {})
|
||||||
|
end
|
||||||
|
|
||||||
|
if ifshade==4 then -- magnitude colored plot with contours
|
||||||
|
cmap1_init(0)
|
||||||
|
pl.surf3d(x, y, z, lor(lor(pl.MAG_COLOR, pl.SURF_CONT), pl.BASE_CONT), clevel)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Clean up
|
||||||
|
pl.plend()
|
350
nanonote-example-files/files/lua-plplot-examples/x09.lua
Normal file
350
nanonote-example-files/files/lua-plplot-examples/x09.lua
Normal file
@ -0,0 +1,350 @@
|
|||||||
|
--[[ $Id: x09.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Contour plot demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
XPTS = 35 -- Data points in x
|
||||||
|
YPTS = 46 -- Data points in y
|
||||||
|
|
||||||
|
XSPA = 2/(XPTS-1)
|
||||||
|
YSPA = 2/(YPTS-1)
|
||||||
|
|
||||||
|
-- polar plot data
|
||||||
|
PERIMETERPTS = 100
|
||||||
|
RPTS = 40
|
||||||
|
THETAPTS = 40
|
||||||
|
|
||||||
|
-- potential plot data
|
||||||
|
PPERIMETERPTS = 100
|
||||||
|
PRPTS = 40
|
||||||
|
PTHETAPTS = 64
|
||||||
|
PNLEVEL = 20
|
||||||
|
|
||||||
|
clevel = { -1, -0.8, -0.6, -0.4, -0.2, 0, 0.2, 0.4, 0.6, 0.8, 1}
|
||||||
|
|
||||||
|
-- Transformation function
|
||||||
|
tr = { XSPA, 0, -1, 0, YSPA, -1 }
|
||||||
|
|
||||||
|
function mypltr(x, y)
|
||||||
|
tx = tr[1] * x + tr[2] * y + tr[3]
|
||||||
|
ty = tr[4] * x + tr[5] * y + tr[6]
|
||||||
|
|
||||||
|
return tx, ty
|
||||||
|
end
|
||||||
|
|
||||||
|
--polar contour plot example.
|
||||||
|
function polar()
|
||||||
|
px = {}
|
||||||
|
py = {}
|
||||||
|
lev = {}
|
||||||
|
|
||||||
|
pl.env(-1, 1, -1, 1, 0, -2)
|
||||||
|
pl.col0(1)
|
||||||
|
|
||||||
|
--Perimeter
|
||||||
|
for i=1, PERIMETERPTS do
|
||||||
|
t = (2*math.pi/(PERIMETERPTS-1))*(i-1)
|
||||||
|
px[i] = math.cos(t)
|
||||||
|
py[i] = math.sin(t)
|
||||||
|
end
|
||||||
|
pl.line(px, py)
|
||||||
|
|
||||||
|
--create data to be contoured.
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = RPTS
|
||||||
|
cgrid2["ny"] = THETAPTS
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
for i = 1, RPTS do
|
||||||
|
r = (i-1)/(RPTS-1)
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
z[i] = {}
|
||||||
|
for j = 1, THETAPTS do
|
||||||
|
theta = (2*math.pi/(THETAPTS-1))*(j-1)
|
||||||
|
cgrid2["xg"][i][j] = r*math.cos(theta)
|
||||||
|
cgrid2["yg"][i][j] = r*math.sin(theta)
|
||||||
|
z[i][j] = r
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 10 do
|
||||||
|
lev[i] = 0.05 + 0.10*(i-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(z, 1, RPTS, 1, THETAPTS, lev, "pltr2", cgrid2)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.lab("", "", "Polar Contour Plot")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- f2mnmx
|
||||||
|
--
|
||||||
|
-- Returns min & max of input 2d array.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
function f2mnmx(f, nx, ny)
|
||||||
|
fmax = f[1][1]
|
||||||
|
fmin = fmax
|
||||||
|
|
||||||
|
for i=1, nx do
|
||||||
|
for j=1, ny do
|
||||||
|
fmax = math.max(fmax, f[i][j])
|
||||||
|
fmin = math.min(fmin, f[i][j])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return fmin, fmax
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--shielded potential contour plot example.
|
||||||
|
function potential()
|
||||||
|
clevelneg = {}
|
||||||
|
clevelpos = {}
|
||||||
|
px = {}
|
||||||
|
py = {}
|
||||||
|
|
||||||
|
--create data to be contoured.
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = PRPTS
|
||||||
|
cgrid2["ny"] = PTHETAPTS
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
for i = 1, PRPTS do
|
||||||
|
r = 0.5 + (i-1)
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
for j = 1, PTHETAPTS do
|
||||||
|
theta = 2*math.pi/(PTHETAPTS-1)*(j-0.5)
|
||||||
|
cgrid2["xg"][i][j] = r*math.cos(theta)
|
||||||
|
cgrid2["yg"][i][j] = r*math.sin(theta)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
rmax = PRPTS-0.5
|
||||||
|
xmin, xmax = f2mnmx(cgrid2["xg"], PRPTS, PTHETAPTS)
|
||||||
|
ymin, ymax = f2mnmx(cgrid2["yg"], PRPTS, PTHETAPTS)
|
||||||
|
x0 = (xmin + xmax)/2
|
||||||
|
y0 = (ymin + ymax)/2
|
||||||
|
|
||||||
|
-- Expanded limits
|
||||||
|
peps = 0.05
|
||||||
|
xpmin = xmin - math.abs(xmin)*peps
|
||||||
|
xpmax = xmax + math.abs(xmax)*peps
|
||||||
|
ypmin = ymin - math.abs(ymin)*peps
|
||||||
|
ypmax = ymax + math.abs(ymax)*peps
|
||||||
|
|
||||||
|
-- Potential inside a conducting cylinder (or sphere) by method of images.
|
||||||
|
-- Charge 1 is placed at (d1, d1), with image charge at (d2, d2).
|
||||||
|
-- Charge 2 is placed at (d1, -d1), with image charge at (d2, -d2).
|
||||||
|
-- Also put in smoothing term at small distances.
|
||||||
|
eps = 2
|
||||||
|
q1 = 1
|
||||||
|
d1 = rmax/4
|
||||||
|
|
||||||
|
q1i = - q1*rmax/d1
|
||||||
|
d1i = rmax^2/d1
|
||||||
|
|
||||||
|
q2 = -1
|
||||||
|
d2 = rmax/4
|
||||||
|
|
||||||
|
q2i = - q2*rmax/d2
|
||||||
|
d2i = rmax^2/d2
|
||||||
|
|
||||||
|
for i = 1, PRPTS do
|
||||||
|
z[i] = {}
|
||||||
|
for j = 1, PTHETAPTS do
|
||||||
|
div1 = math.sqrt((cgrid2.xg[i][j]-d1)^2 + (cgrid2.yg[i][j]-d1)^2 + eps^2)
|
||||||
|
div1i = math.sqrt((cgrid2.xg[i][j]-d1i)^2 + (cgrid2.yg[i][j]-d1i)^2 + eps^2)
|
||||||
|
div2 = math.sqrt((cgrid2.xg[i][j]-d2)^2 + (cgrid2.yg[i][j]+d2)^2 + eps^2)
|
||||||
|
div2i = math.sqrt((cgrid2.xg[i][j]-d2i)^2 + (cgrid2.yg[i][j]+d2i)^2 + eps^2)
|
||||||
|
z[i][j] = q1/div1 + q1i/div1i + q2/div2 + q2i/div2i
|
||||||
|
end
|
||||||
|
end
|
||||||
|
zmin, zmax = f2mnmx(z, PRPTS, PTHETAPTS)
|
||||||
|
|
||||||
|
-- Positive and negative contour levels.
|
||||||
|
dz = (zmax-zmin)/PNLEVEL
|
||||||
|
nlevelneg = 1
|
||||||
|
nlevelpos = 1
|
||||||
|
for i = 1, PNLEVEL do
|
||||||
|
clevel = zmin + (i-0.5)*dz
|
||||||
|
if clevel <= 0 then
|
||||||
|
clevelneg[nlevelneg] = clevel
|
||||||
|
nlevelneg = nlevelneg + 1
|
||||||
|
else
|
||||||
|
clevelpos[nlevelpos] = clevel
|
||||||
|
nlevelpos = nlevelpos + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Colours!
|
||||||
|
ncollin = 11
|
||||||
|
ncolbox = 1
|
||||||
|
ncollab = 2
|
||||||
|
|
||||||
|
-- Finally start plotting this page!
|
||||||
|
pl.adv(0)
|
||||||
|
pl.col0(ncolbox)
|
||||||
|
|
||||||
|
pl.vpas(0.1, 0.9, 0.1, 0.9, 1)
|
||||||
|
pl.wind(xpmin, xpmax, ypmin, ypmax)
|
||||||
|
pl.box("", 0, 0, "", 0, 0)
|
||||||
|
|
||||||
|
pl.col0(ncollin)
|
||||||
|
if nlevelneg>1 then
|
||||||
|
-- Negative contours
|
||||||
|
pl.lsty(2)
|
||||||
|
pl.cont(z, 1, PRPTS, 1, PTHETAPTS, clevelneg, "pltr2", cgrid2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if nlevelpos>1 then
|
||||||
|
-- Positive contours
|
||||||
|
pl.lsty(1)
|
||||||
|
pl.cont(z, 1, PRPTS, 1, PTHETAPTS, clevelpos, "pltr2", cgrid2)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw outer boundary
|
||||||
|
for i = 1, PPERIMETERPTS do
|
||||||
|
t = (2*math.pi/(PPERIMETERPTS-1))*(i-1)
|
||||||
|
px[i] = x0 + rmax*math.cos(t)
|
||||||
|
py[i] = y0 + rmax*math.sin(t)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(ncolbox)
|
||||||
|
pl.line(px, py)
|
||||||
|
|
||||||
|
pl.col0(ncollab)
|
||||||
|
pl.lab("", "", "Shielded potential of charges in a conducting sphere")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does several contour plots using different coordinate mappings.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
mark = { 1500 }
|
||||||
|
space = { 1500 }
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Set up function arrays
|
||||||
|
z = {}
|
||||||
|
w = {}
|
||||||
|
|
||||||
|
for i = 1, XPTS do
|
||||||
|
xx = (i-1 - math.floor(XPTS/2)) / math.floor(XPTS/2)
|
||||||
|
z[i] = {}
|
||||||
|
w[i] = {}
|
||||||
|
for j = 1, YPTS do
|
||||||
|
yy = (j-1 - math.floor(YPTS/2)) / math.floor(YPTS/2) - 1
|
||||||
|
z[i][j] = xx^2 - yy^2
|
||||||
|
w[i][j] = 2 * xx * yy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up grids
|
||||||
|
cgrid1 = {}
|
||||||
|
cgrid1["xg"] = {}
|
||||||
|
cgrid1["yg"] = {}
|
||||||
|
cgrid1["nx"] = XPTS
|
||||||
|
cgrid1["ny"] = YPTS
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = XPTS
|
||||||
|
cgrid2["ny"] = YPTS
|
||||||
|
|
||||||
|
for i = 1, XPTS do
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
for j = 1, YPTS do
|
||||||
|
xx, yy = mypltr(i-1, j-1)
|
||||||
|
|
||||||
|
argx = xx * math.pi/2
|
||||||
|
argy = yy * math.pi/2
|
||||||
|
distort = 0.4
|
||||||
|
|
||||||
|
cgrid1["xg"][i] = xx + distort * math.cos(argx)
|
||||||
|
cgrid1["yg"][j] = yy - distort * math.cos(argy)
|
||||||
|
|
||||||
|
cgrid2["xg"][i][j] = xx + distort * math.cos(argx) * math.cos(argy)
|
||||||
|
cgrid2["yg"][i][j] = yy - distort * math.cos(argx) * math.cos(argy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Plot using identity transform
|
||||||
|
pl.setcontlabelformat(4, 3)
|
||||||
|
pl.setcontlabelparam(0.006, 0.3, 0.1, 1)
|
||||||
|
pl.env(-1, 1, -1, 1, 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(z, 1, XPTS, 1, YPTS, clevel, "mypltr")
|
||||||
|
pl.styl(mark, space)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.cont(w, 1, XPTS, 1, YPTS, clevel, "mypltr")
|
||||||
|
pl.styl({}, {})
|
||||||
|
pl.col0(1)
|
||||||
|
pl.lab("X Coordinate", "Y Coordinate", "Streamlines of flow")
|
||||||
|
pl.setcontlabelparam(0.006, 0.3, 0.1, 0)
|
||||||
|
|
||||||
|
-- Plot using 1d coordinate transform
|
||||||
|
pl.env(-1, 1, -1, 1, 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(z, 1, XPTS, 1, YPTS, clevel, "pltr1", cgrid1)
|
||||||
|
pl.styl(mark, space)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.cont(w, 1, XPTS, 1, YPTS, clevel, "pltr1", cgrid1)
|
||||||
|
pl.styl({}, {})
|
||||||
|
pl.col0(1)
|
||||||
|
pl.lab("X Coordinate", "Y Coordinate", "Streamlines of flow")
|
||||||
|
|
||||||
|
-- Plot using 2d coordinate transform
|
||||||
|
pl.env(-1, 1, -1, 1, 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(z, 1, XPTS, 1, YPTS, clevel, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
pl.styl(mark, space)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.cont(w, 1, XPTS, 1, YPTS, clevel, "pltr2", cgrid2)
|
||||||
|
pl.styl({}, {})
|
||||||
|
pl.col0(1)
|
||||||
|
pl.lab("X Coordinate", "Y Coordinate", "Streamlines of flow")
|
||||||
|
|
||||||
|
pl.setcontlabelparam(0.006, 0.3, 0.1, 0)
|
||||||
|
polar()
|
||||||
|
|
||||||
|
pl.setcontlabelparam(0.006, 0.3, 0.1, 0)
|
||||||
|
potential()
|
||||||
|
|
||||||
|
-- Clean up
|
||||||
|
pl.plend()
|
49
nanonote-example-files/files/lua-plplot-examples/x10.lua
Normal file
49
nanonote-example-files/files/lua-plplot-examples/x10.lua
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
--[[ $Id: x10.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Window positioning demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Demonstrates absolute positioning of graphs on a page.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL);
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.0, 1.0, 0.0, 1.0)
|
||||||
|
pl.wind(0.0, 1.0, 0.0, 1.0)
|
||||||
|
pl.box("bc", 0.0, 0, "bc", 0.0, 0)
|
||||||
|
|
||||||
|
pl.svpa(50.0, 150.0, 50.0, 100.0)
|
||||||
|
pl.wind(0.0, 1.0, 0.0, 1.0)
|
||||||
|
pl.box("bc", 0.0, 0, "bc", 0.0, 0)
|
||||||
|
pl.ptex(0.5, 0.5, 1.0, 0.0, 0.5, "BOX at (50,150,50,100)")
|
||||||
|
pl.plend()
|
160
nanonote-example-files/files/lua-plplot-examples/x11.lua
Normal file
160
nanonote-example-files/files/lua-plplot-examples/x11.lua
Normal file
@ -0,0 +1,160 @@
|
|||||||
|
--[[ $Id: x11.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Mesh plot demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
XPTS = 35 -- Data points in x
|
||||||
|
YPTS = 46 -- Data points in y
|
||||||
|
LEVELS = 10
|
||||||
|
|
||||||
|
opt = { pl.DRAW_LINEXY, pl.DRAW_LINEXY }
|
||||||
|
|
||||||
|
alt = { 33, 17 }
|
||||||
|
az = { 24, 115 }
|
||||||
|
|
||||||
|
title = {
|
||||||
|
"#frPLplot Example 11 - Alt=33, Az=24, Opt=3",
|
||||||
|
"#frPLplot Example 11 - Alt=17, Az=115, Opt=3" }
|
||||||
|
|
||||||
|
|
||||||
|
-- bitwise or operator from http://lua-users.org/wiki/BaseSixtyFour
|
||||||
|
-- (c) 2006-2008 by Alex Kloss
|
||||||
|
-- licensed under the terms of the LGPL2
|
||||||
|
|
||||||
|
-- return single bit (for OR)
|
||||||
|
function bit(x,b)
|
||||||
|
return (math.mod(x, 2^b) - math.mod(x,2^(b-1)) > 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- logic OR for number values
|
||||||
|
function lor(x,y)
|
||||||
|
result = 0
|
||||||
|
for p=1,8 do result = result + (((bit(x,p) or bit(y,p)) == true) and 2^(p-1) or 0) end
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function cmap1_init()
|
||||||
|
i = { 0, 1 } -- left boundary , right boundary
|
||||||
|
h = { 240, 0 } -- blue -> green -> yellow -> red
|
||||||
|
l = { 0.6, 0.6 }
|
||||||
|
s = { 0.8, 0.8 }
|
||||||
|
|
||||||
|
pl.scmap1n(256)
|
||||||
|
pl.scmap1l(0, i, h, l, s)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a series of mesh plots for a given data set, with different
|
||||||
|
-- viewing options in each plot.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
nlevel = LEVELS
|
||||||
|
clevel = {}
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
for i=1, XPTS do
|
||||||
|
x[i] = 3 * (i-1-math.floor(XPTS/2)) / math.floor(XPTS/2)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1, YPTS do
|
||||||
|
y[i] = 3 * (i-1-math.floor(YPTS/2)) / math.floor(YPTS/2)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1, XPTS do
|
||||||
|
xx = x[i]
|
||||||
|
z[i] = {}
|
||||||
|
for j=1, YPTS do
|
||||||
|
yy = y[j]
|
||||||
|
z[i][j] = 3 * (1-xx)^2 * math.exp(-xx^2 - (yy+1.)^2) -
|
||||||
|
10 * (xx/5 - xx^3 - yy^5) * math.exp(-xx^2-yy^2) -
|
||||||
|
1/3 * math.exp(-(xx+1)^2 - yy^2)
|
||||||
|
|
||||||
|
-- Jungfraujoch/Interlaken
|
||||||
|
if false then
|
||||||
|
if z[i][j] < -1 then z[i][j] = -1 end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
zmax, zmin = pl.MinMax2dGrid(z)
|
||||||
|
step = (zmax - zmin)/(nlevel+1)
|
||||||
|
for i=1, nlevel do
|
||||||
|
clevel[i] = zmin + step + step*(i-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
cmap1_init()
|
||||||
|
for k=1, 2 do
|
||||||
|
for i=1, 4 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.vpor(0, 1, 0, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1.5)
|
||||||
|
pl.w3d(1, 1, 1.2, -3, 3, -3, 3, zmin, zmax, alt[k], az[k])
|
||||||
|
pl.box3("bnstu", "x axis", 0, 0,
|
||||||
|
"bnstu", "y axis", 0, 0,
|
||||||
|
"bcdmnstuv", "z axis", 0, 4)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
-- wireframe plot
|
||||||
|
if i==1 then
|
||||||
|
pl.mesh(x, y, z, opt[k])
|
||||||
|
end
|
||||||
|
|
||||||
|
-- magnitude colored wireframe plot
|
||||||
|
if i==2 then
|
||||||
|
pl.mesh(x, y, z, lor(opt[k], pl.MAG_COLOR))
|
||||||
|
end
|
||||||
|
|
||||||
|
-- magnitude colored wireframe plot with sides
|
||||||
|
if i==3 then
|
||||||
|
pl.plot3d(x, y, z, lor(opt[k], pl.MAG_COLOR), 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- magnitude colored wireframe plot with base contour
|
||||||
|
if i==4 then
|
||||||
|
pl.meshc(x, y, z, lor(lor(opt[k], pl.MAG_COLOR), pl.BASE_CONT), clevel)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("t", 1, 0.5, 0.5, title[k])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Clean up
|
||||||
|
|
||||||
|
pl.plend()
|
78
nanonote-example-files/files/lua-plplot-examples/x12.lua
Normal file
78
nanonote-example-files/files/lua-plplot-examples/x12.lua
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
--[[ $Id: x12.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Bar chart demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
function pl.fbox(x0, y0)
|
||||||
|
x = { x0, x0, x0+1,x0+1 }
|
||||||
|
y = { 0, y0, y0, 0 }
|
||||||
|
|
||||||
|
pl.fill(x, y);
|
||||||
|
pl.col0(1);
|
||||||
|
pl.lsty(1);
|
||||||
|
pl.line(x, y);
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a simple bar chart, using color fill. If color fill is
|
||||||
|
-- unavailable, pattern fill is used instead (automatic).
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
y0 = {}
|
||||||
|
|
||||||
|
pos = { 0, 0.25, 0.5, 0.75, 1 }
|
||||||
|
red = { 0, 0.25, 0.5, 1, 1 }
|
||||||
|
green = { 1, 0.5, 0.5, 0.5, 1 }
|
||||||
|
blue = { 1, 1, 0.5, 0.25, 0 }
|
||||||
|
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL);
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(1980, 1990, 0, 35)
|
||||||
|
pl.box("bc", 1, 0, "bcnv", 10, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("Year", "Widget Sales (millions)", "#frPLplot Example 12")
|
||||||
|
|
||||||
|
y0 = { 5, 15, 12, 24, 28, 30, 20, 8, 12, 3}
|
||||||
|
|
||||||
|
pl.scmap1l(1, pos, red, green, blue);
|
||||||
|
|
||||||
|
for i=1, 10 do
|
||||||
|
pl.col1((i-1)/9.0);
|
||||||
|
pl.psty(0);
|
||||||
|
pl.fbox((1980+i-1), y0[i]);
|
||||||
|
pl.ptex((1980+i-0.5), (y0[i]+1), 1, 0, 0.5, tostring(y0[i]));
|
||||||
|
pl.mtex("b", 1, (i*0.1-0.05), 0.5, tostring(1980+i-1));
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend();
|
96
nanonote-example-files/files/lua-plplot-examples/x13.lua
Normal file
96
nanonote-example-files/files/lua-plplot-examples/x13.lua
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
--[[ $Id: x13.lua 9526 2009-02-13 22:06:13Z smekal $
|
||||||
|
|
||||||
|
Pie chart demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
text = { "Maurice", "Geoffrey", "Alan",
|
||||||
|
"Rafael", "Vince" }
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a simple pie chart.
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
per = { 10, 32, 12, 30, 16 }
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL);
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Ensure window has aspect ratio of one so circle is
|
||||||
|
-- plotted as a circle.
|
||||||
|
pl.vasp(1)
|
||||||
|
pl.wind(0, 10, 0, 10)
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
-- n.b. all theta quantities scaled by 2*M_PI/500 to be integers to avoid
|
||||||
|
--floating point logic problems.
|
||||||
|
theta0 = 0
|
||||||
|
dthet = 1
|
||||||
|
for i = 1, 5 do
|
||||||
|
x = { 5 }
|
||||||
|
y = { 5 }
|
||||||
|
j = 2
|
||||||
|
-- n.b. the theta quantities multiplied by 2*math.pi/500 afterward so
|
||||||
|
-- in fact per is interpreted as a percentage.
|
||||||
|
theta1 = theta0 + 5 * per[i]
|
||||||
|
if i == 5 then theta1 = 500 end
|
||||||
|
|
||||||
|
for theta = theta0, theta1, dthet do
|
||||||
|
x[j] = 5 + 3 * math.cos(2*math.pi/500*theta)
|
||||||
|
y[j] = 5 + 3 * math.sin(2*math.pi/500*theta)
|
||||||
|
j = j + 1
|
||||||
|
thetasave=theta
|
||||||
|
end
|
||||||
|
pl.col0(i)
|
||||||
|
pl.psty(math.mod((i + 2), 8) + 1)
|
||||||
|
pl.fill(x, y)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.line(x, y)
|
||||||
|
just = 2*math.pi/500*(theta0 + theta1)/2
|
||||||
|
dx = 0.25 * math.cos(just)
|
||||||
|
dy = 0.25 * math.sin(just)
|
||||||
|
if (theta0 + theta1)<250 or (theta0 + theta1)>750 then
|
||||||
|
just = 0
|
||||||
|
else
|
||||||
|
just = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.ptex((x[(j-1)/2+1] + dx), (y[(j-1)/2+1] + dy), 1, 0, just, text[i]);
|
||||||
|
theta0 = thetasave
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.font(2)
|
||||||
|
pl.schr(0, 1.3)
|
||||||
|
pl.ptex(5, 9, 1, 0, 0.5, "Percentage of Sales")
|
||||||
|
|
||||||
|
pl.plend()
|
||||||
|
|
361
nanonote-example-files/files/lua-plplot-examples/x14.lua
Normal file
361
nanonote-example-files/files/lua-plplot-examples/x14.lua
Normal file
@ -0,0 +1,361 @@
|
|||||||
|
--[[ $Id: x14.lua 10793 2010-02-06 01:48:39Z hbabcock $
|
||||||
|
|
||||||
|
Demo of multiple stream/window capability (requires Tk or Tcl-DP).
|
||||||
|
|
||||||
|
Maurice LeBrun
|
||||||
|
IFS, University of Texas at Austin
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
xs = {}
|
||||||
|
ys = {}
|
||||||
|
space0 = {}
|
||||||
|
mark0 = {}
|
||||||
|
space1 = { 1500 }
|
||||||
|
mark1 = { 1500 }
|
||||||
|
|
||||||
|
|
||||||
|
function plot1()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
for i = 1, 60 do
|
||||||
|
x[i] = xoff + xscale*i/60
|
||||||
|
y[i] = yoff + yscale*x[i]^2
|
||||||
|
end
|
||||||
|
|
||||||
|
xmin = x[1]
|
||||||
|
xmax = x[60]
|
||||||
|
ymin = y[1]
|
||||||
|
ymax = y[60]
|
||||||
|
|
||||||
|
for i = 1, 6 do
|
||||||
|
xs[i] = x[(i-1)*10 + 4]
|
||||||
|
ys[i] = y[(i-1)*10 + 4]
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up the viewport and window using PLENV. The range in X is
|
||||||
|
-- 0.0 to 6.0, and the range in Y is 0.0 to 30.0. The axes are
|
||||||
|
-- scaled separately (just = 0), and we just draw a labelled
|
||||||
|
-- box (axis = 0).
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 0)
|
||||||
|
pl.col0(6)
|
||||||
|
pl.lab("(x)", "(y)", "#frPLplot Example 1 - y=x#u2")
|
||||||
|
|
||||||
|
-- Plot the data points
|
||||||
|
pl.col0(9)
|
||||||
|
pl.poin(xs, ys, 9)
|
||||||
|
|
||||||
|
-- Draw the line through the data
|
||||||
|
pl.col0(4)
|
||||||
|
pl.line(x, y)
|
||||||
|
pl.flush()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot2()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
-- Set up the viewport and window using PLENV. The range in X is -2.0 to
|
||||||
|
-- 10.0, and the range in Y is -0.4 to 2.0. The axes are scaled separately
|
||||||
|
-- (just = 0), and we draw a box with axes (axis = 1).
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(-2, 10, -0.4, 1.2, 0, 1)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("(x)", "sin(x)/x", "#frPLplot Example 1 - Sinc Function")
|
||||||
|
|
||||||
|
-- Fill up the arrays
|
||||||
|
for i = 1, 100 do
|
||||||
|
x[i] = (i-20)/6
|
||||||
|
y[i] = 1
|
||||||
|
if x[i]~=0 then
|
||||||
|
y[i] = math.sin(x[i])/x[i]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw the line
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(x, y)
|
||||||
|
pl.flush()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot3()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
-- For the final graph we wish to override the default tick intervals, and
|
||||||
|
-- so do not use PLENV
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Use standard viewport, and define X range from 0 to 360 degrees, Y range
|
||||||
|
-- from -1.2 to 1.2.
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(0, 360, -1.2, 1.2)
|
||||||
|
|
||||||
|
-- Draw a box with ticks spaced 60 degrees apart in X, and 0.2 in Y.
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 60, 2, "bcnstv", 0.2, 2)
|
||||||
|
|
||||||
|
-- Superimpose a dashed line grid, with 1.5 mm marks and spaces. plstyl
|
||||||
|
-- expects a pointer!!
|
||||||
|
pl.styl(mark1, space1)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box("g", 30, 0, "g", 0.2, 0)
|
||||||
|
pl.styl(mark0, space0)
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lab("Angle (degrees)", "sine", "#frPLplot Example 1 - Sine function")
|
||||||
|
|
||||||
|
for i = 1, 101 do
|
||||||
|
x[i] = 3.6 * (i-1)
|
||||||
|
y[i] = math.sin(x[i]*math.pi/180)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
pl.line(x, y)
|
||||||
|
pl.flush()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot4()
|
||||||
|
x0 = {}
|
||||||
|
y0 = {}
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
dtr = math.pi/180
|
||||||
|
for i = 1, 361 do
|
||||||
|
x0[i] = math.cos(dtr*(i-1))
|
||||||
|
y0[i] = math.sin(dtr*(i-1))
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up viewport and window, but do not draw box
|
||||||
|
pl.env(-1.3, 1.3, -1.3, 1.3, 1, -2)
|
||||||
|
for i = 1, 10 do
|
||||||
|
for j = 1, 361 do
|
||||||
|
x[j] = 0.1*i*x0[j]
|
||||||
|
y[j] = 0.1*i*y0[j]
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw circles for polar grid
|
||||||
|
pl.line(x, y)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
for i = 1, 12 do
|
||||||
|
theta = 30.0 * (i-1)
|
||||||
|
dx = math.cos(dtr * theta)
|
||||||
|
dy = math.sin(dtr * theta)
|
||||||
|
|
||||||
|
-- Draw radial spokes for polar grid
|
||||||
|
pl.join(0, 0, dx, dy)
|
||||||
|
|
||||||
|
-- Write labels for angle
|
||||||
|
-- Slightly off zero to avoid floating point logic flips at 90 and 270 deg.
|
||||||
|
if dx>=-0.00001 then
|
||||||
|
pl.ptex(dx, dy, dx, dy, -0.15, tostring(theta))
|
||||||
|
else
|
||||||
|
pl.ptex(dx, dy, -dx, -dy, 1.15, tostring(theta))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
-- Draw the graph
|
||||||
|
for i = 1, 361 do
|
||||||
|
r = math.sin(dtr * (5*(i-1)))
|
||||||
|
x[i] = x0[i] * r
|
||||||
|
y[i] = y0[i] * r
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(x, y)
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
pl.mtex("t", 2, 0.5, 0.5, "#frPLplot Example 3 - r(#gh)=sin 5#gh")
|
||||||
|
pl.flush()
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Demonstration of contour plotting
|
||||||
|
|
||||||
|
XPTS = 35
|
||||||
|
YPTS = 46
|
||||||
|
XSPA = 2/(XPTS-1)
|
||||||
|
YSPA = 2/(YPTS-1)
|
||||||
|
|
||||||
|
tr = { XSPA, 0, -1, 0, YSPA, -1 }
|
||||||
|
|
||||||
|
function mypltr(x, y)
|
||||||
|
tx = tr[1]*x + tr[2]*y + tr[3]
|
||||||
|
ty = tr[4]*x + tr[5]*y + tr[6]
|
||||||
|
|
||||||
|
return tx, ty
|
||||||
|
end
|
||||||
|
|
||||||
|
clevel = { -1, -.8, -.6, -.4, -.2, 0, .2, .4, .6, .8, 1 }
|
||||||
|
|
||||||
|
function plot5()
|
||||||
|
mark = { 1500 }
|
||||||
|
space = { 1500 }
|
||||||
|
|
||||||
|
-- Set up function arrays
|
||||||
|
z = {}
|
||||||
|
w = {}
|
||||||
|
|
||||||
|
for i = 1, XPTS do
|
||||||
|
xx = (i-1-math.floor(XPTS/2))/math.floor(XPTS/2)
|
||||||
|
z[i] = {}
|
||||||
|
w[i] = {}
|
||||||
|
for j = 1, YPTS do
|
||||||
|
yy = (j-1-math.floor(YPTS/2))/math.floor(YPTS/2)-1
|
||||||
|
z[i][j] = xx * xx - yy * yy
|
||||||
|
w[i][j] = 2 * xx * yy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.env(-1, 1, -1, 1, 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(z, 1, XPTS, 1, YPTS, clevel, "mypltr")
|
||||||
|
pl.styl(mark, space)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.cont(w, 1, XPTS, 1, YPTS, clevel, "mypltr")
|
||||||
|
pl.col0(1)
|
||||||
|
pl.lab("X Coordinate", "Y Coordinate", "Streamlines of flow")
|
||||||
|
pl.flush()
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Plots several simple functions from other example programs.
|
||||||
|
--
|
||||||
|
-- This version sends the output of the first 4 plots (one page) to two
|
||||||
|
-- independent streams.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Select either TK or DP driver and use a small window
|
||||||
|
-- Using DP results in a crash at the end due to some odd cleanup problems
|
||||||
|
-- The geometry strings MUST be in writable memory
|
||||||
|
geometry_master = "500x410+100+200"
|
||||||
|
geometry_slave = "500x410+650+200"
|
||||||
|
|
||||||
|
-- plplot initialization
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- If valid geometry specified on command line, use it for both streams.
|
||||||
|
xp0, yp0, xleng0, yleng0, xoff0, yoff0 = pl.gpage()
|
||||||
|
valid_geometry = xleng0>0 and yleng0>0
|
||||||
|
|
||||||
|
-- Set up first stream
|
||||||
|
if valid_geometry==true then
|
||||||
|
pl.spage(xp0, yp0, xleng0, yleng0, xoff0, yoff0)
|
||||||
|
else
|
||||||
|
pl.setopt("geometry", geometry_master)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.ssub(2, 2)
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
driver = pl.gdev()
|
||||||
|
fam, num, bmax = pl.gfam()
|
||||||
|
|
||||||
|
print("Demo of multiple output streams via the " .. driver .." driver.")
|
||||||
|
print("Running with the second stream as slave to the first.\n")
|
||||||
|
|
||||||
|
-- Start next stream
|
||||||
|
pl.sstrm(1)
|
||||||
|
|
||||||
|
if valid_geometry==true then
|
||||||
|
pl.spage(xp0, yp0, xleng0, yleng0, xoff0, yoff0)
|
||||||
|
else
|
||||||
|
pl.setopt("geometry", geometry_slave)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Turn off pause to make this a slave (must follow master)
|
||||||
|
pl.spause(0)
|
||||||
|
pl.sdev(driver)
|
||||||
|
pl.sfam(fam,num,bmax)
|
||||||
|
|
||||||
|
-- Currently number of digits in format number can only be
|
||||||
|
--set via the command line option
|
||||||
|
pl.setopt("fflen", "2")
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Set up the data & plot
|
||||||
|
-- Original case
|
||||||
|
pl.sstrm(0)
|
||||||
|
|
||||||
|
xscale = 6
|
||||||
|
yscale = 1
|
||||||
|
xoff = 0
|
||||||
|
yoff = 0
|
||||||
|
plot1()
|
||||||
|
|
||||||
|
-- Set up the data & plot
|
||||||
|
xscale = 1
|
||||||
|
yscale = 1e6
|
||||||
|
plot1()
|
||||||
|
|
||||||
|
-- Set up the data & plot
|
||||||
|
xscale = 1.
|
||||||
|
yscale = 1.e-6
|
||||||
|
digmax = 2
|
||||||
|
pl.syax(digmax, 0)
|
||||||
|
plot1()
|
||||||
|
|
||||||
|
-- Set up the data & plot
|
||||||
|
xscale = 1
|
||||||
|
yscale = 0.0014
|
||||||
|
yoff = 0.0185
|
||||||
|
digmax = 5
|
||||||
|
pl.syax(digmax, 0)
|
||||||
|
plot1()
|
||||||
|
|
||||||
|
-- To slave
|
||||||
|
-- The pleop() ensures the eop indicator gets lit.
|
||||||
|
pl.sstrm(1)
|
||||||
|
plot4()
|
||||||
|
pl.eop()
|
||||||
|
|
||||||
|
-- Back to master
|
||||||
|
pl.sstrm(0)
|
||||||
|
plot2()
|
||||||
|
plot3()
|
||||||
|
|
||||||
|
-- To slave
|
||||||
|
pl.sstrm(1)
|
||||||
|
plot5()
|
||||||
|
pl.eop()
|
||||||
|
|
||||||
|
-- Back to master to wait for user to advance
|
||||||
|
pl.sstrm(0)
|
||||||
|
pl.eop()
|
||||||
|
|
||||||
|
-- Call plend to finish off.
|
||||||
|
pl.plend()
|
234
nanonote-example-files/files/lua-plplot-examples/x15.lua
Normal file
234
nanonote-example-files/files/lua-plplot-examples/x15.lua
Normal file
@ -0,0 +1,234 @@
|
|||||||
|
--[[ $Id: x15.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Shade plot demo.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
XPTS = 35 -- Data points in x
|
||||||
|
YPTS = 46 -- Data points in y
|
||||||
|
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
-- Function prototypes
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- cmap1_init1
|
||||||
|
--
|
||||||
|
-- Initializes color map 1 in HLS space.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function cmap1_init1()
|
||||||
|
i = { 0, 0,45, 0.55, 1 } -- left boundary, just before center,
|
||||||
|
-- just after center, right boundary
|
||||||
|
h = { 260, 260, 20, 20 } -- hue -- low: blue-violet, only change as we go over vertex
|
||||||
|
-- hue -- high: red, keep fixed
|
||||||
|
l = { 0.5, 0, 0, 0.5 } -- lightness -- low, lightness -- center
|
||||||
|
-- lightness -- center, lightness -- high
|
||||||
|
s = { 1, 1, 1, 1 } -- maximum saturation
|
||||||
|
|
||||||
|
pl.scmap1l(0, i, h, l, s)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- cmap1_init2
|
||||||
|
--
|
||||||
|
-- Initializes color map 1 in HLS space.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function cmap1_init2()
|
||||||
|
i = { 0, 0.45, 0.55, 1 } -- left boundary, just before center,
|
||||||
|
-- just after center, right boundary
|
||||||
|
h = { 260, 260, 20, 20 } -- hue -- low: blue-violet, only change as we go over vertex
|
||||||
|
-- hue -- high: red, keep fixed
|
||||||
|
l = { 0.6, 0, 0, 0.6 } -- lightness -- low, lightness -- center
|
||||||
|
-- lightness -- center, lightness -- high
|
||||||
|
s = { 1, 0.5, 0.5, 1 } -- saturation -- low, saturation -- center
|
||||||
|
-- saturation -- center, saturation -- high
|
||||||
|
|
||||||
|
pl.scmap1l(0, i, h, l, s)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- plot1
|
||||||
|
--
|
||||||
|
-- Illustrates a single shaded region.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function plot1()
|
||||||
|
sh_cmap = 0
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
-- Plot using identity transform
|
||||||
|
shade_min = zmin + (zmax-zmin)*0.4
|
||||||
|
shade_max = zmin + (zmax-zmin)*0.6
|
||||||
|
sh_color = 7
|
||||||
|
sh_width = 2
|
||||||
|
min_color = 9
|
||||||
|
max_color = 2
|
||||||
|
min_width = 2
|
||||||
|
max_width = 2
|
||||||
|
|
||||||
|
pl.psty(8)
|
||||||
|
pl.shade(z, -1, 1, -1, 1, shade_min, shade_max, sh_cmap, sh_color, sh_width,
|
||||||
|
min_color, min_width, max_color, max_width, 1)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("distance", "altitude", "Bogon flux")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- plot2
|
||||||
|
--
|
||||||
|
-- Illustrates multiple adjacent shaded regions, using different fill
|
||||||
|
-- patterns for each region.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function plot2()
|
||||||
|
sh_cmap = 0
|
||||||
|
min_color = 0
|
||||||
|
min_width = 0
|
||||||
|
max_color = 0
|
||||||
|
max_width = 0
|
||||||
|
|
||||||
|
inc = { {450}, {-450}, {0}, {900}, {300},
|
||||||
|
{450,-450}, {0, 900}, {0, 450}, {450, -450}, {0, 900} }
|
||||||
|
del = { {2000}, {2000}, {2000}, {2000}, {2000},
|
||||||
|
{2000, 2000}, {2000, 2000}, {2000, 2000}, {4000, 4000}, {4000, 2000} }
|
||||||
|
|
||||||
|
sh_width = 2
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
-- Plot using identity transform
|
||||||
|
|
||||||
|
for i = 1, 10 do
|
||||||
|
shade_min = zmin + (zmax - zmin) * (i-1)/10
|
||||||
|
shade_max = zmin + (zmax - zmin) * i/10
|
||||||
|
sh_color = i+5
|
||||||
|
pl.pat(inc[i], del[i])
|
||||||
|
|
||||||
|
pl.shade(z, -1, 1, -1, 1, shade_min, shade_max, sh_cmap, sh_color, sh_width,
|
||||||
|
min_color, min_width, max_color, max_width, 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("distance", "altitude", "Bogon flux")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- plot3
|
||||||
|
--
|
||||||
|
-- Illustrates shaded regions in 3d, using a different fill pattern for
|
||||||
|
-- each region.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function plot3()
|
||||||
|
xx = { {-1, 1, 1, -1, -1}, {-1, 1, 1, -1, -1} }
|
||||||
|
yy = { {1, 1, 0, 0, 1}, {-1, -1, 0, 0, -1} }
|
||||||
|
zz = { {0, 0, 1, 1, 0}, {0, 0, 1, 1, 0} }
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1.)
|
||||||
|
pl.w3d(1, 1, 1, -1, 1, -1, 1, 0, 1.5, 30, -40)
|
||||||
|
|
||||||
|
-- Plot using identity transform
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box3("bntu", "X", 0, 0, "bntu", "Y", 0, 0, "bcdfntu", "Z", 0.5, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("","","3-d polygon filling")
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.psty(1)
|
||||||
|
pl.line3(xx[1], yy[1], zz[1])
|
||||||
|
pl.fill3(xx[1], yy[1], zz[1])
|
||||||
|
pl.psty(2)
|
||||||
|
pl.line3(xx[2], yy[2], zz[2])
|
||||||
|
pl.fill3(xx[2], yy[2], zz[2])
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- f2mnmx
|
||||||
|
--
|
||||||
|
-- Returns min & max of input 2d array.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function f2mnmx(f, nx, ny)
|
||||||
|
fmax = f[1][1]
|
||||||
|
fmin = fmax
|
||||||
|
|
||||||
|
for i=1, nx do
|
||||||
|
for j=1, ny do
|
||||||
|
fmax = math.max(fmax, f[i][j])
|
||||||
|
fmin = math.min(fmin, f[i][j])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return fmin, fmax
|
||||||
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a variety of shade plots.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Set up color map 1
|
||||||
|
cmap1_init2()
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Set up data array
|
||||||
|
for i=1, XPTS do
|
||||||
|
xx = ((i-1) - math.floor(XPTS/2))/math.floor(XPTS/2)
|
||||||
|
z[i] = {}
|
||||||
|
for j = 1, YPTS do
|
||||||
|
yy = ((j-1) - math.floor(YPTS/2))/math.floor(YPTS/2) - 1
|
||||||
|
z[i][j] = xx^2 - yy^2 + (xx - yy)/(xx^2+yy^2 + 0.1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
zmin, zmax = f2mnmx(z, XPTS, YPTS)
|
||||||
|
|
||||||
|
plot1()
|
||||||
|
plot2()
|
||||||
|
plot3()
|
||||||
|
|
||||||
|
pl.plend()
|
324
nanonote-example-files/files/lua-plplot-examples/x16.lua
Normal file
324
nanonote-example-files/files/lua-plplot-examples/x16.lua
Normal file
@ -0,0 +1,324 @@
|
|||||||
|
--[[ $Id: x16.lua 10304 2009-08-20 09:05:43Z andrewross $
|
||||||
|
|
||||||
|
plshade demo, using color fill.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
-- Fundamental settings. See notes[] for more info.
|
||||||
|
ns = 20 -- Default number of shade levels
|
||||||
|
nx = 35 -- Default number of data points in x
|
||||||
|
ny = 46 -- Default number of data points in y
|
||||||
|
exclude = 0 -- By default do not plot a page illustrating
|
||||||
|
-- exclusion. API is probably going to change
|
||||||
|
-- anyway, and cannot be reproduced by any
|
||||||
|
-- front end other than the C one.
|
||||||
|
|
||||||
|
-- polar plot data
|
||||||
|
PERIMETERPTS = 100
|
||||||
|
|
||||||
|
-- Transformation function
|
||||||
|
tr = {}
|
||||||
|
|
||||||
|
function mypltr(x, y)
|
||||||
|
tx = tr[1] * x + tr[2] * y + tr[3]
|
||||||
|
ty = tr[4] * x + tr[5] * y + tr[6]
|
||||||
|
|
||||||
|
return tx, ty
|
||||||
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- f2mnmx
|
||||||
|
--
|
||||||
|
-- Returns min & max of input 2d array.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
function f2mnmx(f, nx, ny)
|
||||||
|
fmax = f[1][1]
|
||||||
|
fmin = fmax
|
||||||
|
|
||||||
|
for i = 1, nx do
|
||||||
|
for j = 1, ny do
|
||||||
|
fmax = math.max(fmax, f[i][j])
|
||||||
|
fmin = math.min(fmin, f[i][j])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return fmin, fmax
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function zdefined(x, y)
|
||||||
|
z = math.sqrt(x^2 + y^2)
|
||||||
|
|
||||||
|
return z<0.4 or z>0.6
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does several shade plots using different coordinate mappings.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
px = {}
|
||||||
|
py = {}
|
||||||
|
|
||||||
|
fill_width = 2
|
||||||
|
cont_color = 0
|
||||||
|
cont_width = 0
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("cmap0_black_on_white.pal");
|
||||||
|
pl.spal1("cmap1_gray.pal",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Set up transformation function
|
||||||
|
tr = { 2/(nx-1), 0, -1, 0, 2/(ny-1), -1 }
|
||||||
|
|
||||||
|
-- Allocate data structures
|
||||||
|
clevel = {}
|
||||||
|
shedge = {}
|
||||||
|
z = {}
|
||||||
|
w = {}
|
||||||
|
|
||||||
|
-- Set up data array
|
||||||
|
for i = 1, nx do
|
||||||
|
x = (i-1 - math.floor(nx/2))/math.floor(nx/2)
|
||||||
|
z[i] = {}
|
||||||
|
w[i] = {}
|
||||||
|
for j = 1, ny do
|
||||||
|
y = (j-1 - math.floor(ny/2))/math.floor(ny/2)-1
|
||||||
|
z[i][j] = -math.sin(7*x) * math.cos(7*y) + x^2 - y^2
|
||||||
|
w[i][j] = -math.cos(7*x) * math.sin(7*y) + 2*x*y
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
zmin, zmax = f2mnmx(z, nx, ny)
|
||||||
|
for i = 1, ns do
|
||||||
|
clevel[i] = zmin + (zmax-zmin)*(i-0.5)/ns
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, ns+1 do
|
||||||
|
shedge[i] = zmin + (zmax-zmin)*(i-1)/ns
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Set up coordinate grids
|
||||||
|
cgrid1 = {}
|
||||||
|
cgrid1["xg"] = {}
|
||||||
|
cgrid1["yg"] = {}
|
||||||
|
cgrid1["nx"] = nx
|
||||||
|
cgrid1["ny"] = ny
|
||||||
|
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = nx
|
||||||
|
cgrid2["ny"] = ny
|
||||||
|
|
||||||
|
for i = 1, nx do
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
for j = 1, ny do
|
||||||
|
x, y = mypltr(i-1, j-1)
|
||||||
|
|
||||||
|
argx = x*math.pi/2
|
||||||
|
argy = y*math.pi/2
|
||||||
|
distort = 0.4
|
||||||
|
|
||||||
|
cgrid1["xg"][i] = x + distort * math.cos(argx)
|
||||||
|
cgrid1["yg"][j] = y - distort * math.cos(argy)
|
||||||
|
|
||||||
|
cgrid2["xg"][i][j] = x + distort * math.cos(argx) * math.cos(argy)
|
||||||
|
cgrid2["yg"][i][j] = y - distort * math.cos(argx) * math.cos(argy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Plot using identity transform
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
pl.psty(0)
|
||||||
|
|
||||||
|
pl.shades(z, -1, 1, -1, 1, shedge, fill_width, cont_color, cont_width, 1)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
--pl.cont(w, 1, nx, 1, ny, clevel, mypltr, {})
|
||||||
|
pl.lab("distance", "altitude", "Bogon density")
|
||||||
|
|
||||||
|
-- Plot using 1d coordinate transform
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("cmap0_black_on_white.pal");
|
||||||
|
pl.spal1("cmap1_blue_yellow.pal",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3);
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
pl.psty(0)
|
||||||
|
|
||||||
|
pl.shades(z, -1, 1, -1, 1, shedge, fill_width, cont_color, cont_width, 1, "pltr1", cgrid1)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab("distance", "altitude", "Bogon density")
|
||||||
|
|
||||||
|
-- Plot using 2d coordinate transform
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("cmap0_black_on_white.pal");
|
||||||
|
pl.spal1("cmap1_blue_red.pal",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3);
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
pl.psty(0)
|
||||||
|
|
||||||
|
pl.shades(z, -1, 1, -1, 1, shedge, fill_width, cont_color, cont_width, 0, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.cont(w, 1, nx, 1, ny, clevel, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
pl.lab("distance", "altitude", "Bogon density, with streamlines")
|
||||||
|
|
||||||
|
-- Plot using 2d coordinate transform
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("");
|
||||||
|
pl.spal1("",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3);
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
pl.psty(0)
|
||||||
|
|
||||||
|
pl.shades(z, -1, 1, -1, 1, shedge, fill_width, 2, 3, 0, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
pl.lab("distance", "altitude", "Bogon density")
|
||||||
|
|
||||||
|
-- Note this exclusion API will probably change.
|
||||||
|
|
||||||
|
-- Plot using 2d coordinate transform and exclusion
|
||||||
|
if exclude~=0 then
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("cmap0_black_on_white.pal");
|
||||||
|
pl.spal1("cmap1_gray.pal",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3);
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
plpsty(0)
|
||||||
|
|
||||||
|
pl.shades(z, zdefined, -1, 1, -1, 1, shedge, fill_width, cont_color, cont_width,
|
||||||
|
0, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.box("bcnst", 0, 0, "bcnstv", 0, 0)
|
||||||
|
|
||||||
|
pl.lab("distance", "altitude", "Bogon density with exclusion")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Example with polar coordinates.
|
||||||
|
|
||||||
|
-- Load colour palettes
|
||||||
|
pl.spal0("cmap0_black_on_white.pal");
|
||||||
|
pl.spal1("cmap1_gray.pal",1);
|
||||||
|
|
||||||
|
-- Reduce colors in cmap 0 so that cmap 1 is useful on a 16-color display
|
||||||
|
pl.scmap0n(3);
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(.1, .9, .1, .9)
|
||||||
|
pl.wind(-1, 1, -1, 1)
|
||||||
|
|
||||||
|
pl.psty(0)
|
||||||
|
|
||||||
|
-- Build new coordinate matrices.
|
||||||
|
for i = 1, nx do
|
||||||
|
r = (i-1)/(nx-1)
|
||||||
|
for j = 1, ny do
|
||||||
|
t = 2*math.pi/(ny-1)*(j-1)
|
||||||
|
cgrid2["xg"][i][j] = r*math.cos(t)
|
||||||
|
cgrid2["yg"][i][j] = r*math.sin(t)
|
||||||
|
z[i][j] = math.exp(-r^2)*math.cos(5*math.pi*r)*math.cos(5*t)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Need a new shedge to go along with the new data set.
|
||||||
|
zmin, zmax = f2mnmx(z, nx, ny)
|
||||||
|
|
||||||
|
for i = 1, ns+1 do
|
||||||
|
shedge[i] = zmin + (zmax-zmin)*(i-1)/ns
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Now we can shade the interior region.
|
||||||
|
pl.shades(z, -1, 1, -1, 1, shedge, fill_width, cont_color, cont_width, 0, "pltr2", cgrid2)
|
||||||
|
|
||||||
|
-- Now we can draw the perimeter. (If do before, shade stuff may overlap.)
|
||||||
|
for i = 1, PERIMETERPTS do
|
||||||
|
t = 2*math.pi/(PERIMETERPTS-1)*(i-1)
|
||||||
|
px[i] = math.cos(t)
|
||||||
|
py[i] = math.sin(t)
|
||||||
|
end
|
||||||
|
pl.col0(1)
|
||||||
|
pl.line(px, py)
|
||||||
|
|
||||||
|
-- And label the plot.
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lab( "", "", "Tokamak Bogon Instability" )
|
||||||
|
|
||||||
|
pl.plend()
|
118
nanonote-example-files/files/lua-plplot-examples/x17.lua
Normal file
118
nanonote-example-files/files/lua-plplot-examples/x17.lua
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
--[[ $Id: x17.lua 9526 2009-02-13 22:06:13Z smekal $
|
||||||
|
|
||||||
|
Plots a simple stripchart with four pens.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
nsteps = 1000
|
||||||
|
colline = {}
|
||||||
|
legline = {}
|
||||||
|
|
||||||
|
-- plplot initialization
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- User sets up plot completely except for window and data
|
||||||
|
-- Eventually settings in place when strip chart is created will be
|
||||||
|
-- remembered so that multiple strip charts can be used simultaneously.
|
||||||
|
|
||||||
|
-- Specify some reasonable defaults for ymin and ymax
|
||||||
|
-- The plot will grow automatically if needed (but not shrink)
|
||||||
|
ymin = -0.1
|
||||||
|
ymax = 0.1
|
||||||
|
|
||||||
|
-- Specify initial tmin and tmax -- this determines length of window.
|
||||||
|
-- Also specify maximum jump in t
|
||||||
|
-- This can accomodate adaptive timesteps
|
||||||
|
tmin = 0
|
||||||
|
tmax = 10
|
||||||
|
tjump = 0.3 -- percentage of plot to jump
|
||||||
|
|
||||||
|
-- Axes options same as plbox.
|
||||||
|
-- Only automatic tick generation and label placement allowed
|
||||||
|
-- Eventually I'll make this fancier
|
||||||
|
colbox = 1
|
||||||
|
collab = 3
|
||||||
|
styline = { 2, 3, 4, 5 } -- line style
|
||||||
|
colline = { 2, 3, 4, 5 } -- pens color
|
||||||
|
|
||||||
|
legline= { "sum", "sin", "sin*noi", "sin+noi" } -- pens legend
|
||||||
|
|
||||||
|
xlab = 0 -- legend position
|
||||||
|
ylab = 0.25
|
||||||
|
|
||||||
|
autoy = 1 -- autoscale y
|
||||||
|
acc = 1 -- don't scrip, accumulate
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vsta()
|
||||||
|
|
||||||
|
id1 = pl.stripc("bcnst", "bcnstv",
|
||||||
|
tmin, tmax, tjump, ymin, ymax,
|
||||||
|
xlab, ylab,
|
||||||
|
autoy, acc,
|
||||||
|
colbox, collab,
|
||||||
|
colline, styline, legline,
|
||||||
|
"t", "", "Strip chart demo")
|
||||||
|
|
||||||
|
autoy = 0 -- autoscale y
|
||||||
|
acc = 1 -- accumulate
|
||||||
|
|
||||||
|
-- This is to represent a loop over time
|
||||||
|
-- Let's try a random walk process
|
||||||
|
|
||||||
|
y1 = 0
|
||||||
|
y2 = 0
|
||||||
|
y3 = 0
|
||||||
|
y4 = 0
|
||||||
|
dt = 0.1
|
||||||
|
|
||||||
|
for n = 0, nsteps-1 do
|
||||||
|
for i = 0, 200000 do end
|
||||||
|
t = n * dt
|
||||||
|
noise = pl.randd() - 0.5
|
||||||
|
y1 = y1 + noise
|
||||||
|
y2 = math.sin(t*math.pi/18)
|
||||||
|
y3 = y2 * noise
|
||||||
|
y4 = y2 + noise/3
|
||||||
|
|
||||||
|
-- There is no need for all pens to have the same number of
|
||||||
|
-- points or beeing equally time spaced.
|
||||||
|
if math.mod(n, 2)~=0 then pl.stripa(id1, 0, t, y1) end
|
||||||
|
if math.mod(n, 3)~=0 then pl.stripa(id1, 1, t, y2) end
|
||||||
|
if math.mod(n, 4)~=0 then pl.stripa(id1, 2, t, y3) end
|
||||||
|
if math.mod(n, 5)~=0 then pl.stripa(id1, 3, t, y4) end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Destroy strip chart and it's memory
|
||||||
|
pl.stripd(id1)
|
||||||
|
pl.plend()
|
145
nanonote-example-files/files/lua-plplot-examples/x18.lua
Normal file
145
nanonote-example-files/files/lua-plplot-examples/x18.lua
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
--[[ $Id: x18.lua 9526 2009-02-13 22:06:13Z smekal $
|
||||||
|
|
||||||
|
3-d line and point plot demo. Adapted from x08c.c.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
function test_poly(k)
|
||||||
|
draw= { { 1, 1, 1, 1 },
|
||||||
|
{ 1, 0, 1, 0 },
|
||||||
|
{ 0, 1, 0, 1 },
|
||||||
|
{ 1, 1, 0, 0 } }
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 0.9)
|
||||||
|
pl.wind(-1, 1, -0.9, 1.1)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.w3d(1, 1, 1, -1, 1, -1, 1, -1, 1, alt[k], az[k])
|
||||||
|
pl.box3("bnstu", "x axis", 0, 0,
|
||||||
|
"bnstu", "y axis", 0, 0,
|
||||||
|
"bcdmnstuv", "z axis", 0, 0)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
-- x = r sin(phi) cos(theta)
|
||||||
|
-- y = r sin(phi) sin(theta)
|
||||||
|
-- z = r cos(phi)
|
||||||
|
-- r = 1 :=)
|
||||||
|
|
||||||
|
for i=0, 19 do
|
||||||
|
for j=0, 19 do
|
||||||
|
x[1] = math.sin( math.pi*j/20.1 ) * math.cos( 2*math.pi*i/20 )
|
||||||
|
y[1] = math.sin( math.pi*j/20.1 ) * math.sin( 2*math.pi*i/20 )
|
||||||
|
z[1] = math.cos( math.pi*j/20.1 )
|
||||||
|
|
||||||
|
x[2] = math.sin( math.pi*(j+1)/20.1 ) * math.cos( 2*math.pi*i/20 )
|
||||||
|
y[2] = math.sin( math.pi*(j+1)/20.1 ) * math.sin( 2*math.pi*i/20 )
|
||||||
|
z[2] = math.cos( math.pi*(j+1)/20.1 )
|
||||||
|
|
||||||
|
x[3] = math.sin( math.pi*(j+1)/20.1 ) * math.cos( 2*math.pi*(i+1)/20 )
|
||||||
|
y[3] = math.sin( math.pi*(j+1)/20.1 ) * math.sin( 2*math.pi*(i+1)/20 )
|
||||||
|
z[3] = math.cos( math.pi*(j+1)/20.1 )
|
||||||
|
|
||||||
|
x[4] = math.sin( math.pi*j/20.1 ) * math.cos( 2*math.pi*(i+1)/20 )
|
||||||
|
y[4] = math.sin( math.pi*j/20.1 ) * math.sin( 2*math.pi*(i+1)/20 )
|
||||||
|
z[4] = math.cos( math.pi*j/20.1 )
|
||||||
|
|
||||||
|
x[5] = math.sin( math.pi*j/20.1 ) * math.cos( 2*math.pi*i/20 )
|
||||||
|
y[5] = math.sin( math.pi*j/20.1 ) * math.sin( 2*math.pi*i/20 )
|
||||||
|
z[5] = math.cos( math.pi*j/20.1 )
|
||||||
|
|
||||||
|
pl.poly3( x, y, z, draw[k], 1 )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("t", 1, 0.5, 0.5, "unit radius sphere" )
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Does a series of 3-d plots for a given data set, with different
|
||||||
|
-- viewing options in each plot.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
NPTS = 1000
|
||||||
|
opt = { 1, 0, 1, 0 }
|
||||||
|
alt = { 20, 35, 50, 65 }
|
||||||
|
az = { 30, 40, 50, 60 }
|
||||||
|
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
for k=1, 4 do
|
||||||
|
test_poly(k)
|
||||||
|
end
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
-- From the mind of a sick and twisted physicist...
|
||||||
|
for i=1, NPTS do
|
||||||
|
z[i] = -1 + 2*(i-1)/NPTS
|
||||||
|
|
||||||
|
-- Pick one ...
|
||||||
|
-- r = 1 - (i-1) / NPTS
|
||||||
|
r = z[i]
|
||||||
|
|
||||||
|
x[i] = r * math.cos( 12*math.pi*(i-1)/NPTS )
|
||||||
|
y[i] = r * math.sin( 12*math.pi*(i-1)/NPTS )
|
||||||
|
end
|
||||||
|
|
||||||
|
for k=1, 4 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 0.9)
|
||||||
|
pl.wind(-1, 1, -0.9, 1.1)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.w3d(1, 1, 1, -1, 1, -1, 1, -1, 1, alt[k], az[k])
|
||||||
|
pl.box3("bnstu", "x axis", 0, 0,
|
||||||
|
"bnstu", "y axis", 0, 0,
|
||||||
|
"bcdmnstuv", "z axis", 0, 0)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
|
||||||
|
if opt[k]~=0 then
|
||||||
|
pl.line3( x, y, z )
|
||||||
|
else
|
||||||
|
pl.poin3( x, y, z, 1 )
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("t", 1.0, 0.5, 0.5, "#frPLplot Example 18 - Alt=" .. alt[k] .. ", Az=" .. az[k])
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
153
nanonote-example-files/files/lua-plplot-examples/x19.lua
Normal file
153
nanonote-example-files/files/lua-plplot-examples/x19.lua
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
--[[ $Id: x19.lua 10293 2009-08-19 07:57:43Z smekal $
|
||||||
|
|
||||||
|
Illustrates backdrop plotting of world, US maps.
|
||||||
|
Contributed by Wesley Ebisuzaki.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- mapform19
|
||||||
|
--
|
||||||
|
-- Defines specific coordinate transformation for example 19.
|
||||||
|
-- Not to be confused with mapform in src/plmap.c.
|
||||||
|
-- x[], y[] are the coordinates to be plotted.
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function mapform19(n, x, y)
|
||||||
|
for i = 1, n do
|
||||||
|
radius = 90 - y[i]
|
||||||
|
xp = radius * math.cos(x[i] * math.pi / 180)
|
||||||
|
yp = radius * math.sin(x[i] * math.pi / 180)
|
||||||
|
x[i] = xp
|
||||||
|
y[i] = yp
|
||||||
|
end
|
||||||
|
|
||||||
|
return x, y
|
||||||
|
end
|
||||||
|
|
||||||
|
-- "Normalize" longitude values so that they always fall between
|
||||||
|
-- -180.0 and 180.0
|
||||||
|
function normalize_longitude(lon)
|
||||||
|
if lon>=-180 and lon<=180 then
|
||||||
|
return lon;
|
||||||
|
else
|
||||||
|
times = math.floor((math.abs(lon)+180)/360)
|
||||||
|
if lon<0 then
|
||||||
|
return lon+360*times
|
||||||
|
else
|
||||||
|
return lon-360*times
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- A custom axis labeling function for longitudes and latitudes.
|
||||||
|
function geolocation_labeler(axis, value)
|
||||||
|
if axis==pl.PL_Y_AXIS then
|
||||||
|
label_val = value
|
||||||
|
if label_val>0 then
|
||||||
|
direction_label = " N"
|
||||||
|
else
|
||||||
|
if label_val<0 then
|
||||||
|
direction_label = " S"
|
||||||
|
else
|
||||||
|
direction_label = "Eq"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if axis==pl.PL_X_AXIS then
|
||||||
|
label_val = normalize_longitude(value);
|
||||||
|
if label_val>0 then
|
||||||
|
direction_label = " E"
|
||||||
|
else
|
||||||
|
if label_val<0 then
|
||||||
|
direction_label = " W"
|
||||||
|
else
|
||||||
|
direction_label = ""
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if axis==pl.PL_Y_AXIS and value==0 then
|
||||||
|
-- A special case for the equator
|
||||||
|
label = direction_label
|
||||||
|
else
|
||||||
|
label = math.abs(label_val) .. direction_label
|
||||||
|
end
|
||||||
|
|
||||||
|
return label
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Shows two views of the world map.
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Longitude (x) and latitude (y)
|
||||||
|
|
||||||
|
miny = -70
|
||||||
|
maxy = 80
|
||||||
|
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Cartesian plots
|
||||||
|
-- Most of world
|
||||||
|
|
||||||
|
minx = 190
|
||||||
|
maxx = 190+360
|
||||||
|
|
||||||
|
-- Setup a custom latitude and longitude-based scaling function.
|
||||||
|
pl.slabelfunc("geolocation_labeler");
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(minx, maxx, miny, maxy, 1, 70)
|
||||||
|
pl.map(nil, "usaglobe", minx, maxx, miny, maxy)
|
||||||
|
|
||||||
|
-- The Americas
|
||||||
|
|
||||||
|
minx = 190
|
||||||
|
maxx = 340
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(minx, maxx, miny, maxy, 1, 70)
|
||||||
|
pl.map(nil, "usaglobe", minx, maxx, miny, maxy)
|
||||||
|
|
||||||
|
-- Clear the labeling function
|
||||||
|
pl.slabelfunc(nil);
|
||||||
|
|
||||||
|
-- Polar, Northern hemisphere
|
||||||
|
|
||||||
|
minx = 0
|
||||||
|
maxx = 360
|
||||||
|
|
||||||
|
pl.env(-75., 75., -75., 75., 1, -1)
|
||||||
|
pl.map("mapform19", "globe", minx, maxx, miny, maxy)
|
||||||
|
|
||||||
|
pl.lsty(2)
|
||||||
|
pl.meridians("mapform19", 10, 10, 0, 360, -10, 80)
|
||||||
|
pl.plend()
|
294
nanonote-example-files/files/lua-plplot-examples/x20.lua
Normal file
294
nanonote-example-files/files/lua-plplot-examples/x20.lua
Normal file
@ -0,0 +1,294 @@
|
|||||||
|
--[[ $Id: x20.lua 9535 2009-02-17 10:14:04Z smekal $
|
||||||
|
|
||||||
|
plimage demo
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
XDIM = 260
|
||||||
|
YDIM = 220
|
||||||
|
|
||||||
|
dbg = 0
|
||||||
|
nosombrero = 0
|
||||||
|
nointeractive = 0
|
||||||
|
f_name=""
|
||||||
|
|
||||||
|
|
||||||
|
-- Transformation function
|
||||||
|
function mypltr(x, y)
|
||||||
|
local x0 = (stretch["xmin"] + stretch["xmax"])*0.5
|
||||||
|
local y0 = (stretch["ymin"] + stretch["ymax"])*0.5
|
||||||
|
local dy = (stretch["ymax"]-stretch["ymin"])*0.5
|
||||||
|
local tx = x0 + (x0-x)*(1 - stretch["stretch"]*math.cos((y-y0)/dy*math.pi*0.5))
|
||||||
|
local ty = y
|
||||||
|
|
||||||
|
return tx, ty
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- read image from file in binary ppm format
|
||||||
|
function read_img(fname)
|
||||||
|
-- naive grayscale binary ppm reading. If you know how to, improve it
|
||||||
|
local fp = io.open(fname, "rb")
|
||||||
|
if fp==nil then
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
|
||||||
|
-- version
|
||||||
|
local ver = fp:read("*line")
|
||||||
|
|
||||||
|
if ver~="P5" then -- I only understand this!
|
||||||
|
fp:close()
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
|
||||||
|
while fp:read(1)=="#" do
|
||||||
|
local com = fp:read("*line")
|
||||||
|
if com==nil then
|
||||||
|
fp:close()
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
fp:seek("cur", -1)
|
||||||
|
|
||||||
|
local w, h, num_col = fp:read("*number", "*number", "*number")
|
||||||
|
if w==nil or h==nil or num_col==nil then -- width, height, num colors
|
||||||
|
fp:close()
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
|
||||||
|
-- read the rest of the line (only EOL)
|
||||||
|
fp:read("*line")
|
||||||
|
|
||||||
|
local img = fp:read(w*h)
|
||||||
|
fp:close()
|
||||||
|
if string.len(img)~=(w*h) then
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
|
||||||
|
local imf = {}
|
||||||
|
|
||||||
|
for i = 1, w do
|
||||||
|
imf[i] = {}
|
||||||
|
for j = 1, h do
|
||||||
|
imf[i][j] = string.byte(img, (h-j)*w+i) -- flip image up-down
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return 0, imf, w, h, num_col
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- save plot
|
||||||
|
function save_plot(fname)
|
||||||
|
local cur_strm = pl.gstrm() -- get current stream
|
||||||
|
local new_strm = pl.mkstrm() -- create a new one
|
||||||
|
|
||||||
|
pl.sdev("psc") -- new device type. Use a known existing driver
|
||||||
|
pl.sfnam(fname) -- file name
|
||||||
|
|
||||||
|
pl.cpstrm(cur_strm, 0) -- copy old stream parameters to new stream
|
||||||
|
pl.replot() -- do the save
|
||||||
|
pl.end1() -- close new device
|
||||||
|
|
||||||
|
pl.sstrm(cur_strm) -- and return to previous one
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- get selection square interactively
|
||||||
|
function get_clip(xi, xe, yi, ye)
|
||||||
|
return 0, xi, xe, yi, ye
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- set gray colormap
|
||||||
|
function gray_cmap(num_col)
|
||||||
|
local r = { 0, 1 }
|
||||||
|
local g = { 0, 1 }
|
||||||
|
local b = { 0, 1 }
|
||||||
|
local pos = { 0, 1 }
|
||||||
|
|
||||||
|
pl.scmap1n(num_col)
|
||||||
|
pl.scmap1l(1, pos, r, g, b)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
r = {}
|
||||||
|
img_f = {}
|
||||||
|
cgrid2 = {}
|
||||||
|
|
||||||
|
|
||||||
|
-- Bugs in plimage():
|
||||||
|
-- + at high magnifications, the left and right edge are ragged, try
|
||||||
|
-- ./x20c -dev xwin -wplt 0.3,0.3,0.6,0.6 -ori 0.5
|
||||||
|
|
||||||
|
-- Bugs in x20c.c:
|
||||||
|
-- + if the window is resized after a selection is made on "lena", when
|
||||||
|
--making a new selection the old one will re-appear.
|
||||||
|
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
z={}
|
||||||
|
|
||||||
|
-- view image border pixels
|
||||||
|
if dbg~=0 then
|
||||||
|
pl.env(1, XDIM, 1, YDIM, 1, 1) -- no plot box
|
||||||
|
|
||||||
|
-- build a one pixel square border, for diagnostics
|
||||||
|
for i = 1, XDIM do
|
||||||
|
z[i] = {}
|
||||||
|
z[i][1] = 1 -- left
|
||||||
|
z[i][YDIM] = 1 -- right
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, YDIM do
|
||||||
|
z[1][i] = 1 -- top
|
||||||
|
z[XDIM][i] = 1 -- botton
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.lab("...around a blue square."," ","A red border should appear...")
|
||||||
|
|
||||||
|
pl.image(z, 1, XDIM, 1, YDIM, 0, 0, 1, XDIM, 1, YDIM)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- sombrero-like demo
|
||||||
|
if nosombrero==0 then
|
||||||
|
r = {}
|
||||||
|
pl.col0(2) -- draw a yellow plot box, useful for diagnostics! :(
|
||||||
|
pl.env(0, 2*math.pi, 0, 3*math.pi, 1, -1)
|
||||||
|
|
||||||
|
for i = 1, XDIM do
|
||||||
|
x[i] = (i-1)*2*math.pi/(XDIM-1)
|
||||||
|
end
|
||||||
|
for i = 1, YDIM do
|
||||||
|
y[i] = (i-1)*3*math.pi/(YDIM-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, XDIM do
|
||||||
|
r[i] = {}
|
||||||
|
z[i] = {}
|
||||||
|
for j=1, YDIM do
|
||||||
|
r[i][j] = math.sqrt(x[i]^2+y[j]^2)+1e-3
|
||||||
|
z[i][j] = math.sin(r[i][j])/r[i][j]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.lab("No, an amplitude clipped \"sombrero\"", "", "Saturn?")
|
||||||
|
pl.ptex(2, 2, 3, 4, 0, "Transparent image")
|
||||||
|
pl.image(z, 0, 2*math.pi, 0, 3*math.pi, 0.05, 1, 0, 2*math.pi, 0, 3*math.pi)
|
||||||
|
|
||||||
|
-- save the plot
|
||||||
|
if f_name~="" then
|
||||||
|
save_plot(f_name)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- read Lena image
|
||||||
|
-- Note we try two different locations to cover the case where this
|
||||||
|
-- examples is being run from the test_c.sh script
|
||||||
|
status, img_f, width, height, num_col = read_img("lena.pgm")
|
||||||
|
if status~=0 then
|
||||||
|
status, img_f, width, height, num_col = read_img("../lena.pgm")
|
||||||
|
if status~=0 then
|
||||||
|
pl.abort("No such file")
|
||||||
|
pl.plend()
|
||||||
|
os.exit()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- set gray colormap
|
||||||
|
gray_cmap(num_col)
|
||||||
|
|
||||||
|
-- display Lena
|
||||||
|
pl.env(1, width, 1, height, 1, -1)
|
||||||
|
|
||||||
|
if nointeractive==0 then
|
||||||
|
pl.lab("Set and drag Button 1 to (re)set selection, Button 2 to finish."," ","Lena...")
|
||||||
|
else
|
||||||
|
pl.lab(""," ","Lena...")
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.image(img_f, 1, width, 1, height, 0, 0, 1, width, 1, height)
|
||||||
|
|
||||||
|
-- selection/expansion demo
|
||||||
|
if nointeractive==0 then
|
||||||
|
xi = 200
|
||||||
|
xe = 330
|
||||||
|
yi = 280
|
||||||
|
ye = 220
|
||||||
|
|
||||||
|
status, xi, xe, yi, ye = get_clip(xi, xe, yi, ye)
|
||||||
|
if status~=0 then -- get selection rectangle
|
||||||
|
pl.plend()
|
||||||
|
os.exit()
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.spause(0)
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- display selection only
|
||||||
|
pl.image(img_f, 1, width, 1, height, 0, 0, xi, xe, ye, yi)
|
||||||
|
|
||||||
|
pl.spause(1)
|
||||||
|
|
||||||
|
-- zoom in selection
|
||||||
|
pl.env(xi, xe, ye, yi, 1, -1)
|
||||||
|
pl.image(img_f, 1, width, 1, height, 0, 0, xi, xe, ye, yi)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Base the dynamic range on the image contents.
|
||||||
|
img_max, img_min = pl.MinMax2dGrid(img_f)
|
||||||
|
|
||||||
|
-- Draw a saturated version of the original image. Only use the middle 50%
|
||||||
|
-- of the image's full dynamic range.
|
||||||
|
pl.col0(2)
|
||||||
|
pl.env(0, width, 0, height, 1, -1)
|
||||||
|
pl.lab("", "", "Reduced dynamic range image example")
|
||||||
|
pl.imagefr(img_f, 0, width, 0, height, 0, 0, img_min + img_max*0.25, img_max - img_max*0.25)
|
||||||
|
|
||||||
|
-- Draw a distorted version of the original image, showing its full dynamic range.
|
||||||
|
pl.env(0, width, 0, height, 1, -1)
|
||||||
|
pl.lab("", "", "Distorted image example")
|
||||||
|
|
||||||
|
stretch = {}
|
||||||
|
stretch["xmin"] = 0
|
||||||
|
stretch["xmax"] = width
|
||||||
|
stretch["ymin"] = 0
|
||||||
|
stretch["ymax"] = height
|
||||||
|
stretch["stretch"] = 0.5
|
||||||
|
|
||||||
|
-- In C / C++ the following would work, with plimagefr directly calling
|
||||||
|
-- mypltr. For compatibilty with other language bindings the same effect
|
||||||
|
-- can be achieved by generating the transformed grid first and then
|
||||||
|
-- using pltr2.
|
||||||
|
-- pl.imagefr(img_f, width, height, 0., width, 0., height, 0., 0., img_min, img_max, mypltr, (PLPointer) &stretch)
|
||||||
|
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = width+1
|
||||||
|
cgrid2["ny"] = height+1
|
||||||
|
|
||||||
|
for i = 1, width+1 do
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
for j = 1, height+1 do
|
||||||
|
xx, yy = mypltr(i, j)
|
||||||
|
cgrid2["xg"][i][j] = xx
|
||||||
|
cgrid2["yg"][i][j] = yy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
--pl.imagefr(img_f, 0, width, 0, height, 0, 0, img_min, img_max, "pltr2", cgrid2)
|
||||||
|
pl.imagefr(img_f, 0, width, 0, height, 0, 0, img_min, img_max, "mypltr")
|
||||||
|
|
||||||
|
pl.plend()
|
256
nanonote-example-files/files/lua-plplot-examples/x21.lua
Normal file
256
nanonote-example-files/files/lua-plplot-examples/x21.lua
Normal file
@ -0,0 +1,256 @@
|
|||||||
|
--[[ $Id: x21.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
Grid data demo
|
||||||
|
|
||||||
|
Copyright (C) 200 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
-- bitwise or operator from http://lua-users.org/wiki/BaseSixtyFour
|
||||||
|
-- (c) 2006-2008 by Alex Kloss
|
||||||
|
-- licensed under the terms of the LGPL2
|
||||||
|
|
||||||
|
-- return single bit (for OR)
|
||||||
|
function bit(x,b)
|
||||||
|
return (math.mod(x, 2^b) - math.mod(x,2^(b-1)) > 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- logic OR for number values
|
||||||
|
function lor(x,y)
|
||||||
|
result = 0
|
||||||
|
for p=1,8 do result = result + (((bit(x,p) or bit(y,p)) == true) and 2^(p-1) or 0) end
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Options data structure definition.
|
||||||
|
pts = 500
|
||||||
|
xp = 25
|
||||||
|
yp = 20
|
||||||
|
nl = 16
|
||||||
|
knn_order = 20
|
||||||
|
threshold = 1.001
|
||||||
|
wmin = -1e3
|
||||||
|
randn = 0
|
||||||
|
rosen = 0
|
||||||
|
|
||||||
|
|
||||||
|
function cmap1_init()
|
||||||
|
i = { 0, 1 } -- left and right boundary
|
||||||
|
|
||||||
|
h = { 240, 0 } -- blue -> green -> yellow -> red
|
||||||
|
l = { 0.6, 0.6 }
|
||||||
|
s = { 0.8, 0.8 }
|
||||||
|
|
||||||
|
pl.scmap1n(256)
|
||||||
|
pl.scmap1l(0, i, h, l, s)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function create_grid(px, py)
|
||||||
|
local x = {}
|
||||||
|
local y = {}
|
||||||
|
|
||||||
|
for i = 1, px do
|
||||||
|
x[i] = xm + (xM-xm)*(i-1)/(px-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, py do
|
||||||
|
y[i] = ym + (yM-ym)*(i-1)/(py-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
return x, y
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function create_data(pts)
|
||||||
|
local x = {}
|
||||||
|
local y = {}
|
||||||
|
local z = {}
|
||||||
|
|
||||||
|
for i = 1, pts do
|
||||||
|
xt = (xM-xm)*pl.randd()
|
||||||
|
yt = (yM-ym)*pl.randd()
|
||||||
|
if randn==0 then
|
||||||
|
x[i] = xt + xm
|
||||||
|
y[i] = yt + ym
|
||||||
|
else -- std=1, meaning that many points are outside the plot range
|
||||||
|
x[i] = math.sqrt(-2*math.log(xt)) * math.cos(2*math.pi*yt) + xm
|
||||||
|
y[i] = math.sqrt(-2*math.log(xt)) * math.sin(2*math.pi*yt) + ym
|
||||||
|
end
|
||||||
|
if rosen==0 then
|
||||||
|
r = math.sqrt(x[i]^2 + y[i]^2)
|
||||||
|
z[i] = math.exp(-r^2) * math.cos(2*math.pi*r)
|
||||||
|
else
|
||||||
|
z[i] = math.log((1-x[i])^2 + 100*(y[i] - x[i]^2)^2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return x, y, z
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
title = { "Cubic Spline Approximation",
|
||||||
|
"Delaunay Linear Interpolation",
|
||||||
|
"Natural Neighbors Interpolation",
|
||||||
|
"KNN Inv. Distance Weighted",
|
||||||
|
"3NN Linear Interpolation",
|
||||||
|
"4NN Around Inv. Dist. Weighted" }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
xm = -0.2
|
||||||
|
ym = -0.2
|
||||||
|
xM = 0.6
|
||||||
|
yM = 0.6
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
opt = { 0, 0, wmin, knn_order, threshold, 0 }
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Initialise random number generator
|
||||||
|
pl.seed(5489)
|
||||||
|
|
||||||
|
x, y, z = create_data(pts) -- the sampled data
|
||||||
|
zmin = z[1]
|
||||||
|
zmax = z[1]
|
||||||
|
for i=2, pts do
|
||||||
|
if z[i]>zmax then zmax = z[i] end
|
||||||
|
if z[i]<zmin then zmin = z[i] end
|
||||||
|
end
|
||||||
|
|
||||||
|
xg, yg = create_grid(xp, yp) -- grid the data at
|
||||||
|
clev = {}
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.env(xm, xM, ym, yM, 2, 0)
|
||||||
|
pl.col0(15)
|
||||||
|
pl.lab("X", "Y", "The original data sampling")
|
||||||
|
pl.col0(2)
|
||||||
|
pl.poin(x, y, 5)
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
pl.ssub(3, 2)
|
||||||
|
|
||||||
|
for k = 1, 2 do
|
||||||
|
pl.adv(0)
|
||||||
|
for alg=1, 6 do
|
||||||
|
zg = pl.griddata(x, y, z, xg, yg, alg, opt[alg])
|
||||||
|
|
||||||
|
--[[
|
||||||
|
- CSA can generate NaNs (only interpolates?!).
|
||||||
|
- DTLI and NNI can generate NaNs for points outside the convex hull
|
||||||
|
of the data points.
|
||||||
|
- NNLI can generate NaNs if a sufficiently thick triangle is not found
|
||||||
|
|
||||||
|
PLplot should be NaN/Inf aware, but changing it now is quite a job...
|
||||||
|
so, instead of not plotting the NaN regions, a weighted average over
|
||||||
|
the neighbors is done. --]]
|
||||||
|
|
||||||
|
|
||||||
|
if alg==pl.GRID_CSA or alg==pl.GRID_DTLI or alg==pl.GRID_NNLI or alg==pl.GRID_NNI then
|
||||||
|
for i = 1, xp do
|
||||||
|
for j = 1, yp do
|
||||||
|
if zg[i][j]~=zg[i][j] then -- average (IDW) over the 8 neighbors
|
||||||
|
zg[i][j] = 0
|
||||||
|
dist = 0
|
||||||
|
|
||||||
|
for ii=i-1, i+1 do
|
||||||
|
if ii<=xp then
|
||||||
|
for jj=j-1, j+1 do
|
||||||
|
if jj<=yp then
|
||||||
|
if ii>=1 and jj>=1 and zg[ii][jj]==zg[ii][jj] then
|
||||||
|
if (math.abs(ii-i) + math.abs(jj-j)) == 1 then
|
||||||
|
d = 1
|
||||||
|
else
|
||||||
|
d = 1.4142
|
||||||
|
end
|
||||||
|
zg[i][j] = zg[i][j] + zg[ii][jj]/(d^2)
|
||||||
|
dist = dist + d
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if dist~=0 then
|
||||||
|
zg[i][j] = zg[i][j]/dist
|
||||||
|
else
|
||||||
|
zg[i][j] = zmin
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
lzM, lzm = pl.MinMax2dGrid(zg)
|
||||||
|
|
||||||
|
if lzm~=lzm then lzm=zmin else lzm = math.min(lzm, zmin) end
|
||||||
|
if lzM~=lzM then lzM=zmax else lzM = math.max(lzM, zmax) end
|
||||||
|
|
||||||
|
-- Increase limits slightly to prevent spurious contours
|
||||||
|
-- due to rounding errors
|
||||||
|
lzm = lzm-0.01
|
||||||
|
lzM = lzM+0.01
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
|
||||||
|
pl.adv(alg)
|
||||||
|
|
||||||
|
if k==1 then
|
||||||
|
for i = 1, nl do
|
||||||
|
clev[i] = lzm + (lzM-lzm)/(nl-1)*(i-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.env0(xm, xM, ym, yM, 2, 0)
|
||||||
|
pl.col0(15)
|
||||||
|
pl.lab("X", "Y", title[alg])
|
||||||
|
pl.shades(zg, xm, xM, ym, yM, clev, 1, 0, 1, 1)
|
||||||
|
pl.col0(2)
|
||||||
|
else
|
||||||
|
for i = 1, nl do
|
||||||
|
clev[i] = lzm + (lzM-lzm)/(nl-1)*(i-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
cmap1_init()
|
||||||
|
pl.vpor(0, 1, 0, 0.9)
|
||||||
|
pl.wind(-1.1, 0.75, -0.65, 1.20)
|
||||||
|
|
||||||
|
-- For the comparison to be fair, all plots should have the
|
||||||
|
-- same z values, but to get the max/min of the data generated
|
||||||
|
-- by all algorithms would imply two passes. Keep it simple.
|
||||||
|
--
|
||||||
|
-- pl.w3d(1, 1, 1, xm, xM, ym, yM, zmin, zmax, 30, -60)
|
||||||
|
|
||||||
|
|
||||||
|
pl.w3d(1, 1, 1, xm, xM, ym, yM, lzm, lzM, 30, -40)
|
||||||
|
pl.box3("bntu", "X", 0, 0,
|
||||||
|
"bntu", "Y", 0, 0,
|
||||||
|
"bcdfntu", "Z", 0.5, 0)
|
||||||
|
pl.col0(15)
|
||||||
|
pl.lab("", "", title[alg])
|
||||||
|
pl.plot3dc(xg, yg, zg, lor(lor(pl.DRAW_LINEXY, pl.MAG_COLOR), pl.BASE_CONT), clev)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
273
nanonote-example-files/files/lua-plplot-examples/x22.lua
Normal file
273
nanonote-example-files/files/lua-plplot-examples/x22.lua
Normal file
@ -0,0 +1,273 @@
|
|||||||
|
--[[ $Id: x22.lua 9526 2009-02-13 22:06:13Z smekal $
|
||||||
|
|
||||||
|
Simple vector plot example
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
-- Pairs of points making the line segments used to plot the user defined arrow
|
||||||
|
arrow_x = { -0.5, 0.5, 0.3, 0.5, 0.3, 0.5 }
|
||||||
|
arrow_y = { 0, 0, 0.2, 0, -0.2, 0 }
|
||||||
|
arrow2_x = { -0.5, 0.3, 0.3, 0.5, 0.3, 0.3 }
|
||||||
|
arrow2_y = { 0, 0, 0.2, 0, -0.2, 0 }
|
||||||
|
|
||||||
|
|
||||||
|
-- Vector plot of the circulation about the origin
|
||||||
|
function circulation()
|
||||||
|
nx = 20
|
||||||
|
ny = 20
|
||||||
|
dx = 1
|
||||||
|
dy = 1
|
||||||
|
|
||||||
|
xmin = -nx/2*dx
|
||||||
|
xmax = nx/2*dx
|
||||||
|
ymin = -ny/2*dy
|
||||||
|
ymax = ny/2*dy
|
||||||
|
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = nx
|
||||||
|
cgrid2["ny"] = ny
|
||||||
|
u = {}
|
||||||
|
v = {}
|
||||||
|
|
||||||
|
-- Create data - circulation around the origin.
|
||||||
|
for i = 1, nx do
|
||||||
|
x = (i-1-nx/2+0.5)*dx
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
u[i] = {}
|
||||||
|
v[i] = {}
|
||||||
|
for j=1, ny do
|
||||||
|
y = (j-1-ny/2+0.5)*dy
|
||||||
|
cgrid2["xg"][i][j] = x
|
||||||
|
cgrid2["yg"][i][j] = y
|
||||||
|
u[i][j] = y
|
||||||
|
v[i][j] = -x
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Plot vectors with default arrows
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 0)
|
||||||
|
pl.lab("(x)", "(y)", "#frPLplot Example 22 - circulation")
|
||||||
|
pl.col0(2)
|
||||||
|
pl.vect(u, v, 0, "pltr2", cgrid2 )
|
||||||
|
pl.col0(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Vector plot of flow through a constricted pipe
|
||||||
|
function constriction()
|
||||||
|
nx = 20
|
||||||
|
ny = 20
|
||||||
|
dx = 1
|
||||||
|
dy = 1
|
||||||
|
|
||||||
|
xmin = -nx/2*dx
|
||||||
|
xmax = nx/2*dx
|
||||||
|
ymin = -ny/2*dy
|
||||||
|
ymax = ny/2*dy
|
||||||
|
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = nx
|
||||||
|
cgrid2["ny"] = ny
|
||||||
|
u = {}
|
||||||
|
v = {}
|
||||||
|
|
||||||
|
Q = 2
|
||||||
|
for i = 1, nx do
|
||||||
|
x = (i-1-nx/2+0.5)*dx
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
u[i] = {}
|
||||||
|
v[i] = {}
|
||||||
|
for j = 1, ny do
|
||||||
|
y = (j-1-ny/2+0.5)*dy
|
||||||
|
cgrid2["xg"][i][j] = x
|
||||||
|
cgrid2["yg"][i][j] = y
|
||||||
|
b = ymax/4*(3-math.cos(math.pi*x/xmax))
|
||||||
|
if math.abs(y)<b then
|
||||||
|
dbdx = ymax/4*math.sin(math.pi*x/xmax)*y/b
|
||||||
|
u[i][j] = Q*ymax/b
|
||||||
|
v[i][j] = dbdx*u[i][j]
|
||||||
|
else
|
||||||
|
u[i][j] = 0
|
||||||
|
v[i][j] = 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 0)
|
||||||
|
pl.lab("(x)", "(y)", "#frPLplot Example 22 - constriction")
|
||||||
|
pl.col0(2)
|
||||||
|
pl.vect(u, v, -0.5, "pltr2", cgrid2)
|
||||||
|
pl.col0(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function f2mnmx(f, nx, ny)
|
||||||
|
fmax = f[1][1]
|
||||||
|
fmin = fmax
|
||||||
|
|
||||||
|
for i=1, nx do
|
||||||
|
for j=1, ny do
|
||||||
|
fmax = math.max(fmax, f[i][j])
|
||||||
|
fmin = math.min(fmin, f[i][j])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return fmin, fmax
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Vector plot of the gradient of a shielded potential (see example 9)
|
||||||
|
function potential()
|
||||||
|
nper = 100
|
||||||
|
nlevel = 10
|
||||||
|
nr = 20
|
||||||
|
ntheta = 20
|
||||||
|
|
||||||
|
u = {}
|
||||||
|
v = {}
|
||||||
|
z = {}
|
||||||
|
clevel = {}
|
||||||
|
px = {}
|
||||||
|
py = {}
|
||||||
|
|
||||||
|
cgrid2 = {}
|
||||||
|
cgrid2["xg"] = {}
|
||||||
|
cgrid2["yg"] = {}
|
||||||
|
cgrid2["nx"] = nr
|
||||||
|
cgrid2["ny"] = ntheta
|
||||||
|
|
||||||
|
-- Potential inside a conducting cylinder (or sphere) by method of images.
|
||||||
|
-- Charge 1 is placed at (d1, d1), with image charge at (d2, d2).
|
||||||
|
-- Charge 2 is placed at (d1, -d1), with image charge at (d2, -d2).
|
||||||
|
-- Also put in smoothing term at small distances.
|
||||||
|
rmax = nr
|
||||||
|
|
||||||
|
eps = 2
|
||||||
|
|
||||||
|
q1 = 1
|
||||||
|
d1 = rmax/4
|
||||||
|
|
||||||
|
q1i = -q1*rmax/d1
|
||||||
|
d1i = rmax^2/d1
|
||||||
|
|
||||||
|
q2 = -1
|
||||||
|
d2 = rmax/4
|
||||||
|
|
||||||
|
q2i = -q2*rmax/d2
|
||||||
|
d2i = rmax^2/d2
|
||||||
|
|
||||||
|
for i = 1, nr do
|
||||||
|
r = i - 0.5
|
||||||
|
cgrid2["xg"][i] = {}
|
||||||
|
cgrid2["yg"][i] = {}
|
||||||
|
u[i] = {}
|
||||||
|
v[i] = {}
|
||||||
|
z[i] = {}
|
||||||
|
for j = 1, ntheta do
|
||||||
|
theta = 2*math.pi/(ntheta-1)*(j-0.5)
|
||||||
|
x = r*math.cos(theta)
|
||||||
|
y = r*math.sin(theta)
|
||||||
|
cgrid2["xg"][i][j] = x
|
||||||
|
cgrid2["yg"][i][j] = y
|
||||||
|
div1 = math.sqrt((x-d1)^2 + (y-d1)^2 + eps^2)
|
||||||
|
div1i = math.sqrt((x-d1i)^2 + (y-d1i)^2 + eps^2)
|
||||||
|
div2 = math.sqrt((x-d2)^2 + (y+d2)^2 + eps^2)
|
||||||
|
div2i = math.sqrt((x-d2i)^2 + (y+d2i)^2 + eps^2)
|
||||||
|
z[i][j] = q1/div1 + q1i/div1i + q2/div2 + q2i/div2i
|
||||||
|
u[i][j] = -q1*(x-d1)/div1^3 - q1i*(x-d1i)/div1i^3
|
||||||
|
-q2*(x-d2)/div2^3 - q2i*(x-d2i)/div2i^3
|
||||||
|
v[i][j] = -q1*(y-d1)/div1^3 - q1i*(y-d1i)/div1i^3
|
||||||
|
-q2*(y+d2)/div2^3 - q2i*(y+d2i)/div2i^3
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
xmin, xmax = f2mnmx(cgrid2["xg"], nr, ntheta)
|
||||||
|
ymin, ymax = f2mnmx(cgrid2["yg"], nr, ntheta)
|
||||||
|
zmin, zmax = f2mnmx(z, nr, ntheta)
|
||||||
|
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 0)
|
||||||
|
pl.lab("(x)", "(y)", "#frPLplot Example 22 - potential gradient vector plot")
|
||||||
|
|
||||||
|
-- Plot contours of the potential
|
||||||
|
dz = (zmax-zmin)/nlevel
|
||||||
|
for i = 1, nlevel do
|
||||||
|
clevel[i] = zmin + (i-0.5)*dz
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lsty(2)
|
||||||
|
pl.cont(z, 1, nr, 1, ntheta, clevel, "pltr2", cgrid2)
|
||||||
|
pl.lsty(1)
|
||||||
|
pl.col0(1)
|
||||||
|
|
||||||
|
-- Plot the vectors of the gradient of the potential
|
||||||
|
pl.col0(2)
|
||||||
|
pl.vect(u, v, 25, "pltr2", cgrid2)
|
||||||
|
pl.col0(1)
|
||||||
|
|
||||||
|
-- Plot the perimeter of the cylinder
|
||||||
|
for i=1, nper do
|
||||||
|
theta = 2*math.pi/(nper-1)*(i-1)
|
||||||
|
px[i] = rmax*math.cos(theta)
|
||||||
|
py[i] = rmax*math.sin(theta)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.line(px, py)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Generates several simple vector plots.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
circulation()
|
||||||
|
|
||||||
|
fill = 0
|
||||||
|
|
||||||
|
-- Set arrow style using arrow_x and arrow_y then
|
||||||
|
-- plot using these arrows.
|
||||||
|
pl.svect(arrow_x, arrow_y, fill)
|
||||||
|
constriction()
|
||||||
|
|
||||||
|
-- Set arrow style using arrow2_x and arrow2_y then
|
||||||
|
-- plot using these filled arrows.
|
||||||
|
fill = 1
|
||||||
|
pl.svect(arrow2_x, arrow2_y, fill)
|
||||||
|
constriction()
|
||||||
|
|
||||||
|
potential()
|
||||||
|
|
||||||
|
pl.plend()
|
331
nanonote-example-files/files/lua-plplot-examples/x23.lua
Normal file
331
nanonote-example-files/files/lua-plplot-examples/x23.lua
Normal file
@ -0,0 +1,331 @@
|
|||||||
|
--[[ $Id: x23.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Displays Greek letters and mathematically interesting Unicode ranges
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Displays Greek letters and mathematically interesting Unicode ranges
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Greek = {
|
||||||
|
"#gA","#gB","#gG","#gD","#gE","#gZ","#gY","#gH","#gI","#gK","#gL","#gM",
|
||||||
|
"#gN","#gC","#gO","#gP","#gR","#gS","#gT","#gU","#gF","#gX","#gQ","#gW",
|
||||||
|
"#ga","#gb","#gg","#gd","#ge","#gz","#gy","#gh","#gi","#gk","#gl","#gm",
|
||||||
|
"#gn","#gc","#go","#gp","#gr","#gs","#gt","#gu","#gf","#gx","#gq","#gw"
|
||||||
|
}
|
||||||
|
|
||||||
|
Type1 = {
|
||||||
|
32, 33, 35, 37, 38,
|
||||||
|
40, 41, 43, 44, 46,
|
||||||
|
47, 48, 49, 50, 51,
|
||||||
|
52, 53, 54, 55, 56,
|
||||||
|
57, 58, 59, 60, 61,
|
||||||
|
62, 63, 91, 93, 95,
|
||||||
|
123, 124, 125, 169, 172,
|
||||||
|
174, 176, 177, 215, 247,
|
||||||
|
402, 913, 914, 915, 916,
|
||||||
|
917, 918, 919, 920, 921,
|
||||||
|
922, 923, 924, 925, 926,
|
||||||
|
927, 928, 929, 931, 932,
|
||||||
|
933, 934, 935, 936, 937,
|
||||||
|
945, 946, 947, 948, 949,
|
||||||
|
950, 951, 952, 953, 954,
|
||||||
|
955, 956, 957, 958, 959,
|
||||||
|
960, 961, 962, 963, 964,
|
||||||
|
965, 966, 967, 968, 969,
|
||||||
|
977, 978, 981, 982, 8226,
|
||||||
|
8230, 8242, 8243, 8254, 8260,
|
||||||
|
8465, 8472, 8476, 8482, 8486,
|
||||||
|
8501, 8592, 8593, 8594, 8595,
|
||||||
|
8596, 8629, 8656, 8657, 8658,
|
||||||
|
8659, 8660, 8704, 8706, 8707,
|
||||||
|
8709, 8710, 8711, 8712, 8713,
|
||||||
|
8715, 8719, 8721, 8722, 8725,
|
||||||
|
8727, 8730, 8733, 8734, 8736,
|
||||||
|
8743, 8744, 8745, 8746, 8747,
|
||||||
|
8756, 8764, 8773, 8776, 8800,
|
||||||
|
8801, 8804, 8805, 8834, 8835,
|
||||||
|
8836, 8838, 8839, 8853, 8855,
|
||||||
|
8869, 8901, 8992, 8993, 9001,
|
||||||
|
9002, 9674, 9824, 9827, 9829,
|
||||||
|
9830
|
||||||
|
}
|
||||||
|
|
||||||
|
title = {
|
||||||
|
"#<0x10>PLplot Example 23 - Greek Letters",
|
||||||
|
"#<0x10>PLplot Example 23 - Type 1 Symbol Font Glyphs by Unicode (a)",
|
||||||
|
"#<0x10>PLplot Example 23 - Type 1 Symbol Font Glyphs by Unicode (b)",
|
||||||
|
"#<0x10>PLplot Example 23 - Type 1 Symbol Font Glyphs by Unicode (c)",
|
||||||
|
"#<0x10>PLplot Example 23 - Number Forms Unicode Block",
|
||||||
|
"#<0x10>PLplot Example 23 - Arrows Unicode Block (a)",
|
||||||
|
"#<0x10>PLplot Example 23 - Arrows Unicode Block (b)",
|
||||||
|
"#<0x10>PLplot Example 23 - Mathematical Operators Unicode Block (a)",
|
||||||
|
"#<0x10>PLplot Example 23 - Mathematical Operators Unicode Block (b)",
|
||||||
|
"#<0x10>PLplot Example 23 - Mathematical Operators Unicode Block (c)",
|
||||||
|
"#<0x10>PLplot Example 23 - Mathematical Operators Unicode Block (d)"
|
||||||
|
}
|
||||||
|
|
||||||
|
lo = {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
64,
|
||||||
|
128,
|
||||||
|
8531,
|
||||||
|
8592,
|
||||||
|
8656,
|
||||||
|
8704,
|
||||||
|
8768,
|
||||||
|
8832,
|
||||||
|
8896
|
||||||
|
}
|
||||||
|
|
||||||
|
hi = {
|
||||||
|
48,
|
||||||
|
64,
|
||||||
|
128,
|
||||||
|
166,
|
||||||
|
8580,
|
||||||
|
8656,
|
||||||
|
8704,
|
||||||
|
8768,
|
||||||
|
8832,
|
||||||
|
8896,
|
||||||
|
8960
|
||||||
|
}
|
||||||
|
|
||||||
|
nxcells = {
|
||||||
|
12,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8
|
||||||
|
}
|
||||||
|
|
||||||
|
nycells = {
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8,
|
||||||
|
8
|
||||||
|
}
|
||||||
|
|
||||||
|
-- non-zero values Must be consistent with nxcells and nycells.
|
||||||
|
offset = {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
64,
|
||||||
|
128,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0
|
||||||
|
}
|
||||||
|
|
||||||
|
-- 30 possible FCI values.
|
||||||
|
FCI_COMBINATIONS = 30
|
||||||
|
fci = {
|
||||||
|
2147483648,
|
||||||
|
2147483649,
|
||||||
|
2147483650,
|
||||||
|
2147483651,
|
||||||
|
2147483652,
|
||||||
|
2147483664,
|
||||||
|
2147483665,
|
||||||
|
2147483666,
|
||||||
|
2147483667,
|
||||||
|
2147483668,
|
||||||
|
2147483680,
|
||||||
|
2147483681,
|
||||||
|
2147483682,
|
||||||
|
2147483683,
|
||||||
|
2147483684,
|
||||||
|
2147483904,
|
||||||
|
2147483905,
|
||||||
|
2147483906,
|
||||||
|
2147483907,
|
||||||
|
2147483908,
|
||||||
|
2147483920,
|
||||||
|
2147483921,
|
||||||
|
2147483922,
|
||||||
|
2147483923,
|
||||||
|
2147483924,
|
||||||
|
2147483936,
|
||||||
|
2147483937,
|
||||||
|
2147483938,
|
||||||
|
2147483939,
|
||||||
|
2147483940
|
||||||
|
}
|
||||||
|
|
||||||
|
family = {
|
||||||
|
"sans-serif",
|
||||||
|
"serif",
|
||||||
|
"monospace",
|
||||||
|
"script",
|
||||||
|
"symbol"
|
||||||
|
}
|
||||||
|
|
||||||
|
style = {
|
||||||
|
"upright",
|
||||||
|
"italic",
|
||||||
|
"oblique"
|
||||||
|
}
|
||||||
|
|
||||||
|
weight = {
|
||||||
|
"medium",
|
||||||
|
"bold"
|
||||||
|
}
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
for page=1, 11 do
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Set up viewport and window
|
||||||
|
pl.vpor(0.02, 0.98, 0.02, 0.90)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
xmin, xmax, ymin, ymax = pl.gspa()
|
||||||
|
pl.schr(0, 0.8)
|
||||||
|
ycharacter_scale = (1-0)/(ymax-ymin)
|
||||||
|
|
||||||
|
-- Factor should be 0.5, but heuristically it turns out to be larger.
|
||||||
|
chardef, charht = pl.gchr()
|
||||||
|
yoffset = charht*ycharacter_scale
|
||||||
|
|
||||||
|
-- Draw the grid using plbox
|
||||||
|
pl.col0(2)
|
||||||
|
deltax = 1.0/nxcells[page]
|
||||||
|
deltay = 1.0/nycells[page]
|
||||||
|
pl.box("bcg", deltax, 0, "bcg", deltay, 0)
|
||||||
|
pl.col0(15)
|
||||||
|
length=hi[page]-lo[page]
|
||||||
|
slice = 1
|
||||||
|
|
||||||
|
for j=nycells[page]-1, -1, -1 do
|
||||||
|
y = (0.5+j)*deltay
|
||||||
|
for i=1, nxcells[page] do
|
||||||
|
x = (i-0.5)*deltax
|
||||||
|
if slice<=length then
|
||||||
|
if page==1 then
|
||||||
|
cmdString = "#" .. Greek[slice]
|
||||||
|
elseif (page>=2) and (page<=4) then
|
||||||
|
cmdString = string.format("##[0x%.4x]", Type1[offset[page]+slice])
|
||||||
|
elseif page>4 then
|
||||||
|
cmdString = string.format("##[0x%.4x]", lo[page]+slice-1)
|
||||||
|
end
|
||||||
|
pl.ptex(x, y+yoffset, 1, 0, 0.5, string.sub(cmdString,2))
|
||||||
|
pl.ptex(x, y-yoffset, 1, 0, 0.5, cmdString)
|
||||||
|
end
|
||||||
|
slice = slice + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.schr(0, 1)
|
||||||
|
|
||||||
|
-- Page title
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, title[page])
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Demonstrate methods of getting the current fonts
|
||||||
|
fci_old = pl.gfci()
|
||||||
|
ifamily, istyle, iweight = pl.gfont()
|
||||||
|
print(string.format("For example 23 prior to page 12 the FCI is 0x%x", fci_old))
|
||||||
|
print(string.format("For example 23 prior to page 12 the font family, style and weight are %s %s %s",
|
||||||
|
family[ifamily+1], style[istyle+1], weight[iweight+1]))
|
||||||
|
|
||||||
|
for page=12, 16 do
|
||||||
|
dy = 0.030
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.02, 0.98, 0.02, 0.90)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
pl.sfci(0)
|
||||||
|
|
||||||
|
if page==12 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "#<0x10>PLplot Example 23 - Set Font with plsfci")
|
||||||
|
elseif page==13 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "#<0x10>PLplot Example 23 - Set Font with plsfont")
|
||||||
|
elseif page==14 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "#<0x10>PLplot Example 23 - Set Font with ##<0x8nnnnnnn> construct")
|
||||||
|
elseif page==15 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "#<0x10>PLplot Example 23 - Set Font with ##<0xmn> constructs")
|
||||||
|
elseif page==16 then
|
||||||
|
pl.mtex("t", 1.5, 0.5, 0.5, "#<0x10>PLplot Example 23 - Set Font with ##<FCI COMMAND STRING/> constructs")
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.schr(0, 0.75)
|
||||||
|
for i=1, FCI_COMBINATIONS do
|
||||||
|
family_index = math.mod(i-1, 5)+1
|
||||||
|
style_index = math.mod(math.floor((i-1)/5), 3)+1
|
||||||
|
weight_index = math.mod(math.floor((i-1)/5/3), 2)+1
|
||||||
|
if page==12 then
|
||||||
|
pl.sfci(fci[i])
|
||||||
|
str = string.format("Page 12, %s, %s, %s: The quick brown fox jumps over the lazy dog",
|
||||||
|
family[family_index], style[style_index], weight[weight_index])
|
||||||
|
elseif page==13 then
|
||||||
|
pl.sfont(family_index-1, style_index-1, weight_index-1)
|
||||||
|
str = string.format("Page 13, %s, %s, %s: The quick brown fox jumps over the lazy dog",
|
||||||
|
family[family_index], style[style_index], weight[weight_index])
|
||||||
|
elseif page==14 then
|
||||||
|
str = string.format("Page 14, %s, %s, %s: #<0x%x>The quick brown fox jumps over the lazy dog",
|
||||||
|
family[family_index], style[style_index], weight[weight_index], fci[i])
|
||||||
|
elseif page==15 then
|
||||||
|
str = string.format("Page 15, %s, %s, %s: #<0x%1x0>#<0x%1x1>#<0x%1x2>The quick brown fox jumps over the lazy dog",
|
||||||
|
family[family_index], style[style_index], weight[weight_index],
|
||||||
|
family_index-1, style_index-1, weight_index-1)
|
||||||
|
elseif page==16 then
|
||||||
|
str = string.format("Page 16, %s, %s, %s: #<%s/>#<%s/>#<%s/>The quick brown fox jumps over the lazy dog",
|
||||||
|
family[family_index], style[style_index], weight[weight_index],
|
||||||
|
family[family_index], style[style_index], weight[weight_index])
|
||||||
|
end
|
||||||
|
pl.ptex(0, 1-(i-0.5)*dy, 1, 0, 0, str)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.schr(0, 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Restore defaults
|
||||||
|
pl.col0(1)
|
||||||
|
|
||||||
|
pl.plend()
|
142
nanonote-example-files/files/lua-plplot-examples/x24.lua
Normal file
142
nanonote-example-files/files/lua-plplot-examples/x24.lua
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
--[[ $Id: x24.lua 9414 2009-01-29 22:48:54Z airwin $
|
||||||
|
|
||||||
|
Unicode Pace Flag
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
|
In Debian, run like this:
|
||||||
|
|
||||||
|
( TTFDIR=/usr/share/fonts/truetype \
|
||||||
|
PLPLOT_FREETYPE_SANS_FONT=$TTFDIR/arphic/bkai00mp.ttf \
|
||||||
|
PLPLOT_FREETYPE_SERIF_FONT=$TTFDIR/freefont/FreeSerif.ttf \
|
||||||
|
PLPLOT_FREETYPE_MONO_FONT=$TTFDIR/ttf-devanagari-fonts/lohit_hi.ttf \
|
||||||
|
PLPLOT_FREETYPE_SCRIPT_FONT=$TTFDIR/unfonts/UnBatang.ttf \
|
||||||
|
PLPLOT_FREETYPE_SYMBOL_FONT=$TTFDIR/ttf-bengali-fonts/JamrulNormal.ttf \
|
||||||
|
./x24c -dev png -drvopt smooth=0 -o x24c.png )
|
||||||
|
|
||||||
|
Packages needed:
|
||||||
|
|
||||||
|
ttf-arphic-bkai00mp
|
||||||
|
ttf-freefont
|
||||||
|
ttf-devanagari-fonts
|
||||||
|
ttf-unfonts
|
||||||
|
ttf-bengali-fonts
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
red = { 240, 204, 204, 204, 0, 39, 125 }
|
||||||
|
green = { 240, 0, 125, 204, 204, 80, 0 }
|
||||||
|
blue = { 240, 0, 0, 0, 0, 204, 125 }
|
||||||
|
|
||||||
|
px = { 0, 0, 1, 1 }
|
||||||
|
py = { 0, 0.25, 0.25, 0 }
|
||||||
|
|
||||||
|
sx = {
|
||||||
|
0.16374,
|
||||||
|
0.15844,
|
||||||
|
0.15255,
|
||||||
|
0.17332,
|
||||||
|
0.50436,
|
||||||
|
0.51721,
|
||||||
|
0.49520,
|
||||||
|
0.48713,
|
||||||
|
0.83976,
|
||||||
|
0.81688,
|
||||||
|
0.82231,
|
||||||
|
0.82647
|
||||||
|
}
|
||||||
|
|
||||||
|
sy = {
|
||||||
|
0.125,
|
||||||
|
0.375,
|
||||||
|
0.625,
|
||||||
|
0.875,
|
||||||
|
0.125,
|
||||||
|
0.375,
|
||||||
|
0.625,
|
||||||
|
0.875,
|
||||||
|
0.125,
|
||||||
|
0.375,
|
||||||
|
0.625,
|
||||||
|
0.875
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
-- Taken from http://www.columbia.edu/~fdc/pace/
|
||||||
|
|
||||||
|
peace = {
|
||||||
|
-- Mandarin
|
||||||
|
"#<0x00>和平",
|
||||||
|
-- Hindi
|
||||||
|
"#<0x20>शांति",
|
||||||
|
-- English
|
||||||
|
"#<0x10>Peace",
|
||||||
|
-- Hebrew
|
||||||
|
"#<0x10>שלום",
|
||||||
|
-- Russian
|
||||||
|
"#<0x10>Мир",
|
||||||
|
-- German
|
||||||
|
"#<0x10>Friede",
|
||||||
|
-- Korean
|
||||||
|
"#<0x30>평화",
|
||||||
|
-- French
|
||||||
|
"#<0x10>Paix",
|
||||||
|
-- Spanish
|
||||||
|
"#<0x10>Paz",
|
||||||
|
-- Arabic
|
||||||
|
"#<0x10>ﺳﻼم",
|
||||||
|
-- Turkish
|
||||||
|
"#<0x10>Barış",
|
||||||
|
-- Kurdish
|
||||||
|
"#<0x10>Hasîtî",
|
||||||
|
}
|
||||||
|
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 1)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
pl.col0(0)
|
||||||
|
pl.box("", 1, 0, "", 1, 0)
|
||||||
|
|
||||||
|
pl.scmap0n(7)
|
||||||
|
pl.scmap0(red, green, blue)
|
||||||
|
|
||||||
|
pl.schr(0, 4)
|
||||||
|
pl.font(1)
|
||||||
|
|
||||||
|
for i = 1, 4 do
|
||||||
|
pl.col0(i)
|
||||||
|
pl.fill(px, py)
|
||||||
|
|
||||||
|
for j = 1, 4 do
|
||||||
|
py[j] = py[j] + 1/4
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(0)
|
||||||
|
for i = 1, 12 do
|
||||||
|
pl.ptex(sx[i], sy[i], 1, 0, 0.5, peace[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
96
nanonote-example-files/files/lua-plplot-examples/x25.lua
Normal file
96
nanonote-example-files/files/lua-plplot-examples/x25.lua
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
--[[ $Id: x25.lua 10668 2009-12-02 08:38:49Z airwin $
|
||||||
|
|
||||||
|
Filling and clipping polygons.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Test program for filling polygons and proper clipping
|
||||||
|
--------------------------------------------------------------------------
|
||||||
|
|
||||||
|
xextreme = {}
|
||||||
|
yextreme ={}
|
||||||
|
x0 = {}
|
||||||
|
y0 = {}
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.ssub(3, 3)
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
xextreme = { { -120, 120 }, { -120, 120 }, { -120, 120 }, { -80, 80 }, { -220, -120 },
|
||||||
|
{ -20, 20 }, { -20, 20 }, { -80, 80 }, { 20, 120 } }
|
||||||
|
|
||||||
|
yextreme = { { -120, 120 }, { 20, 120 }, { -20, 120 }, { -20, 120 }, { -120, 120 },
|
||||||
|
{ -120, 120 }, { -20, 20 }, { -80, 80 }, { -120, 120 } }
|
||||||
|
|
||||||
|
for k = 1, 2 do
|
||||||
|
for j = 1, 4 do
|
||||||
|
if j==1 then
|
||||||
|
-- Polygon 1: a diamond
|
||||||
|
x0 = { 0, -100, 0, 100 }
|
||||||
|
y0 = { -100, 0, 100, 0}
|
||||||
|
end
|
||||||
|
if j==2 then
|
||||||
|
-- Polygon 1: a diamond - reverse direction
|
||||||
|
x0 = { 100, 0, -100, 0 }
|
||||||
|
y0 = { 0, 100, 0, -100}
|
||||||
|
end
|
||||||
|
if j==3 then
|
||||||
|
-- Polygon 2: a square with punctures
|
||||||
|
x0 = { -100, -100, 80, -100, -100, -80, 0, 80, 100, 100 }
|
||||||
|
y0 = { -100, -80, 0, 80, 100, 100, 80, 100, 100, -100}
|
||||||
|
end
|
||||||
|
if j==4 then
|
||||||
|
-- Polygon 2: a square with punctures - reversed direction
|
||||||
|
x0 = { 100, 100, 80, 0, -80, -100, -100, 80, -100, -100 }
|
||||||
|
y0 = { -100, 100, 100, 80, 100, 100, 80, 0, -80, -100}
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, 9 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(xextreme[i][1], xextreme[i][2], yextreme[i][1], yextreme[i][2])
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box("bc", 1, 0, "bcnv", 10, 0)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.psty(0)
|
||||||
|
if k==1 then
|
||||||
|
pl.fill(x0, y0)
|
||||||
|
else
|
||||||
|
pl.gradient(x0, y0, 45.)
|
||||||
|
end
|
||||||
|
pl.col0(2)
|
||||||
|
pl.lsty(1)
|
||||||
|
pl.line(x0, y0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Don't forget to call plend() to finish off!
|
||||||
|
pl.plend()
|
151
nanonote-example-files/files/lua-plplot-examples/x26.lua
Normal file
151
nanonote-example-files/files/lua-plplot-examples/x26.lua
Normal file
@ -0,0 +1,151 @@
|
|||||||
|
--[[ -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
$Id: x26.lua 9506 2009-02-11 08:23:29Z smekal $
|
||||||
|
|
||||||
|
Multi-lingual version of the first page of example 4.
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
Thanks to the following for providing translated strings for this example:
|
||||||
|
Valery Pipin (Russian)
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
--[[
|
||||||
|
This example designed just for devices (e.g., psttfc and the
|
||||||
|
cairo-related devices) that use the pango and fontconfig libraries. The
|
||||||
|
best choice of glyph is selected by fontconfig and automatically rendered
|
||||||
|
by pango in way that is sensitive to complex text layout (CTL) language
|
||||||
|
issues for each unicode character in this example. Of course, you must
|
||||||
|
have the appropriate TrueType fonts installed to have access to all the
|
||||||
|
required glyphs.
|
||||||
|
|
||||||
|
Translation instructions: The strings to be translated are given by
|
||||||
|
x_label, y_label, alty_label, title_label, and line_label below. The
|
||||||
|
encoding used must be UTF-8.
|
||||||
|
|
||||||
|
The following strings to be translated involve some scientific/mathematical
|
||||||
|
jargon which is now discussed further to help translators.
|
||||||
|
|
||||||
|
(1) dB is a decibel unit, see http://en.wikipedia.org/wiki/Decibel .
|
||||||
|
(2) degrees is an angular measure, see
|
||||||
|
http://en.wikipedia.org/wiki/Degree_(angle) .
|
||||||
|
(3) low-pass filter is one that transmits (passes) low frequencies.
|
||||||
|
(4) pole is in the mathematical sense, see
|
||||||
|
http://en.wikipedia.org/wiki/Pole_(complex_analysis) . "Single Pole"
|
||||||
|
means a particular mathematical transformation of the filter function has
|
||||||
|
a single pole, see
|
||||||
|
http://ccrma.stanford.edu/~jos/filters/Pole_Zero_Analysis_I.html .
|
||||||
|
Furthermore, a single-pole filter must have an inverse square decline
|
||||||
|
(or -20 db/decade). Since the filter plotted here does have that
|
||||||
|
characteristic, it must by definition be a single-pole filter, see also
|
||||||
|
http://www-k.ext.ti.com/SRVS/Data/ti/KnowledgeBases/analog/document/faqs/1p.htm
|
||||||
|
(5) decade represents a factor of 10, see
|
||||||
|
http://en.wikipedia.org/wiki/Decade_(log_scale) .
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
x_label = { "Frequency", "Частота" }
|
||||||
|
y_label = { "Amplitude (dB)", "Амплитуда (dB)" }
|
||||||
|
alty_label = { "Phase shift (degrees)", "Фазовый сдвиг (градусы)" }
|
||||||
|
title_label = { "Single Pole Low-Pass Filter", "Однополюсный Низко-Частотный Фильтр" }
|
||||||
|
line_label = { "-20 dB/decade", "-20 dB/десяток" }
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- plot1
|
||||||
|
--
|
||||||
|
-- Log-linear plot.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function plot1(typ, x_label, y_label, alty_label, title_label, line_label)
|
||||||
|
freql = {}
|
||||||
|
ampl = {}
|
||||||
|
phase = {}
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Set up data for log plot
|
||||||
|
|
||||||
|
f0 = 1
|
||||||
|
for i = 1, 101 do
|
||||||
|
freql[i] = -2 + (i-1)/20
|
||||||
|
freq = 10^freql[i]
|
||||||
|
ampl[i] = 20 * math.log10(1/math.sqrt(1+(freq/f0)^2))
|
||||||
|
phase[i] = -180/math.pi*math.atan(freq/f0)
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.vpor(0.15, 0.85, 0.1, 0.9)
|
||||||
|
pl.wind(-2, 3, -80, 0)
|
||||||
|
|
||||||
|
-- Try different axis and labelling styles.
|
||||||
|
pl.col0(1)
|
||||||
|
if typ==0 then
|
||||||
|
pl.box("bclnst", 0, 0, "bnstv", 0, 0)
|
||||||
|
else
|
||||||
|
pl.box("bcfghlnst", 0, 0, "bcghnstv", 0, 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Plot ampl vs freq
|
||||||
|
pl.col0(2)
|
||||||
|
pl.line(freql, ampl)
|
||||||
|
pl.col0(1)
|
||||||
|
pl.ptex(1.6, -30, 1, -20, 0.5, line_label)
|
||||||
|
|
||||||
|
-- Put labels on
|
||||||
|
pl.col0(1)
|
||||||
|
pl.mtex("b", 3.2, 0.5, 0.5, x_label)
|
||||||
|
pl.mtex("t", 2, 0.5, 0.5, title_label)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.mtex("l", 5, 0.5, 0.5, y_label)
|
||||||
|
|
||||||
|
-- For the gridless case, put phase vs freq on same plot
|
||||||
|
if typ==0 then
|
||||||
|
pl.col0(1)
|
||||||
|
pl.wind(-2, 3, -100, 0)
|
||||||
|
pl.box("", 0, 0, "cmstv", 30, 3)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.line(freql, phase)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.mtex("r", 5, 0.5, 0.5, alty_label)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Illustration of logarithmic axes, and redefinition of window.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
pl.font(2)
|
||||||
|
|
||||||
|
-- Make log plots using two different styles.
|
||||||
|
for i = 1, 2 do
|
||||||
|
plot1(0, x_label[i], y_label[i], alty_label[i], title_label[i], line_label[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
129
nanonote-example-files/files/lua-plplot-examples/x27.lua
Normal file
129
nanonote-example-files/files/lua-plplot-examples/x27.lua
Normal file
@ -0,0 +1,129 @@
|
|||||||
|
--[[ $Id: x27.lua 9526 2009-02-13 22:06:13Z smekal $
|
||||||
|
|
||||||
|
Drawing "spirograph" curves - epitrochoids, cycolids, roulettes
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
|
||||||
|
function cycloid()
|
||||||
|
-- TODO
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function spiro( params )
|
||||||
|
NPNT = 20000
|
||||||
|
xcoord = {}
|
||||||
|
ycoord = {}
|
||||||
|
|
||||||
|
-- Fill the coordinates
|
||||||
|
windings = params[4]
|
||||||
|
steps = math.floor(NPNT/windings)
|
||||||
|
dphi = 8*math.acos(-1)/steps
|
||||||
|
|
||||||
|
xmin = 0 -- This initialisation is safe!
|
||||||
|
xmax = 0
|
||||||
|
ymin = 0
|
||||||
|
ymax = 0
|
||||||
|
|
||||||
|
for i = 1, windings*steps+1 do
|
||||||
|
phi = (i-1) * dphi
|
||||||
|
phiw = (params[1]-params[2])/params[2]*phi
|
||||||
|
xcoord[i] = (params[1]-params[2])*math.cos(phi) + params[3]*math.cos(phiw)
|
||||||
|
ycoord[i] = (params[1]-params[2])*math.sin(phi) - params[3]*math.sin(phiw)
|
||||||
|
|
||||||
|
if xmin>xcoord[i] then xmin = xcoord[i] end
|
||||||
|
if xmax<xcoord[i] then xmax = xcoord[i] end
|
||||||
|
if ymin>ycoord[i] then ymin = ycoord[i] end
|
||||||
|
if ymax<ycoord[i] then ymax = ycoord[i] end
|
||||||
|
end
|
||||||
|
|
||||||
|
if (xmax-xmin)>(ymax-ymin) then
|
||||||
|
scale = xmax - xmin
|
||||||
|
else
|
||||||
|
scale = ymax - ymin
|
||||||
|
end
|
||||||
|
xmin = -0.65*scale
|
||||||
|
xmax = 0.65*scale
|
||||||
|
ymin = -0.65*scale
|
||||||
|
ymax = 0.65*scale
|
||||||
|
|
||||||
|
pl.wind(xmin, xmax, ymin, ymax)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
pl.line(xcoord, ycoord)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Generates two kinds of plots:
|
||||||
|
-- - construction of a cycloid (animated)
|
||||||
|
-- - series of epitrochoids and hypotrochoids
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- R, r, p, N
|
||||||
|
params = {
|
||||||
|
{ 21, 7, 7, 3 }, -- Deltoid
|
||||||
|
{ 21, 7, 10, 3 },
|
||||||
|
{ 21, -7, 10, 3 },
|
||||||
|
{ 20, 3, 7, 20 },
|
||||||
|
{ 20, 3, 10, 20 },
|
||||||
|
{ 20, -3, 10, 20 },
|
||||||
|
{ 20, 13, 7, 20 },
|
||||||
|
{ 20, 13, 20, 20 },
|
||||||
|
{ 20,-13, 20, 20 } }
|
||||||
|
|
||||||
|
-- plplot initialization
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Illustrate the construction of a cycloid
|
||||||
|
cycloid()
|
||||||
|
|
||||||
|
-- Loop over the various curves
|
||||||
|
-- First an overview, then all curves one by one
|
||||||
|
|
||||||
|
pl.ssub(3, 3) -- Three by three window
|
||||||
|
|
||||||
|
for i = 1, 9 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 1)
|
||||||
|
spiro(params[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.ssub(1, 1) -- One window per curve
|
||||||
|
|
||||||
|
for i = 1, 9 do
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 1)
|
||||||
|
spiro(params[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Don't forget to call plend() to finish off!
|
||||||
|
pl.plend()
|
376
nanonote-example-files/files/lua-plplot-examples/x28.lua
Normal file
376
nanonote-example-files/files/lua-plplot-examples/x28.lua
Normal file
@ -0,0 +1,376 @@
|
|||||||
|
--[[ $Id: x28.lua 10710 2009-12-08 06:51:27Z airwin $
|
||||||
|
|
||||||
|
pl.mtex3, plptex3 demo.
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
-- Choose these values to correspond to tick marks.
|
||||||
|
XPTS = 2
|
||||||
|
YPTS = 2
|
||||||
|
NREVOLUTION = 16
|
||||||
|
NROTATION = 8
|
||||||
|
NSHEAR = 8
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Demonstrates plotting text in 3D.
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
xmin=0
|
||||||
|
xmax=1
|
||||||
|
xmid = 0.5*(xmax + xmin)
|
||||||
|
xrange = xmax - xmin
|
||||||
|
ymin=0
|
||||||
|
ymax=1
|
||||||
|
ymid = 0.5*(ymax + ymin)
|
||||||
|
yrange = ymax - ymin
|
||||||
|
zmin=0
|
||||||
|
zmax=1
|
||||||
|
zmid = 0.5*(zmax + zmin)
|
||||||
|
zrange = zmax - zmin
|
||||||
|
ysmin = ymin + 0.1 * yrange
|
||||||
|
ysmax = ymax - 0.1 * yrange
|
||||||
|
ysrange = ysmax - ysmin
|
||||||
|
dysrot = ysrange / ( NROTATION - 1 )
|
||||||
|
dysshear = ysrange / ( NSHEAR - 1 )
|
||||||
|
zsmin = zmin + 0.1 * zrange
|
||||||
|
zsmax = zmax - 0.1 * zrange
|
||||||
|
zsrange = zsmax - zsmin
|
||||||
|
dzsrot = zsrange / ( NROTATION - 1 )
|
||||||
|
dzsshear = zsrange / ( NSHEAR - 1 )
|
||||||
|
|
||||||
|
pstring = "The future of our civilization depends on software freedom."
|
||||||
|
|
||||||
|
-- Allocate and define the minimal x, y, and z to insure 3D box
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
z = {}
|
||||||
|
|
||||||
|
for i = 1, XPTS do
|
||||||
|
x[i] = xmin + (i-1) * (xmax-xmin)/(XPTS-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
for j = 1, YPTS do
|
||||||
|
y[j] = ymin + (j-1) * (ymax-ymin)/(YPTS-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, XPTS do
|
||||||
|
z[i] = {}
|
||||||
|
for j = 1, YPTS do
|
||||||
|
z[i][j] = 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Page 1: Demonstrate inclination and shear capability pattern.
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(-0.15, 1.15, -0.05, 1.05)
|
||||||
|
pl.wind(-1.2, 1.2, -0.8, 1.5)
|
||||||
|
pl.w3d(1, 1, 1, xmin, xmax, ymin, ymax, zmin, zmax, 20, 45)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box3("b", "", xmax-xmin, 0,
|
||||||
|
"b", "", ymax-ymin, 0,
|
||||||
|
"bcd", "", zmax-zmin, 0)
|
||||||
|
|
||||||
|
-- z = zmin.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
for i = 1, NREVOLUTION do
|
||||||
|
omega = 2*math.pi*(i-1)/NREVOLUTION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
x_inclination = 0.5*xrange*cos_omega
|
||||||
|
y_inclination = 0.5*yrange*sin_omega
|
||||||
|
z_inclination = 0
|
||||||
|
x_shear = -0.5*xrange*sin_omega
|
||||||
|
y_shear = 0.5*yrange*cos_omega
|
||||||
|
z_shear = 0
|
||||||
|
pl.ptex3( xmid, ymid, zmin, x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear, 0, " revolution")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- x = xmax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
for i = 1, NREVOLUTION do
|
||||||
|
omega = 2.*math.pi*(i-1)/NREVOLUTION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
x_inclination = 0.
|
||||||
|
y_inclination = -0.5*yrange*cos_omega
|
||||||
|
z_inclination = 0.5*zrange*sin_omega
|
||||||
|
x_shear = 0
|
||||||
|
y_shear = 0.5*yrange*sin_omega
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
pl.ptex3(xmax, ymid, zmid, x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear, 0, " revolution")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- y = ymax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
for i = 1, NREVOLUTION do
|
||||||
|
omega = 2.*math.pi*(i-1)/NREVOLUTION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
x_inclination = 0.5*xrange*cos_omega
|
||||||
|
y_inclination = 0.
|
||||||
|
z_inclination = 0.5*zrange*sin_omega
|
||||||
|
x_shear = -0.5*xrange*sin_omega
|
||||||
|
y_shear = 0.
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
pl.ptex3(xmid, ymax, zmid, x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear, 0, " revolution")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw minimal 3D grid to finish defining the 3D box.
|
||||||
|
pl.mesh(x, y, z, pl.DRAW_LINEXY)
|
||||||
|
|
||||||
|
-- Page 2: Demonstrate rotation of string around its axis.
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(-0.15, 1.15, -0.05, 1.05)
|
||||||
|
pl.wind(-1.2, 1.2, -0.8, 1.5)
|
||||||
|
pl.w3d(1, 1, 1, xmin, xmax, ymin, ymax, zmin, zmax, 20, 45)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box3("b", "", xmax-xmin, 0,
|
||||||
|
"b", "", ymax-ymin, 0,
|
||||||
|
"bcd", "", zmax-zmin, 0)
|
||||||
|
|
||||||
|
-- y = ymax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 1
|
||||||
|
y_inclination = 0
|
||||||
|
z_inclination = 0
|
||||||
|
x_shear = 0
|
||||||
|
for i = 1, NROTATION do
|
||||||
|
omega = 2.*math.pi*(i-1)/NROTATION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
y_shear = 0.5*yrange*sin_omega
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
zs = zsmax - dzsrot * (i-1)
|
||||||
|
pl.ptex3(xmid, ymax, zs,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "rotation for y = y#dmax#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- x = xmax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 0
|
||||||
|
y_inclination = -1
|
||||||
|
z_inclination = 0
|
||||||
|
y_shear = 0
|
||||||
|
for i = 1, NROTATION do
|
||||||
|
omega = 2.*math.pi*(i-1)/NROTATION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
x_shear = 0.5*xrange*sin_omega
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
zs = zsmax - dzsrot * (i-1)
|
||||||
|
pl.ptex3(xmax, ymid, zs,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "rotation for x = x#dmax#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- z = zmin.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 1
|
||||||
|
y_inclination = 0
|
||||||
|
z_inclination = 0
|
||||||
|
x_shear = 0
|
||||||
|
for i = 1, NROTATION do
|
||||||
|
omega = 2.*math.pi*(i-1)/NROTATION
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
y_shear = 0.5*yrange*cos_omega
|
||||||
|
z_shear = 0.5*zrange*sin_omega
|
||||||
|
ys = ysmax - dysrot * (i-1)
|
||||||
|
pl.ptex3(xmid, ys, zmin,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "rotation for z = z#dmin#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw minimal 3D grid to finish defining the 3D box.
|
||||||
|
pl.mesh(x, y, z, pl.DRAW_LINEXY)
|
||||||
|
|
||||||
|
-- Page 3: Demonstrate shear of string along its axis.
|
||||||
|
-- Work around xcairo and pngcairo (but not pscairo) problems for
|
||||||
|
-- shear vector too close to axis of string. (N.B. no workaround
|
||||||
|
-- would be domega = 0.)
|
||||||
|
domega = 0.05
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(-0.15, 1.15, -0.05, 1.05)
|
||||||
|
pl.wind(-1.2, 1.2, -0.8, 1.5)
|
||||||
|
pl.w3d(1, 1, 1, xmin, xmax, ymin, ymax, zmin, zmax, 20, 45)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box3("b", "", xmax-xmin, 0,
|
||||||
|
"b", "", ymax-ymin, 0,
|
||||||
|
"bcd", "", zmax-zmin, 0)
|
||||||
|
|
||||||
|
-- y = ymax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 1
|
||||||
|
y_inclination = 0
|
||||||
|
z_inclination = 0
|
||||||
|
y_shear = 0
|
||||||
|
for i = 1, NSHEAR do
|
||||||
|
omega = domega + 2.*math.pi*(i-1)/NSHEAR
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
x_shear = 0.5*xrange*sin_omega
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
zs = zsmax - dzsshear * (i-1)
|
||||||
|
pl.ptex3(xmid, ymax, zs,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "shear for y = y#dmax#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- x = xmax.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 0
|
||||||
|
y_inclination = -1
|
||||||
|
z_inclination = 0
|
||||||
|
x_shear = 0
|
||||||
|
for i = 1, NSHEAR do
|
||||||
|
omega = domega + 2.*math.pi*(i-1)/NSHEAR
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
y_shear = -0.5*yrange*sin_omega
|
||||||
|
z_shear = 0.5*zrange*cos_omega
|
||||||
|
zs = zsmax - dzsshear * (i-1)
|
||||||
|
pl.ptex3(xmax, ymid, zs,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "shear for x = x#dmax#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- z = zmin.
|
||||||
|
pl.schr(0, 1)
|
||||||
|
x_inclination = 1
|
||||||
|
y_inclination = 0
|
||||||
|
z_inclination = 0
|
||||||
|
z_shear = 0
|
||||||
|
for i = 1, NSHEAR do
|
||||||
|
omega = domega + 2.*math.pi*(i-1)/NSHEAR
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
y_shear = 0.5*yrange*cos_omega
|
||||||
|
x_shear = 0.5*xrange*sin_omega
|
||||||
|
ys = ysmax - dysshear * (i-1)
|
||||||
|
pl.ptex3(xmid, ys, zmin,
|
||||||
|
x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear,
|
||||||
|
0.5, "shear for z = z#dmin#u")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw minimal 3D grid to finish defining the 3D box.
|
||||||
|
pl.mesh(x, y, z, pl.DRAW_LINEXY)
|
||||||
|
|
||||||
|
-- Page 4: Demonstrate drawing a string on a 3D path.
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(-0.15, 1.15, -0.05, 1.05)
|
||||||
|
pl.wind(-1.2, 1.2, -0.8, 1.5)
|
||||||
|
pl.w3d(1, 1, 1, xmin, xmax, ymin, ymax, zmin, zmax, 40, -30)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box3("b", "", xmax-xmin, 0,
|
||||||
|
"b", "", ymax-ymin, 0,
|
||||||
|
"bcd", "", zmax-zmin, 0)
|
||||||
|
|
||||||
|
pl.schr(0, 1.2)
|
||||||
|
-- domega controls the spacing between the various characters of the
|
||||||
|
-- string and also the maximum value of omega for the given number
|
||||||
|
-- of characters in *pstring.
|
||||||
|
domega = 2.*math.pi/string.len(pstring)
|
||||||
|
omega = 0
|
||||||
|
|
||||||
|
-- 3D function is a helix of the given radius and pitch
|
||||||
|
radius = 0.5
|
||||||
|
pitch = 1/(2*math.pi)
|
||||||
|
|
||||||
|
for i = 1, string.len(pstring) do
|
||||||
|
sin_omega = math.sin(omega)
|
||||||
|
cos_omega = math.cos(omega)
|
||||||
|
xpos = xmid + radius*sin_omega
|
||||||
|
ypos = ymid - radius*cos_omega
|
||||||
|
zpos = zmin + pitch*omega
|
||||||
|
|
||||||
|
-- In general, the inclination is proportional to the derivative of
|
||||||
|
--the position wrt theta.
|
||||||
|
x_inclination = radius*cos_omega
|
||||||
|
y_inclination = radius*sin_omega
|
||||||
|
z_inclination = pitch
|
||||||
|
|
||||||
|
-- The shear vector should be perpendicular to the 3D line with Z
|
||||||
|
-- component maximized, but for low pitch a good approximation is
|
||||||
|
--a constant vector that is parallel to the Z axis.
|
||||||
|
x_shear = 0
|
||||||
|
y_shear = 0
|
||||||
|
z_shear = 1
|
||||||
|
pl.ptex3(xpos, ypos, zpos, x_inclination, y_inclination, z_inclination,
|
||||||
|
x_shear, y_shear, z_shear, 0.5, string.sub(pstring, i, i))
|
||||||
|
omega = omega + domega
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Draw minimal 3D grid to finish defining the 3D box.
|
||||||
|
pl.mesh(x, y, z, pl.DRAW_LINEXY)
|
||||||
|
|
||||||
|
-- Page 5: Demonstrate pl.mtex3 axis labelling capability
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(-0.15, 1.15, -0.05, 1.05)
|
||||||
|
pl.wind(-1.2, 1.2, -0.8, 1.5)
|
||||||
|
pl.w3d(1, 1, 1, xmin, xmax, ymin, ymax, zmin, zmax, 20, 45)
|
||||||
|
|
||||||
|
pl.col0(2)
|
||||||
|
pl.box3("b", "", xmax-xmin, 0,
|
||||||
|
"b", "", ymax-ymin, 0,
|
||||||
|
"bcd", "", zmax-zmin, 0)
|
||||||
|
|
||||||
|
pl.schr(0, 1)
|
||||||
|
pl.mtex3("xp", 3, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("xp", 4.5, 0.5, 0.5, "primary X-axis label")
|
||||||
|
pl.mtex3("xs", -2.5, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("xs", -1, 0.5, 0.5, "secondary X-axis label")
|
||||||
|
pl.mtex3("yp", 3, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("yp", 4.5, 0.5, 0.5, "primary Y-axis label")
|
||||||
|
pl.mtex3("ys", -2.5, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("ys", -1, 0.5, 0.5, "secondary Y-axis label")
|
||||||
|
pl.mtex3("zp", 4.5, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("zp", 3, 0.5, 0.5, "primary Z-axis label")
|
||||||
|
pl.mtex3("zs", -2.5, 0.5, 0.5, "Arbitrarily displaced")
|
||||||
|
pl.mtex3("zs", -1, 0.5, 0.5, "secondary Z-axis label")
|
||||||
|
|
||||||
|
-- Draw minimal 3D grid to finish defining the 3D box.
|
||||||
|
pl.mesh(x, y, z, pl.DRAW_LINEXY)
|
||||||
|
|
||||||
|
pl.plend()
|
327
nanonote-example-files/files/lua-plplot-examples/x29.lua
Normal file
327
nanonote-example-files/files/lua-plplot-examples/x29.lua
Normal file
@ -0,0 +1,327 @@
|
|||||||
|
--[[ $Id: x29.lua 10299 2009-08-19 17:54:27Z smekal $
|
||||||
|
|
||||||
|
Sample plots using date / time formatting for axes
|
||||||
|
|
||||||
|
Copyright (C) 2009 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
-- Plot a model diurnal cycle of temperature
|
||||||
|
function plot1()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
xerr1 = {}
|
||||||
|
xerr2 = {}
|
||||||
|
yerr1 = {}
|
||||||
|
yerr2 = {}
|
||||||
|
-- Data points every 10 minutes for 1 day
|
||||||
|
npts = 73
|
||||||
|
|
||||||
|
xmin = 0
|
||||||
|
xmax = 60*60*24 -- Number of seconds in a day
|
||||||
|
ymin = 10
|
||||||
|
ymax = 20
|
||||||
|
|
||||||
|
for i = 1, npts do
|
||||||
|
x[i] = xmax*((i-1)/npts)
|
||||||
|
y[i] = 15 - 5*math.cos(2*math.pi*((i-1)/npts))
|
||||||
|
-- Set x error bars to +/- 5 minute
|
||||||
|
xerr1[i] = x[i]-60*5
|
||||||
|
xerr2[i] = x[i]+60*5
|
||||||
|
-- Set y error bars to +/- 0.1 deg C
|
||||||
|
yerr1[i] = y[i]-0.1
|
||||||
|
yerr2[i] = y[i]+0.1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
-- Rescale major ticks marks by 0.5
|
||||||
|
pl.smaj(0, 0.5)
|
||||||
|
-- Rescale minor ticks and error bar marks by 0.5
|
||||||
|
pl.smin(0, 0.5)
|
||||||
|
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(xmin, xmax, ymin, ymax)
|
||||||
|
|
||||||
|
-- Draw a box with ticks spaced every 3 hour in X and 1 degree C in Y.
|
||||||
|
pl.col0(1)
|
||||||
|
-- Set time format to be hours:minutes
|
||||||
|
pl.timefmt("%H:%M")
|
||||||
|
pl.box("bcnstd", 3*60*60, 3, "bcnstv", 1, 5)
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lab("Time (hours:mins)", "Temperature (degC)", "@frPLplot Example 29 - Daily temperature")
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
|
||||||
|
pl.line(x, y)
|
||||||
|
pl.col0(2)
|
||||||
|
pl.errx(xerr1, xerr2, y)
|
||||||
|
pl.col0(3)
|
||||||
|
pl.erry(x, yerr1, yerr2)
|
||||||
|
|
||||||
|
-- Rescale major / minor tick marks back to default
|
||||||
|
pl.smin(0, 1)
|
||||||
|
pl.smaj(0, 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Plot the number of hours of daylight as a function of day for a year
|
||||||
|
function plot2()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
-- Latitude for London
|
||||||
|
lat = 51.5
|
||||||
|
|
||||||
|
npts = 365
|
||||||
|
|
||||||
|
xmin = 0
|
||||||
|
xmax = npts*60*60*24
|
||||||
|
ymin = 0
|
||||||
|
ymax = 24
|
||||||
|
|
||||||
|
-- Formula for hours of daylight from
|
||||||
|
-- "A Model Comparison for Daylength as a Function of Latitude and
|
||||||
|
-- Day of the Year", 1995, Ecological Modelling, 80, pp 87-95.
|
||||||
|
for j = 1, npts do
|
||||||
|
x[j] = (j-1)*60*60*24
|
||||||
|
p = math.asin(0.39795*math.cos(0.2163108 + 2*math.atan(0.9671396*math.tan(0.00860*(j-1-186)))))
|
||||||
|
d = 24 - (24/math.pi)*
|
||||||
|
math.acos( (math.sin(0.8333*math.pi/180) + math.sin(lat*math.pi/180)*math.sin(p)) /
|
||||||
|
(math.cos(lat*math.pi/180)*math.cos(p)) )
|
||||||
|
y[j] = d
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
-- Set time format to be abbreviated month name followed by day of month
|
||||||
|
pl.timefmt("%b %d")
|
||||||
|
pl.prec(1, 1)
|
||||||
|
pl.env(xmin, xmax, ymin, ymax, 0, 40)
|
||||||
|
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lab("Date", "Hours of daylight", "@frPLplot Example 29 - Hours of daylight at 51.5N")
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
|
||||||
|
pl.line(x, y)
|
||||||
|
|
||||||
|
pl.prec(0, 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot3()
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
tstart = 1133395200
|
||||||
|
|
||||||
|
npts = 62
|
||||||
|
|
||||||
|
xmin = tstart
|
||||||
|
xmax = xmin + npts*60*60*24
|
||||||
|
ymin = 0
|
||||||
|
ymax = 5
|
||||||
|
|
||||||
|
for i = 1, npts do
|
||||||
|
x[i] = xmin + (i-1)*60*60*24
|
||||||
|
y[i] = 1 + math.sin(2*math.pi*(i-1)/7) + math.exp(math.min(i-1,npts-i+1)/31)
|
||||||
|
end
|
||||||
|
pl.adv(0)
|
||||||
|
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(xmin, xmax, ymin, ymax)
|
||||||
|
|
||||||
|
pl.col0(1)
|
||||||
|
-- Set time format to be ISO 8601 standard YYYY-MM-DD. Note that this is
|
||||||
|
--equivalent to %f for C99 compliant implementations of strftime.
|
||||||
|
pl.timefmt("%Y-%m-%d")
|
||||||
|
-- Draw a box with ticks spaced every 14 days in X and 1 hour in Y.
|
||||||
|
pl.box("bcnstd", 14*24*60*60,14, "bcnstv", 1, 4)
|
||||||
|
|
||||||
|
pl.col0(3)
|
||||||
|
pl.lab("Date", "Hours of television watched", "@frPLplot Example 29 - Hours of television watched in Dec 2005 / Jan 2006")
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
|
||||||
|
-- Rescale symbol size (used by plpoin) by 0.5
|
||||||
|
pl.ssym(0, 0.5)
|
||||||
|
pl.poin(x, y, 2)
|
||||||
|
pl.line(x, y)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function plot4()
|
||||||
|
-- TAI-UTC (seconds) as a function of time.
|
||||||
|
-- Use Besselian epochs as the continuous time interval just to prove
|
||||||
|
-- this does not introduce any issues.
|
||||||
|
|
||||||
|
x = {}
|
||||||
|
y = {}
|
||||||
|
|
||||||
|
-- Use the definition given in http://en.wikipedia.org/wiki/Besselian_epoch
|
||||||
|
-- B = 1900. + (JD -2415020.31352)/365.242198781
|
||||||
|
-- ==> (as calculated with aid of "bc -l" command)
|
||||||
|
-- B = (MJD + 678940.364163900)/365.242198781
|
||||||
|
-- ==>
|
||||||
|
-- MJD = B*365.24219878 - 678940.364163900
|
||||||
|
scale = 365.242198781
|
||||||
|
offset1 = -678940
|
||||||
|
offset2 = -0.3641639
|
||||||
|
pl.configtime(scale, offset1, offset2, 0, 0, 0, 0, 0, 0, 0, 0.)
|
||||||
|
|
||||||
|
for kind = 0, 6 do
|
||||||
|
if kind == 0 then
|
||||||
|
xmin = pl.ctime(1950, 0, 2, 0, 0, 0)
|
||||||
|
xmax = pl.ctime(2020, 0, 2, 0, 0, 0)
|
||||||
|
npts = 70*12 + 1
|
||||||
|
ymin = 0
|
||||||
|
ymax = 36
|
||||||
|
time_format = "%Y%"
|
||||||
|
if_TAI_time_format = 1
|
||||||
|
title_suffix = "from 1950 to 2020"
|
||||||
|
xtitle = "Year"
|
||||||
|
xlabel_step = 10
|
||||||
|
end
|
||||||
|
if kind==1 or kind==2 then
|
||||||
|
xmin = pl.ctime(1961, 7, 1, 0, 0, 1.64757-0.20)
|
||||||
|
xmax = pl.ctime(1961, 7, 1, 0, 0, 1.64757+0.20)
|
||||||
|
npts = 1001
|
||||||
|
ymin = 1.625
|
||||||
|
ymax = 1.725
|
||||||
|
time_format = "%S%2%"
|
||||||
|
title_suffix = "near 1961-08-01 (TAI)"
|
||||||
|
xlabel_step = 0.05/(scale*86400)
|
||||||
|
if kind==1 then
|
||||||
|
if_TAI_time_format = 1
|
||||||
|
xtitle = "Seconds (TAI)"
|
||||||
|
else
|
||||||
|
if_TAI_time_format = 0
|
||||||
|
xtitle = "Seconds (TAI) labelled with corresponding UTC"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if kind==3 or kind==4 then
|
||||||
|
xmin = pl.ctime(1963, 10, 1, 0, 0, 2.6972788-0.20)
|
||||||
|
xmax = pl.ctime(1963, 10, 1, 0, 0, 2.6972788+0.20)
|
||||||
|
npts = 1001
|
||||||
|
ymin = 2.55
|
||||||
|
ymax = 2.75
|
||||||
|
time_format = "%S%2%"
|
||||||
|
title_suffix = "near 1963-11-01 (TAI)"
|
||||||
|
xlabel_step = 0.05/(scale*86400)
|
||||||
|
if kind==3 then
|
||||||
|
if_TAI_time_format = 1
|
||||||
|
xtitle = "Seconds (TAI)"
|
||||||
|
else
|
||||||
|
if_TAI_time_format = 0
|
||||||
|
xtitle = "Seconds (TAI) labelled with corresponding UTC"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if kind==5 or kind==6 then
|
||||||
|
xmin = pl.ctime(2009, 0, 1, 0, 0, 34-5)
|
||||||
|
xmax = pl.ctime(2009, 0, 1, 0, 0, 34+5)
|
||||||
|
npts = 1001
|
||||||
|
ymin = 32.5
|
||||||
|
ymax = 34.5
|
||||||
|
time_format = "%S%2%"
|
||||||
|
title_suffix = "near 2009-01-01 (TAI)"
|
||||||
|
xlabel_step = 1/(scale*86400)
|
||||||
|
if kind==5 then
|
||||||
|
if_TAI_time_format = 1
|
||||||
|
xtitle = "Seconds (TAI)"
|
||||||
|
else
|
||||||
|
if_TAI_time_format = 0
|
||||||
|
xtitle = "Seconds (TAI) labelled with corresponding UTC"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, npts do
|
||||||
|
x[i] = xmin + (i-1)*(xmax-xmin)/(npts-1)
|
||||||
|
pl.configtime(scale, offset1, offset2, 0, 0, 0, 0, 0, 0, 0, 0)
|
||||||
|
tai = x[i]
|
||||||
|
tai_year, tai_month, tai_day, tai_hour, tai_min, tai_sec = pl.btime(tai)
|
||||||
|
pl.configtime(scale, offset1, offset2, 2, 0, 0, 0, 0, 0, 0, 0)
|
||||||
|
utc_year, utc_month, utc_day, utc_hour, utc_min, utc_sec = pl.btime(tai)
|
||||||
|
pl.configtime(scale, offset1, offset2, 0, 0, 0, 0, 0, 0, 0, 0.)
|
||||||
|
utc = pl.ctime(utc_year, utc_month, utc_day, utc_hour, utc_min, utc_sec)
|
||||||
|
y[i]=(tai-utc)*scale*86400.
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vsta()
|
||||||
|
pl.wind(xmin, xmax, ymin, ymax)
|
||||||
|
pl.col0(1)
|
||||||
|
if if_TAI_time_format ~= 0 then
|
||||||
|
pl.configtime(scale, offset1, offset2, 0, 0, 0, 0, 0, 0, 0, 0)
|
||||||
|
else
|
||||||
|
pl.configtime(scale, offset1, offset2, 2, 0, 0, 0, 0, 0, 0, 0)
|
||||||
|
end
|
||||||
|
pl.timefmt(time_format)
|
||||||
|
pl.box("bcnstd", xlabel_step, 0, "bcnstv", 0., 0)
|
||||||
|
pl.col0(3)
|
||||||
|
title = "@frPLplot Example 29 - TAI-UTC " .. title_suffix
|
||||||
|
pl.lab(xtitle, "TAI-UTC (sec)", title)
|
||||||
|
|
||||||
|
pl.col0(4)
|
||||||
|
|
||||||
|
pl.line(x, y)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
-- main
|
||||||
|
--
|
||||||
|
-- Draws several plots which demonstrate the use of date / time formats for
|
||||||
|
-- the axis labels.
|
||||||
|
-- Time formatting is done using the system strftime routine. See the
|
||||||
|
-- documentation of this for full details of the available formats.
|
||||||
|
--
|
||||||
|
-- 1) Plotting temperature over a day (using hours / minutes)
|
||||||
|
-- 2) Plotting
|
||||||
|
--
|
||||||
|
-- Note: Times are stored as seconds since the epoch (usually 1st Jan 1970).
|
||||||
|
--
|
||||||
|
----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- Parse command line arguments
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Change the escape character to a '@' instead of the default '#'
|
||||||
|
pl.sesc('@')
|
||||||
|
|
||||||
|
plot1()
|
||||||
|
|
||||||
|
plot2()
|
||||||
|
|
||||||
|
plot3()
|
||||||
|
|
||||||
|
plot4()
|
||||||
|
|
||||||
|
-- Don't forget to call plend() to finish off!
|
||||||
|
pl.plend()
|
137
nanonote-example-files/files/lua-plplot-examples/x30.lua
Normal file
137
nanonote-example-files/files/lua-plplot-examples/x30.lua
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
--[[ $Id: x30.lua 10668 2009-12-02 08:38:49Z airwin $
|
||||||
|
|
||||||
|
Alpha color values demonstration.
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
red = { 0, 255, 0, 0 }
|
||||||
|
green = { 0, 0, 255, 0 }
|
||||||
|
blue = { 0, 0, 0, 255 }
|
||||||
|
alpha = { 1, 1, 1, 1 }
|
||||||
|
|
||||||
|
px = { 0.1, 0.5, 0.5, 0.1 }
|
||||||
|
py = { 0.1, 0.1, 0.5, 0.5 }
|
||||||
|
|
||||||
|
pos = { 0, 1 }
|
||||||
|
rcoord = { 1, 1 }
|
||||||
|
gcoord = { 0, 0 }
|
||||||
|
bcoord = { 0, 0 }
|
||||||
|
acoord = { 0, 1 }
|
||||||
|
rev = { 0, 0 }
|
||||||
|
|
||||||
|
pl.parseopts (arg, pl.PL_PARSE_FULL);
|
||||||
|
|
||||||
|
pl.init()
|
||||||
|
pl.scmap0n(4)
|
||||||
|
pl.scmap0a(red, green, blue, alpha)
|
||||||
|
|
||||||
|
-- Page 1:
|
||||||
|
--
|
||||||
|
-- This is a series of red, green and blue rectangles overlaid
|
||||||
|
-- on each other with gradually increasing transparency.
|
||||||
|
|
||||||
|
-- Set up the window
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0, 1, 0, 1)
|
||||||
|
pl.wind(0, 1, 0, 1)
|
||||||
|
pl.col0(0)
|
||||||
|
pl.box("", 1, 0, "", 1, 0)
|
||||||
|
|
||||||
|
-- Draw the boxes
|
||||||
|
for i = 0, 8 do
|
||||||
|
icol = math.mod(i, 3) + 1
|
||||||
|
|
||||||
|
-- Get a color, change its transparency and
|
||||||
|
-- set it as the current color.
|
||||||
|
r, g, b, a = pl.gcol0a(icol)
|
||||||
|
pl.scol0a(icol, r, g, b, 1-i/9)
|
||||||
|
pl.col0(icol)
|
||||||
|
|
||||||
|
-- Draw the rectangle
|
||||||
|
pl.fill(px, py)
|
||||||
|
|
||||||
|
-- Shift the rectangles coordinates
|
||||||
|
for j = 1, 4 do
|
||||||
|
px[j] = px[j] + 0.5/9
|
||||||
|
py[j] = py[j] + 0.5/9
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Page 2:
|
||||||
|
|
||||||
|
-- This is a bunch of boxes colored red, green or blue with a single
|
||||||
|
-- large (red) box of linearly varying transparency overlaid. The
|
||||||
|
-- overlaid box is completely transparent at the bottom and completely
|
||||||
|
-- opaque at the top.
|
||||||
|
|
||||||
|
-- Set up the window
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.1, 0.9, 0.1, 0.9)
|
||||||
|
pl.wind(0.0, 1.0, 0.0, 1.0)
|
||||||
|
|
||||||
|
-- Draw the boxes. There are 25 of them drawn on a 5 x 5 grid.
|
||||||
|
for i = 0, 4 do
|
||||||
|
-- Set box X position
|
||||||
|
px[1] = 0.05 + 0.2 * i
|
||||||
|
px[2] = px[1] + 0.1
|
||||||
|
px[3] = px[2]
|
||||||
|
px[4] = px[1]
|
||||||
|
|
||||||
|
-- We don't want the boxes to be transparent, so since we changed
|
||||||
|
-- the colors transparencies in the first example we have to change
|
||||||
|
-- the transparencies back to completely opaque.
|
||||||
|
icol = math.mod(i, 3) + 1
|
||||||
|
r, g, b, a = pl.gcol0a(icol)
|
||||||
|
pl.scol0a(icol, r, g, b, 1)
|
||||||
|
pl.col0(icol)
|
||||||
|
|
||||||
|
for j = 0, 4 do
|
||||||
|
-- Set box y position and draw the box.
|
||||||
|
py[1] = 0.05 + 0.2 * j
|
||||||
|
py[2] = py[1]
|
||||||
|
py[3] = py[1] + 0.1
|
||||||
|
py[4] = py[3]
|
||||||
|
pl.fill(px, py)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Create the color map with 128 colors and use plscmap1la to initialize
|
||||||
|
-- the color values with a linearly varying red transparency (or alpha)
|
||||||
|
pl.scmap1n(128)
|
||||||
|
pl.scmap1la(1, pos, rcoord, gcoord, bcoord, acoord, rev)
|
||||||
|
|
||||||
|
-- Use that cmap1 to create a transparent red gradient for the whole
|
||||||
|
-- window.
|
||||||
|
px[1] = 0.
|
||||||
|
px[2] = 1.
|
||||||
|
px[3] = 1.
|
||||||
|
px[4] = 0.
|
||||||
|
|
||||||
|
py[1] = 0.
|
||||||
|
py[2] = 0.
|
||||||
|
py[3] = 1.
|
||||||
|
py[4] = 1.
|
||||||
|
|
||||||
|
pl.gradient(px, py, 90.)
|
||||||
|
|
||||||
|
pl.plend()
|
225
nanonote-example-files/files/lua-plplot-examples/x31.lua
Normal file
225
nanonote-example-files/files/lua-plplot-examples/x31.lua
Normal file
@ -0,0 +1,225 @@
|
|||||||
|
--[[ $Id: x31.lua 9533 2009-02-16 22:18:37Z smekal $
|
||||||
|
|
||||||
|
Copyright (C) 2008 Werner Smekal
|
||||||
|
|
||||||
|
set/get tester
|
||||||
|
|
||||||
|
This file is part of PLplot.
|
||||||
|
|
||||||
|
PLplot is free software you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Library Public License as published
|
||||||
|
by the Free Software Foundation either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
PLplot is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public License
|
||||||
|
along with PLplot if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
--]]
|
||||||
|
|
||||||
|
|
||||||
|
-- initialise Lua bindings for PLplot examples.
|
||||||
|
dofile("plplot_examples.lua")
|
||||||
|
|
||||||
|
r1 = { 0, 255 }
|
||||||
|
g1 = { 255, 0 }
|
||||||
|
b1 = { 0, 0 }
|
||||||
|
a1 = { 1, 1 }
|
||||||
|
|
||||||
|
-- Parse and process command line arguments
|
||||||
|
status = 0
|
||||||
|
pl.parseopts(arg, pl.PL_PARSE_FULL)
|
||||||
|
|
||||||
|
-- Test setting / getting familying parameters before plinit
|
||||||
|
-- Save values set by plparseopts to be restored later.
|
||||||
|
fam0, num0, bmax0 = pl.gfam()
|
||||||
|
fam1 = 0
|
||||||
|
num1 = 10
|
||||||
|
bmax1 = 1000
|
||||||
|
pl.sfam(fam1, num1, bmax1)
|
||||||
|
|
||||||
|
-- Retrieve the same values?
|
||||||
|
fam2, num2, bmax2 = pl.gfam()
|
||||||
|
print(string.format("family parameters: fam, num, bmax = %d %d %d", fam2, num2, bmax2))
|
||||||
|
if fam2~=fam1 or num2~=num1 or bmax2~=bmax1 then
|
||||||
|
io.stderr:write("plgfam test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
-- Restore values set initially by plparseopts.
|
||||||
|
pl.sfam(fam0, num0, bmax0)
|
||||||
|
|
||||||
|
-- Test setting / getting page parameters before plinit
|
||||||
|
-- Save values set by plparseopts to be restored later.
|
||||||
|
xp0, yp0, xleng0, yleng0, xoff0, yoff0 = pl.gpage()
|
||||||
|
xp1 = 200.
|
||||||
|
yp1 = 200.
|
||||||
|
xleng1 = 400
|
||||||
|
yleng1 = 200
|
||||||
|
xoff1 = 10
|
||||||
|
yoff1 = 20
|
||||||
|
pl.spage(xp1, yp1, xleng1, yleng1, xoff1, yoff1)
|
||||||
|
|
||||||
|
-- Retrieve the same values?
|
||||||
|
xp2, yp2, xleng2, yleng2, xoff2, yoff2 = pl.gpage()
|
||||||
|
print(string.format("page parameters: xp, yp, xleng, yleng, xoff, yoff = %f %f %d %d %d %d", xp2, yp2, xleng2, yleng2, xoff2, yoff2))
|
||||||
|
if xp2~=xp1 or yp2~=yp1 or xleng2~=xleng1 or yleng2~=yleng1 or xoff2~=xoff1 or yoff2~=yoff1 then
|
||||||
|
io.stderr:write("plgpage test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
-- Restore values set initially by plparseopts.
|
||||||
|
pl.spage(xp0, yp0, xleng0, yleng0, xoff0, yoff0)
|
||||||
|
|
||||||
|
-- Test setting / getting compression parameter across plinit.
|
||||||
|
compression1 = 95
|
||||||
|
pl.scompression(compression1)
|
||||||
|
|
||||||
|
-- Initialize plplot
|
||||||
|
pl.init()
|
||||||
|
|
||||||
|
-- Test if device initialization screwed around with the preset
|
||||||
|
-- compression parameter.
|
||||||
|
compression2 = pl.gcompression()
|
||||||
|
print("Output various PLplot parameters")
|
||||||
|
print("compression parameter = " .. compression2)
|
||||||
|
if compression2~=compression1 then
|
||||||
|
io.stderr:write("plgcompression test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- Exercise plscolor, plscol0, plscmap1, and plscmap1a to make sure
|
||||||
|
--they work without any obvious error messages.
|
||||||
|
pl.scolor(1)
|
||||||
|
pl.scol0(1, 255, 0, 0)
|
||||||
|
pl.scmap1(r1, g1, b1)
|
||||||
|
pl.scmap1a(r1, g1, b1, a1)
|
||||||
|
|
||||||
|
level2 = pl.glevel()
|
||||||
|
print("level parameter = " .. level2)
|
||||||
|
if level2~=1 then
|
||||||
|
io.stderr:write("plglevel test failed.\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.adv(0)
|
||||||
|
pl.vpor(0.01, 0.99, 0.02, 0.49)
|
||||||
|
xmin, xmax, ymin, ymax = pl.gvpd()
|
||||||
|
print(string.format("plvpor: xmin, xmax, ymin, ymax = %f %f %f %f", xmin, xmax, ymin, ymax))
|
||||||
|
if xmin~=0.01 or xmax~=0.99 or ymin~=0.02 or ymax~=0.49 then
|
||||||
|
io.stderr:write("plgvpd test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
xmid = 0.5*(xmin+xmax)
|
||||||
|
ymid = 0.5*(ymin+ymax)
|
||||||
|
|
||||||
|
pl.wind(0.2, 0.3, 0.4, 0.5)
|
||||||
|
xmin, xmax, ymin, ymax = pl.gvpw()
|
||||||
|
print(string.format("plwind: xmin, xmax, ymin, ymax = %f %f %f %f", xmin, xmax, ymin, ymax))
|
||||||
|
if xmin~=0.2 or xmax~=0.3 or ymin~=0.4 or ymax~=0.5 then
|
||||||
|
io.stderr:write("plgvpw test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Get world coordinates for middle of viewport
|
||||||
|
wx, wy, win = pl.calc_world(xmid,ymid)
|
||||||
|
print(string.format("world parameters: wx, wy, win = %f %f %d", wx, wy, win))
|
||||||
|
if math.abs(wx-0.5*(xmin+xmax))>1.0e-5 or math.abs(wy-0.5*(ymin+ymax))>1.0e-5 then
|
||||||
|
io.stderr:write("plcalc_world test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Retrieve and print the name of the output file (if any).
|
||||||
|
-- This goes to stderr not stdout since it will vary between tests and
|
||||||
|
-- we want stdout to be identical for compare test.
|
||||||
|
fnam = pl.gfnam()
|
||||||
|
if fnam=="" then
|
||||||
|
print("No output file name is set")
|
||||||
|
else
|
||||||
|
print("Output file name read")
|
||||||
|
end
|
||||||
|
io.stderr:write(string.format("Output file name is %s\n",fnam))
|
||||||
|
|
||||||
|
-- Set and get the number of digits used to display axis labels
|
||||||
|
-- Note digits is currently ignored in pls[xyz]ax and
|
||||||
|
-- therefore it does not make sense to test the returned
|
||||||
|
-- value
|
||||||
|
pl.sxax(3,0)
|
||||||
|
digmax, digits = pl.gxax()
|
||||||
|
print(string.format("x axis parameters: digmax, digits = %d %d", digmax, digits))
|
||||||
|
if digmax~=3 then
|
||||||
|
io.stderr:write("plgxax test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.syax(4,0)
|
||||||
|
digmax, digits = pl.gyax()
|
||||||
|
print(string.format("y axis parameters: digmax, digits = %d %d", digmax, digits))
|
||||||
|
if digmax~=4 then
|
||||||
|
io.stderr:write("plgyax test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.szax(5,0)
|
||||||
|
digmax,digits = pl.gzax()
|
||||||
|
print(string.format("z axis parameters: digmax, digits = %d %d", digmax, digits))
|
||||||
|
if digmax~=5 then
|
||||||
|
io.stderr:write("plgzax test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.sdidev(0.05, pl.PL_NOTSET, 0.1, 0.2)
|
||||||
|
mar, aspect, jx, jy = pl.gdidev()
|
||||||
|
print(string.format("device-space window parameters: mar, aspect, jx, jy = %f %f %f %f" , mar, aspect, jx, jy))
|
||||||
|
if mar~=0.05 or jx~=0.1 or jy~=0.2 then
|
||||||
|
io.stderr:write("plgdidev test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.sdiori(1.0)
|
||||||
|
ori = pl.gdiori()
|
||||||
|
print(string.format("ori parameter = %f", ori))
|
||||||
|
if ori~=1.0 then
|
||||||
|
io.stderr:write("plgdiori test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.sdiplt(0.1, 0.2, 0.9, 0.8)
|
||||||
|
xmin, ymin, xmax, ymax = pl.gdiplt()
|
||||||
|
print(string.format("plot-space window parameters: xmin, ymin, xmax, ymax = %f %f %f %f", xmin, ymin, xmax, ymax))
|
||||||
|
if xmin~=0.1 or xmax~=0.9 or ymin~=0.2 or ymax~=0.8 then
|
||||||
|
io.stderr:write("plgdiplt test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.sdiplz(0.1, 0.1, 0.9, 0.9)
|
||||||
|
zxmin, zymin, zxmax, zymax = pl.gdiplt()
|
||||||
|
print(string.format("zoomed plot-space window parameters: xmin, ymin, xmax, ymax = %f %f %f %f", zxmin, zymin, zxmax, zymax))
|
||||||
|
if math.abs(zxmin -(xmin + (xmax-xmin)*0.1)) > 1.0e-5 or
|
||||||
|
math.abs(zxmax -(xmin+(xmax-xmin)*0.9)) > 1.0e-5 or
|
||||||
|
math.abs(zymin -(ymin+(ymax-ymin)*0.1)) > 1.0e-5 or
|
||||||
|
math.abs(zymax -(ymin+(ymax-ymin)*0.9)) > 1.0e-5 then
|
||||||
|
io.stderr:write("plsdiplz test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.scolbg(10, 20, 30)
|
||||||
|
r, g, b = pl.gcolbg()
|
||||||
|
print(string.format("background colour parameters: r, g, b = %d %d %d", r, g, b))
|
||||||
|
if r~=10 or g~=20 or b~=30 then
|
||||||
|
io.stderr:write("plgcolbg test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.scolbga(20, 30, 40, 0.5)
|
||||||
|
r, g, b, a = pl.gcolbga()
|
||||||
|
print(string.format("background/transparency colour parameters: r, g, b, a = %d %d %d %f", r, g, b, a))
|
||||||
|
if r~=20 or g~=30 or b~=40 or a~=0.5 then
|
||||||
|
io.stderr:write("plgcolbga test failed\n")
|
||||||
|
status = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
pl.plend()
|
Loading…
Reference in New Issue
Block a user