173 |
|
#endif |
174 |
|
dinfo.nrows = dinfo.ncols = dinfo.ncomp = 0; |
175 |
|
dinfo.dtype = DTascii; |
176 |
< |
if (getheader(fp, &get_dminfo, &dinfo) < 0) { |
176 |
> |
if (getheader(fp, get_dminfo, &dinfo) < 0) { |
177 |
|
fclose(fp); |
178 |
|
return(NULL); |
179 |
|
} |
180 |
< |
if ((dinfo.dtype == DTrgbe) | (dinfo.dtype == DTxyze)) { |
180 |
> |
if ((dinfo.nrows <= 0) | (dinfo.ncols <= 0)) { |
181 |
|
if (!fscnresolu(&dinfo.ncols, &dinfo.nrows, fp)) { |
182 |
|
fclose(fp); |
183 |
|
return(NULL); |
184 |
|
} |
185 |
< |
dinfo.ncomp = 3; |
185 |
> |
if (dinfo.ncomp <= 0) |
186 |
> |
dinfo.ncomp = 3; |
187 |
> |
else if ((dinfo.dtype == DTrgbe) | (dinfo.dtype == DTxyze) && |
188 |
> |
dinfo.ncomp != 3) { |
189 |
> |
fclose(fp); |
190 |
> |
return(NULL); |
191 |
> |
} |
192 |
|
} |
193 |
|
dnew = rmx_alloc(dinfo.nrows, dinfo.ncols, dinfo.ncomp); |
194 |
|
if (dnew == NULL) { |
388 |
|
return(dnew); |
389 |
|
} |
390 |
|
|
391 |
< |
/* Swap rows and columns in the given matrix in situ */ |
392 |
< |
int |
393 |
< |
rmx_transpose(RMATRIX *rm) |
391 |
> |
/* Allocate and assign transposed matrix */ |
392 |
> |
RMATRIX * |
393 |
> |
rmx_transpose(const RMATRIX *rm) |
394 |
|
{ |
395 |
< |
RMATRIX dswap; |
395 |
> |
RMATRIX *dnew; |
396 |
|
int i, j, k; |
397 |
|
|
398 |
|
if (rm == NULL) |
399 |
|
return(0); |
400 |
< |
dswap.nrows = rm->ncols; |
401 |
< |
dswap.ncols = rm->nrows; |
402 |
< |
dswap.ncomp = rm->ncomp; |
403 |
< |
for (i = 1; i < rm->nrows; i++) |
404 |
< |
for (j = 0; j < i; j++) |
405 |
< |
for (k = rm->ncomp; k--; ) { |
406 |
< |
double *opp = rm->mtx + rmx_indx(&dswap,j,i,k); |
407 |
< |
double d = *opp; |
402 |
< |
*opp = rmx_lval(rm,i,j,k); |
403 |
< |
rmx_lval(rm,i,j,k) = d; |
404 |
< |
} |
405 |
< |
rm->nrows = dswap.nrows; |
406 |
< |
rm->ncols = dswap.ncols; |
407 |
< |
return(1); |
400 |
> |
dnew = rmx_alloc(rm->ncols, rm->nrows, rm->ncomp); |
401 |
> |
if (dnew == NULL) |
402 |
> |
return(NULL); |
403 |
> |
for (i = dnew->nrows; i--; ) |
404 |
> |
for (j = dnew->ncols; j--; ) |
405 |
> |
for (k = dnew->ncomp; k--; ) |
406 |
> |
rmx_lval(dnew,i,j,k) = rmx_lval(rm,j,i,k); |
407 |
> |
return(dnew); |
408 |
|
} |
409 |
|
|
410 |
|
/* Multiply (concatenate) two matrices and allocate the result */ |