13 static char rcs_ident[] =
"$Header: /software/dmsv/sun4/sunos/SWT-BACKUP/spencer/src/urt/tools/tools/RCS/smush.c,v 3.0.1.1 1992/01/23 20:56:39 spencer Exp $";
26 char * infname = NULL, * outfname = NULL, * maskfname = NULL;
27 FILE * outfile = stdout;
28 int oflag = 0, mflag = 0, no_norm = 0;
29 int xlinewidth, xlen, ylen, x, y;
30 int i, j, k, chan, nchan, level, levels = 1;
31 int maskskip, origmasksize;
32 int maxmaskskip, maxmasksize, maxmaskbelow;
33 int masksize, maskbelow, maskabove;
36 float *mask_mult_table;
37 rle_hdr in_hdr, out_hdr;
40 rle_pixel *rastptr, *rasterbase, *centerpxl, *calcpxl;
41 rle_pixel *outrastptr, *outrasterbase, *outpxl, *tempbase;
42 rle_pixel *bot_edge_pxl, *bot_data_pxl, *bot_extrap_pxl;
43 rle_pixel *top_edge_pxl, *top_data_pxl, *top_extrap_pxl;
44 rle_pixel *left_edge_pxl, *left_data_pxl, *left_extrap_pxl;
45 rle_pixel *right_edge_pxl, *right_data_pxl, *right_extrap_pxl;
55 "% m%-maskfile!s n%- o%-outfile!s level%d infile%s",
56 &mflag
, &maskfname
, &no_norm
,
57 &oflag
, &outfname
, &levels
, &infname
) == 0 )
88 mask_mult_table = (
float *) malloc(
sizeof(
float) * origmasksize *
91 for (i=0; i < origmasksize; i++)
93 maskmult = &(mask_mult_table[(i*origmasksize) << 8]);
94 for (j=0; j < origmasksize; j++)
96 for (k=0;k < 256; k++)
97 maskmult[ k ] = (
float) k * mask[i*origmasksize+j];
104 fprintf(stderr,
"Level must be greater than 0.\n");
109 maxmaskskip = 1 << (levels - 1);
110 maxmasksize = (origmasksize - 1) * maxmaskskip + 1;
111 maxmaskbelow = (maxmasksize-1) / 2;
116 xlinewidth = xlen + maxmasksize - 1;
133 rasterbase = (
unsigned char *)malloc(
134 xlinewidth * (ylen + maxmasksize - 1) * nchan );
135 outrasterbase = (
unsigned char *)malloc(
136 xlinewidth * (ylen + maxmasksize - 1) * nchan );
139 rastptr = &(rasterbase[maxmaskbelow * xlinewidth * nchan + maxmaskbelow]);
147 for (chan=0; chan < nchan; chan++)
149 rows[chan] = rastptr;
151 rastptr = &(rastptr[xlinewidth]);
157 for(level = 1; level <= levels; level++)
160 maskskip = 1 << (level - 1);
161 masksize = (origmasksize - 1) * maskskip + 1;
162 maskbelow = (masksize-1) / 2;
163 maskabove = masksize / 2;
168 if ((maskbelow > 0) && (maskabove > 0))
170 rastptr = &(rasterbase[maxmaskbelow +
171 maxmaskbelow * xlinewidth * nchan]);
173 for (chan = 0; chan < nchan; chan++)
175 bot_edge_pxl = &(rastptr[chan * xlinewidth]);
176 top_edge_pxl = &(rastptr[(ylen-1) * nchan * xlinewidth
177 + chan * xlinewidth]);
178 for(x=0; x < xlen; x++)
180 for (i=1; i <= maskbelow; i++)
182 bot_data_pxl = bot_edge_pxl + i * xlinewidth * nchan;
183 bot_extrap_pxl = bot_edge_pxl - i * xlinewidth * nchan;
184 newvalue = 2 * (*bot_edge_pxl) - (*bot_data_pxl);
185 *bot_extrap_pxl = (newvalue < 0) ? 0 :
186 ((newvalue > 255) ? 255 : newvalue);
188 for (i=1; i <= maskabove; i++)
190 top_data_pxl = top_edge_pxl - i * xlinewidth * nchan;
191 top_extrap_pxl = top_edge_pxl + i * xlinewidth * nchan;
192 newvalue = 2 * (*top_edge_pxl) - (*top_data_pxl);
193 *top_extrap_pxl = (newvalue < 0) ? 0 :
194 ((newvalue > 255) ? 255 : newvalue);
201 left_edge_pxl = &(rastptr[(-maskbelow) * nchan * xlinewidth]);
202 right_edge_pxl = &(rastptr[(-maskbelow) * nchan * xlinewidth
203 + xlinewidth - masksize]);
204 for (chan = 0; chan < nchan; chan++)
206 for(y=0; y < ylen + masksize - 1; y++)
208 for (i=1; i <= maskbelow; i++)
210 left_data_pxl = left_edge_pxl + i;
211 left_extrap_pxl = left_edge_pxl - i;
212 newvalue = 2 * (*left_edge_pxl) - (*left_data_pxl);
213 *left_extrap_pxl = (newvalue < 0) ? 0 :
214 ((newvalue > 255) ? 255 : newvalue);
216 for (i=1; i <= maskabove; i++)
218 right_data_pxl = right_edge_pxl - i;
219 right_extrap_pxl = right_edge_pxl + i;
220 newvalue = 2 * (*right_edge_pxl) - (*right_data_pxl);
221 *right_extrap_pxl = (newvalue < 0) ? 0 :
222 ((newvalue > 255) ? 255 : newvalue);
224 left_edge_pxl += xlinewidth;
225 right_edge_pxl += xlinewidth;
230 for (y = 0; y < ylen; y++)
232 rastptr = &(rasterbase[maxmaskbelow + (y+maxmaskbelow) *
233 xlinewidth * nchan]);
234 outrastptr = &(outrasterbase[maxmaskbelow + (y+maxmaskbelow) *
235 xlinewidth * nchan]);
237 for (chan = 0; chan < nchan; chan++)
239 centerpxl = &(rastptr[chan * xlinewidth]);
240 outpxl = &(outrastptr[chan * xlinewidth]);
241 for(x=0; x < xlen; x++)
244 for (i=0; i < origmasksize; i++)
246 calcpxl = centerpxl + (i * maskskip - maskbelow)
247 * xlinewidth * nchan - maskbelow;
248 maskmult = &(mask_mult_table[(i*origmasksize) << 8]);
250 for (j=0; j < origmasksize; j++)
253 total += maskmult[ calcpxl[j*maskskip] ];
259 *outpxl = (total < 0.0) ? 0 :
260 ((total > 255.0) ? 255 : (
unsigned char) total );
267 tempbase = rasterbase;
268 rasterbase = outrasterbase;
269 outrasterbase = tempbase;
279 for ( chan=0; chan < nchan; chan++)
281 rows[chan] = scanout[chan];
285 for (y = 0; y < ylen; y++)
287 rastptr = &(rasterbase[maxmaskbelow + (y+maxmaskbelow) *
288 xlinewidth * nchan]);
290 for (chan = 0; chan < nchan; chan++)
292 outpxl = &(rastptr[chan * xlinewidth]);
293 for(x=0; x < xlen; x++)
295 scanout[chan][x] = *outpxl;
304 free( mask_mult_table );
307 free( outrasterbase );
336 mptr = (
float *) malloc(
sizeof(
float) * siz * siz );
341 fprintf(stderr,
"mask size not 5\n");
349 mptr[j+i*siz] = w[j]*w[i];
367 fscanf(maskfile,
"%d", &masksize);
369 mptr = (
float *) malloc(
sizeof(
float) * masksize * masksize);
373 for (i=0; i< masksize; i++)
374 for (j=0; j< masksize; j++)
376 fscanf(maskfile,
"%f", &(mptr[j+i*masksize]));
377 total += mptr[j+i*masksize];
384 fprintf(stderr,
"%s: Input mask total not valid\n",
progname);
388 for (i=0; i< masksize; i++)
389 for (j=0; j< masksize; j++)
391 mptr[j+i*masksize] /= total;
397 if ( maskfile != stdin )
FILE * rle_open_f(char *prog_name, char *file_name, char *mode)
#define RLE_SET_BIT(glob, bit)
rle_hdr * rle_hdr_cp(rle_hdr *from_hdr, rle_hdr *to_hdr)
void rle_names(rle_hdr *the_hdr, const char *pgmname, const char *fname, int img_num)
void rle_row_free(rle_hdr *the_hdr, rle_pixel **scanp)
char * cmd_name(char **argv)
void main(int argc, char **argv)
int rle_get_setup(rle_hdr *the_hdr)
int rle_row_alloc(rle_hdr *the_hdr, rle_pixel ***scanp)
int rle_getrow(rle_hdr *the_hdr, scanline)
int rle_get_error(int code, const char *pgmname, const char *fname)
int scanargs(int argc, char **argv, const char *format,...)
void rle_puteof(rle_hdr *the_hdr)
void rle_putrow(rows, int rowlen, rle_hdr *the_hdr)
void rle_addhist(argv, rle_hdr *in_hdr, rle_hdr *out_hdr)
void rle_put_setup(rle_hdr *the_hdr)
float * read_mask(int *size, char *fname, int no_norm)
rle_hdr * rle_hdr_init(rle_hdr *the_hdr)
#define RLE_CHECK_ALLOC(pgm, ptr, name)
float * gauss_mask(int siz)