WgSplineTool Procedure 
Graphical User Interface (GUI) that computes a one-dimensional, least-squares spline fit to (possibly noisy) data.
Usage
WgSplineTool[, fit, parent, shell]
Input Parameters
parent—Widget handle of a parent widget. If supplied, it will be used as the parent shell for the tool.
Output Parameters
fit—Structure containing the computed spline. See the introduction of this chapter for a complete description of the spline structure.
shell—Used to pass the shell widget handle for the tool back to the caller.
Input Keywords
XData—One-dimensional array containing the abscissas of the data to be fit. If XData is specified, then YData must also be specified.
YData—One-dimensional array containing ordinates of the data to be fit.
XSize—Width, in pixels, of the draw widget used to display the fit. Keyword XSize must be between 100 and 800. Default: XSize = 600
YSize—Height, in pixels, of the draw widget used to display the fit. Keyword YSize must be between 100 and 800. Default: YSize = 600
Demo_Data—If present and nonzero, sets path to the PV‑WAVE example data directory for importing data. Otherwise, WwFileSelection prompts for input from the same directory from which WgSplineTool was invoked.
Foreground—Specifies the default foreground color name.
Background—Specifies the default background color name.
Font—Specifies the name of the default font used for text.
Position—Specifies the position of the upper-left corner of the main window on the screen.
Title—String specifying shell title. Default is “Constrained Spline Tool.”
Discussion
Procedure WgSplineTool is designed to help compute a least-squares spline fit to (possibly noisy) data. The WgSplineTool procedure computes the fit using function CONLSQ. The default use of WgSplineTool does not require any arguments or keywords and can be used as follows:
WgSplineTool
There are two ways to supply data to WgSplineTool. First, if the data is contained in variables, for example, x and y, invoke WgSplineTool with the following call:
WgSplineTool, XData = x, YData = y
The variables x and y should be one-dimensional arrays of equal length.
The YData keyword can be used without the XData keyword. in this case, it is assumed that the associated x values are monotonically increasing from 0. The call would be as follows:
WgSplineTool, YData = y
The variable y should be a one-dimensional array.
The second method to import data into the application is through an external ASCII file, along with the button labeled Open. The structure of the file is as follows:

The first line contains the total number of (
x, 
y) pairs.

Each line after the first line should contain one (
x, 
y) pair.
For example, the following six lines could be put into a file for use by WgSplineTool:
5
0.0454    3.43245
0.1243    4.45645
0.2454    1.43553
1.2311    1.76543
2.4325    9.53234
Once the data has been imported to the application, the data is automatically fitted with the default choice of knots. After this is accomplished, you have the ability to add the order of the fit, the spline space dimension, and the placement of the knots. To adjust the placement of the knots, simply use the mouse to “click and drag” the knots on the plot (the knot abscissae are the triangles that appear near the bottom of the plot). WgSplineTool returns the last computed fit in the argument fit. 
Use the Save Spline button to save any intermediate fits. After saving the fit, you can restore the spline at a later time into a variable using the following command:
RESTORE, 'filename'
A description of each element of the top-level widget follows. The numbers correspond to the labels in 
Figure 4-15: Spline Fitting Widget:
 1. Plotting Options:
1. Plotting Options: Once a fit has been computed, the following plots can be viewed:

The computed fit.

The first derivative of the computed fit.

The second derivative of the computed fit.
 2. 1st Derivative Constraints:
2. 1st Derivative Constraints: Once a fit has been computed, the following choices for global constraints on the first derivative of the computed fit can be enforced:

Does not enforce any constraints.

Forces the fit to be nondecreasing, i.e., the first derivative is non-negative throughout the domain of the data.

Forces the fit to be nonincreasing, i.e., the first derivative is nonpositive throughout the domain of the data.
 3. 2nd Derivative Constraints:
3. 2nd Derivative Constraints: Once a fit has been computed, the following choices for global constraints on the second derivative of the computed fit can be enforced:

Does not enforce any constraints.

Forces the fit to be convex, i.e., the second derivative is non-negative throughout the domain of the data.

Forces the fit to be concave, i.e., the second derivative is nonpositive throughout the domain of the data. 
 4. Spline Parameters:
4. Spline Parameters: Once a fit has been computed, the following spline parameters can be changed using sliders:
 Spline Order
Spline Order. Note: The order of the spline is one more than the degree of the fit.
 Spline Space Dimension.
Spline Space Dimension. Changing this value increases the number of knots used in computing the fit.
 5. Plot Window:
5. Plot Window: Displays a plot of the fit in this draw widget. Using the mouse, the knots can be moved from within this window. 
 6. Mouse Coordinates:
6. Mouse Coordinates: As the mouse is moved over the plot, reflects the mouse coordinates. The coordinates are computed in data coordinates.
 7. Default Knots:
7. Default Knots: Fits the current data with a default set of knots.
 8. Open:
8. Open: Imports data from an external ASCII file.
 9. Save Spline:
9. Save Spline: Allows saving of computed splines in save files.
 10. Dismiss:
10. Dismiss: Terminates this program.
 11. Help:
11. Help: Opens the online help file for viewing.