CONCRV plots contours generated by other software packages.
The call is: | CALL CONCRV (XRAY, YRAY, N, ZLEV) | level 2, 3 |
or: | void concrv (float *xray, float *yray, int n, float zlev); |
XRAY, YRAY | are arrays containing the X- and Y-coordinates of a contour line. |
N | is the number of points. |
ZLEV | is a function value used for labels. |
The routine CONTUR calculates and plots contours of the function Z = F(X,Y).
The call is: | CALL CONTUR (XRAY, N, YRAY, M, ZMAT, ZLEV) | level 2, 3 |
or: | void contur (float *xray, int n, float *yray, int m, float *zmat, float zlev); |
XRAY | is an array containing X-coordinates. |
N | is the dimension of XRAY. |
YRAY | is an array containing Y-coordinates. |
M | is the dimension of YRAY. |
ZMAT | is a matrix of the dimension (N, M) containing function values. |
ZLEV | is a function value that defines the contour line to be calculated. ZLEV can be used for labels. |
The routine CONMAT plots contours of the function Z = F(X,Y). The function values correspond to a linear grid in the XY-plane.
The call is: | CALL CONMAT (ZMAT, N, M, ZLEV) | level 2, 3 |
or: | void conmat (float *zmat, int n, int m, float zlev); |
ZMAT | is a matrix of the dimension (N, M) containing
the function values. If XA, XE, YA and
YE are the axis limits in
GRAF or values defined with
the routine
SURSZE, the connection of grid points and
matrix elements can be described by the
formula: ZMAT(I,J) = F(X,Y) where X = XA + (I - 1) * (XE - XA) / (N - 1) , I = 1,..,N and Y = YA + (J - 1) * (YE - YA) / (M - 1) , J = 1,..,M. |
N, M | define the dimension of ZMAT. |
ZLEV | is a function value that defines the contour line to be calculated. The value can be used for labels. |
Additional notes:
The routine CONTRI plots contours from triangulated data that can be calculated by the routine TRIANG from a set of irregularily distributed data points.
The call is: | CALL CONTRI (XRAY, YRAY, ZRAY, N, I1RAY, I2RAY, I3RAY, NTRI, ZLEV) | level 2, 3 |
or: | void contri (float *xray, float *yray, float *zray, int n, int *i1ray, int *i2ray, int *i3ray, int ntri, float zlev); |
XRAY | is an array containing the X-coordinates of data points. |
YRAY | is an array containing the Y-coordinates of data points. |
ZRAY | is an array containing the Z-coordinates of data points. |
N | is the number of data points. |
I1RAY, I2RAY, I3RAY | is the Delaunay triangulation of the points (XRAY, YRAY) calculated by the routine TRIANG. |
NTRI | is the number of triangles in I1RAY, I2RAY and I3RAY. |
ZLEV | is a function value that defines the contour line to be calculated. |
The routine CONSHD plots filled contours of the function Z = F(X,Y). Two algorithms can be selected for contour filling: a cell filling algorithm and a polygon filling algorithm. For a polygon filling, only closed contours can be filled. The algorithm can be defined with the routine SHDMOD.
The call is: | CALL CONSHD (XRAY, N, YRAY, M, ZMAT, ZLVRAY, NLEV) | level 2, 3 |
or: | void conshd (float *xray, int n, float *yray, int m, float *zmat, float *zlvray, int nlev); |
XRAY | is an array containing X-coordinates. |
N | is the dimension of XRAY. |
YRAY | is an array containing Y-coordinates. |
M | is the dimension of YRAY. |
ZMAT | is a matrix of the dimension (N, M) containing function values. |
ZLVRAY | is an array containing the levels. The levels must be sorted in ascending order if cell filling is selected. For polygon filling, the levels should be sorted in such a way that inner contours are plotted last. |
NLEV | is the number of levels. |
Additional notes:
The routine CONFLL plots filled contours from triangulated data that can be calculated by the routine TRIANG from a set of irregularily distributed data points.
The call is: | CALL CONFLL (XRAY, YRAY, ZRAY, N, I1RAY, I2RAY, I3RAY, NTRI, ZLVRAY, NLEV) | level 2, 3 |
or: | void confll (float *xray, float *yray, float *zray, int n, int *i1ray, int *i2ray, int *i3ray, int ntri, float *zlvray, int nlev); |
XRAY | is an array containing the X-coordinates of data points. |
YRAY | is an array containing the Y-coordinates of data points. |
ZRAY | is an array containing the Z-coordinates of data points. |
N | is the number of data points. |
I1RAY, I2RAY, I3RAY | is the Delaunay triangulation of the points (XRAY, YRAY) calculated by the routine TRIANG. |
NTRI | is the number of triangles in I1RAY, I2RAY and I3RAY. |
ZLVRAY | is an array containing the levels. |
NLEV | is the number of levels. |
The routine CONPTS generates contours without plotting. Multiple curves can be returned for one contour level.
The call is: | CALL CONPTS (XRAY, N, YRAY, M, ZMAT, ZLEV, XPTRAY, YPTRAY, MAXPTS, IRAY, MAXCRV, NCURVS) | level 0, 1, 2, 3 |
or: | void conpts (float *xray, int n, float *yray, int m, float *zmat, float zlev, float *xptray, float *yptray, int maxpts, int *iray, int maxcrv, int *ncurvs); |
XRAY | is an array containing X-coordinates. |
N | is the dimension of XRAY. |
YRAY | is an array containing Y-coordinates. |
M | is the dimension of YRAY. |
ZMAT | is a matrix of the dimension (N, M) containing function values. |
ZLEV | is a function value that defines the contour line to be calculated. |
XPTRAY, YPTRAY | are returned arrays containing the calculated contour. The arrays can contain several curves. |
MAXPTS | is the maximal number of points that can be passed to XPTRAY and YPTRAY. |
IRAY | is a returned integer array that contains the number of points for each generated contour curve. |
MAXCRV | is the maximal number of entries that can be passed to IRAY. |
NCURVS | is the returned number of generated curves. |
Example:
The following statements generate from some arrays XRAY, YRAY and ZMAT contours and plot them with the routine CURVE.
PARAMETER (N=100, MAXPTS=1000,MAXCRV=10) REAL ZMAT(N,N),XRAY(N),YRAY(N),XPTS(MAXPTS),YPTS(MAXPTS) INTEGER IRAY(MAXCRV) ..... DO I=1,12 ZLEV=0.1+(I-1)*0.1 CALL CONPTS(XRAY,N,YRAY,N,ZMAT,ZLEV,XPTS,YPTS,MAXPTS, * IRAY,MAXCRV,NCURVS) K=1 DO J=1,NCURVS CALL CURVE(XPTS(K),YPTS(K),IRAY(J)) K=K+IRAY(J) END do END DOT R I P T S
The routine TRIPTS generates contours from triangulated data without plotting. Multiple curves can be returned for one contour level.
The call is: | CALL TRIPTS (XRAY, YRAY, ZRAY, N, I1RAY, I2RAY, I3RAY, NTRI, ZLEV, XPTRAY, YPTRAY, MAXPTS, IRAY, MAXCRV, NCURVS) | level 0, 1, 2, 3 |
or: | void tripts (float *xray, float *yray, float *zray, int n, int *i1ray, int *i2ray, int *i3ray, int ntri, float zlev, float *xptray, float *yptray, int maxpts, int *iray, int maxray, int *ncurvs); |
XRAY | is an array containing the X-coordinates of data points. |
YRAY | is an array containing the Y-coordinates of data points. |
ZRAY | is an array containing the Z-coordinates of data points. |
N | is the number of data points. |
I1RAY, I2RAY, I3RAY | is the Delaunay triangulation of the points (XRAY, YRAY) calculated by the routine TRIANG. |
NTRI | is the number of triangles in I1RAY, I2RAY and I3RAY. |
ZLEV | is a function value that defines the contour line to be calculated. |
XPTRAY, YPTRAY | are returned arrays containing the calculated contour. The arrays can contain several curves. |
MAXPTS | is the maximal number of points that can be passed to XPTRAY and YPTRAY. |
IRAY | is a returned integer array that contains the number of points for each generated contour curve. |
MAXCRV | is the maximal number of entries that can be passed to IRAY. |
NCURVS | is the returned number of generated curves. |
The routine LABELS defines contour labels.
The call is: | CALL LABELS (COPT, 'CONTUR') | level 1, 2, 3 |
or: | void labels (char *copt, "CONTUR"); |
COPT | is a character string defining the labels. |
= 'NONE' | means that no labels will be plotted. |
= 'FLOAT' | means that the level value will be used for labels. |
= 'CONLAB' | means that labels defined with the routine CONLAB will be plotted. Default: COPT = 'NONE'. |
Additional note:
The routine LABDIS defines the distance between contour labels.
The call is: | CALL LABDIS (NDIS, 'CONTUR') | level 1, 2, 3 |
or: | void labdis (int ndis, "CONTUR"); |
NDIS | is the distance between labels in plot coordinates. Default: NDIS = 500 |
The routine LABCLR defines the colour of contour labels.
The call is: | CALL LABCLR (NCLR, 'CONTUR') | level 1, 2, 3 |
or: | void labclr (int nclr, "CONTUR"); |
NCLR | is a colour number value. If NCLR = -1, the contour labels will be plotted with the current colour. Default: NCLR = -1 |
The routine CONLAB defines a character string which will be used for labels if the routine LABELS is called with the parameter 'CONLAB'.
The call is: | CALL CONLAB (CLAB) | level 1, 2, 3 |
or: | void conlab (char *clab); |
CLAB | is a character string containing the label. Default: CLAB = ' '. |
The routine CONMOD modifies the appearance of contour labels. By default, DISLIN suppresses the plotting of labels at a position where the contour is very curved. To measure the curvature of a contour for an interval, DISLIN calculates the ratio between the arc length and the length of the straight line between the interval limits. If the quotient is much greater than 1, the contour line is very curved in that interval.
The call is: | CALL CONMOD (XFAC, XQUOT) | level 1, 2, 3 |
or: | void conmod (float xfac, float xquot); |
XFAC | defines the length of intervals (>= 0). The curvature of contours will be tested in intervals of the length (1 + XFAC) * W where W is the label length. |
XQUOT | defines an upper limit for the quotient of arc length
and length of the straight line (> 1). If the quotient
is greater than XQUOT, the plotting of labels will be
suppressed in the tested interval. Default: (0.5, 1.5). |
The routine CONGAP defines the distance between contour lines and labels.
The call is: | CALL CONGAP (XFAC) | level 1, 2, 3 |
or: | void congap (float xfac); |
XFAC | is a real number used as a scaling factor. The distance between contour lines and labels is set to XFAC * NH where NH is the current character height. Default: XFAC = 0.5. |
The routine SHDMOD selects the algorithm used for contour filling, or modifies options for cell filling.
The call is: | CALL SHDMOD (COPT, CKEY) | level 1, 2, 3 |
or: | void shdmod (char *copt, char *ckey); |
CKEY | is a character string containing one of the following keywords: |
= 'CONTUR' | defines the algorithm used for contour filling. COPT can have the values 'CELL' and 'POLY'. The default value is COPT = 'CELL'. |
= 'CELL' | modifies the cell filling algorithm. COPT can have the values 'BOTH', 'UPPER', 'LOWER' and 'NONE'. If COPT = 'NONE', the filling of the regions below and above the level limits are suppressed. If COPT = 'UPPER', the filling of the region below the lowermost level is suppressed. COPT = 'LOWER' means that the filling of the region above the uppermost level is suppressed. By default, both regions described above are filled. |
= 'COLOR' | modifies the calculation of colours for cell filling. COPT can have the values 'LOWER', 'MIDDLE' and 'UPPER'. For COPT = 'LOWER', the lower value of two neighbouring levels is used for colour calculation, for COPT = 'UPPER', the upper value of two neighbouring levels is used, and for COPT = 'MIDDLE', the mean value of the two levels is used for colour calculation. The default value is COPT = 'LOWER'. |
The routine CONCLR defines colours for filled contour lines.
The call is: | CALL CONCLR (NCRAY, N) | level 1, 2, 3 |
or: | void conclr (int *ncray, int n); |
NCRAY | is an integer array containing colour numbers. |
N | is the number of entries in NCRAY. |