From fc9b18afa66eca90d15302af3161a09e942c3a37 Mon Sep 17 00:00:00 2001 From: bremner Date: Tue, 11 Jul 2006 11:15:40 +0000 Subject: git-svn-id: file:///export/data/bremner/svn/trunk/inetools@5465 09fa754a-f411-0410-976a-da6bfa213b30 --- ine_io.c | 53 +++++++++++++++++++++++ rat2int.c | 139 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ rat2int.doc | 10 +++++ rat2int.h | 11 +++++ 4 files changed, 213 insertions(+) create mode 100644 ine_io.c create mode 100644 rat2int.c create mode 100644 rat2int.doc create mode 100644 rat2int.h diff --git a/ine_io.c b/ine_io.c new file mode 100644 index 0000000..46d1716 --- /dev/null +++ b/ine_io.c @@ -0,0 +1,53 @@ +#include +#include + +void scan_for_begin(int *m_p, int *n_p, char **type_p){ + char buf[BUFSIZ]; + char *cursor; + int m,n; + + while ( fgets(buf,BUFSIZ,stdin) !=NULL ) { + fputs(buf,stdout); + for (cursor=buf; isblank(*cursor); cursor++); + if (strncmp(cursor,"begin",5)==0) break; + } + + if (fgets(buf,BUFSIZ,stdin)==NULL) { + fprintf(stderr,"No parameter line"); + exit(1); + } + + m=strtol(buf,&cursor,10); + if (errno==ERANGE || m==0){ + fprintf(stderr,"Missing or absurd row count"); + exit(1); + } + *m_p=m; + + n=strtol(cursor,&cursor,10); + if (errno==ERANGE || m==0){ + fprintf(stderr,"Missing or absurd column count"); + exit(1); + } + + *n_p=n; + + while (isblank(*cursor)){ + cursor++; + } + + *type_p=cursor; + +} + +void check_type( char *type, char *ok[], int count){ + int i; + for (i=0; i< count; i++){ + if (strncmp(type,ok[i],strlen(ok[i]))==0) + return; + } + + fprintf(stderr,"Type %s not permitted\n", + type); + exit(1); +} diff --git a/rat2int.c b/rat2int.c new file mode 100644 index 0000000..24c7ade --- /dev/null +++ b/rat2int.c @@ -0,0 +1,139 @@ +/* + * Reads a polyhedron file on stdin with rationals and outputs an equivalent + * system with integer coefficents. + * + * David Bremner. bremner@unb.ca + * + */ +static char rcsid[]="$Id: rat2int.c 2055 2006-04-03 19:41:14Z bremner $"; +#include +#include + +#ifndef LRSMP +#error This file only compiles with LRSMP +#endif + +#include "lrsmp.h" +#include "rat2int.h" + +static long int m,n,type; +#define MP_DIGITS 1000L + +static void lcm3(lrs_mp a,lrs_mp b,lrs_mp c); + + +main(int argc, char **argv) +{ + + + int i,j; + lrs_mp l,g,scratch; + char *type; + lrs_mp *D, *N; + char *ok[]={ "integer", "rational"}; + process_args(argc,argv,DOCSTRING); + lrs_mp_init (MP_DIGITS,stdin,stdout); + scan_for_begin(&m,&n,&type); + + check_type(type, ok , 2); + + printf("%d %d integer\n",m,n); + D=calloc(n,sizeof(lrs_mp)); + N=calloc(n,sizeof(lrs_mp)); + + for (i=0;i