ftp.nice.ch/pub/next/unix/developer/plplot.3.0.s.tar.gz#/plplot/examples/example09.c

This is example09.c in view mode; [Download] [Up]

/* Demonstration of contour plotting */
#define XPTS      35
#define YPTS      46
#define XSPA      2./(XPTS-1)
#define YSPA      2./(YPTS-1)

FLOAT tr[6] = {XSPA, 0.0, -1.0, 0.0, YSPA, -1.0};
static FLOAT clevel[11] = {-1.,-.8,-.6,-.4,-.2,0,.2,.4,.6,.8,1.};

main()
{
   int i, j;
   double xx, yy;
   FLOAT **z, **w;
   static int mark=1500, space=1500;
   char *malloc();
   void xform();

   z = (FLOAT **)malloc(XPTS*sizeof(FLOAT *));
   w = (FLOAT **)malloc(XPTS*sizeof(FLOAT *));
   for (i=0; i<XPTS; i++) {
     z[i] = (FLOAT *)malloc(YPTS*sizeof(FLOAT));
     w[i] = (FLOAT *)malloc(YPTS*sizeof(FLOAT));
     xx = (double)(i-(XPTS/2))/(double)(XPTS/2);
     for (j=0; j<YPTS; j++)  {
       yy = (double)(j-(YPTS/2))/(double)(YPTS/2) - 1.0;
       z[i][j] = xx*xx - yy*yy;
       w[i][j] = 2*xx*yy;
     }
   }
   plstar(1,1);
   plenv(-1.0,1.0,-1.0,1.0,0,0);
   plcol(2);
   plcont(z,XPTS,YPTS,1,XPTS,1,YPTS,clevel,11,xform);
   plstyl(1,&mark,&space);
   plcol(3);
   plcont(w,XPTS,YPTS,1,XPTS,1,YPTS,clevel,11,xform);
   plcol(1);
   pllab("X Coordinate", "Y Coordinate","Contour Plots of Saddle Points");
   plend();
}

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.