#include "cs.h" /* load a triplet matrix from a file */ cs *cs_load (FILE *f) { CS_INT i, j ; double x ; #ifdef CS_COMPLEX double xi ; #endif cs *T ; if (!f) return (NULL) ; /* check inputs */ T = cs_spalloc (0, 0, 1, 1, 1) ; /* allocate result */ #ifdef CS_COMPLEX while (fscanf (f, ""CS_ID" "CS_ID" %lg %lg\n", &i, &j, &x, &xi) == 4) #else while (fscanf (f, ""CS_ID" "CS_ID" %lg\n", &i, &j, &x) == 3) #endif { #ifdef CS_COMPLEX if (!cs_entry (T, i, j, x + xi*I)) return (cs_spfree (T)) ; #else if (!cs_entry (T, i, j, x)) return (cs_spfree (T)) ; #endif } return (T) ; }