亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? jas_seq.c

?? JPEG2000是以小波變換為基礎
?? C
字號:
/* * Copyright (c) 1999-2000 Image Power, Inc. and the University of *   British Columbia. * Copyright (c) 2001-2002 Michael David Adams. * All rights reserved. *//* __START_OF_JASPER_LICENSE__ *  * JasPer License Version 2.0 *  * Copyright (c) 2001-2006 Michael David Adams * Copyright (c) 1999-2000 Image Power, Inc. * Copyright (c) 1999-2000 The University of British Columbia *  * All rights reserved. *  * Permission is hereby granted, free of charge, to any person (the * "User") obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without restriction, * including without limitation the rights to use, copy, modify, merge, * publish, distribute, and/or sell copies of the Software, and to permit * persons to whom the Software is furnished to do so, subject to the * following conditions: *  * 1.  The above copyright notices and this permission notice (which * includes the disclaimer below) shall be included in all copies or * substantial portions of the Software. *  * 2.  The name of a copyright holder shall not be used to endorse or * promote products derived from the Software without specific prior * written permission. *  * THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS * LICENSE.  NO USE OF THE SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER * THIS DISCLAIMER.  THE SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS * "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.  IN NO * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL * INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.  NO ASSURANCES ARE * PROVIDED BY THE COPYRIGHT HOLDERS THAT THE SOFTWARE DOES NOT INFRINGE * THE PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS OF ANY OTHER ENTITY. * EACH COPYRIGHT HOLDER DISCLAIMS ANY LIABILITY TO THE USER FOR CLAIMS * BROUGHT BY ANY OTHER ENTITY BASED ON INFRINGEMENT OF INTELLECTUAL * PROPERTY RIGHTS OR OTHERWISE.  AS A CONDITION TO EXERCISING THE RIGHTS * GRANTED HEREUNDER, EACH USER HEREBY ASSUMES SOLE RESPONSIBILITY TO SECURE * ANY OTHER INTELLECTUAL PROPERTY RIGHTS NEEDED, IF ANY.  THE SOFTWARE * IS NOT FAULT-TOLERANT AND IS NOT INTENDED FOR USE IN MISSION-CRITICAL * SYSTEMS, SUCH AS THOSE USED IN THE OPERATION OF NUCLEAR FACILITIES, * AIRCRAFT NAVIGATION OR COMMUNICATION SYSTEMS, AIR TRAFFIC CONTROL * SYSTEMS, DIRECT LIFE SUPPORT MACHINES, OR WEAPONS SYSTEMS, IN WHICH * THE FAILURE OF THE SOFTWARE OR SYSTEM COULD LEAD DIRECTLY TO DEATH, * PERSONAL INJURY, OR SEVERE PHYSICAL OR ENVIRONMENTAL DAMAGE ("HIGH * RISK ACTIVITIES").  THE COPYRIGHT HOLDERS SPECIFICALLY DISCLAIM ANY * EXPRESS OR IMPLIED WARRANTY OF FITNESS FOR HIGH RISK ACTIVITIES. *  * __END_OF_JASPER_LICENSE__ *//* * Sequence/Matrix Library * * $Id$ *//******************************************************************************\* Includes.\******************************************************************************/#include <stdlib.h>#include <assert.h>#include <math.h>#include "jasper/jas_seq.h"#include "jasper/jas_malloc.h"#include "jasper/jas_math.h"/******************************************************************************\* Constructors and destructors.\******************************************************************************/jas_matrix_t *jas_seq2d_create(int xstart, int ystart, int xend, int yend){	jas_matrix_t *matrix;	assert(xstart <= xend && ystart <= yend);	if (!(matrix = jas_matrix_create(yend - ystart, xend - xstart))) {		return 0;	}	matrix->xstart_ = xstart;	matrix->ystart_ = ystart;	matrix->xend_ = xend;	matrix->yend_ = yend;	return matrix;}jas_matrix_t *jas_matrix_create(int numrows, int numcols){	jas_matrix_t *matrix;	int i;	if (!(matrix = jas_malloc(sizeof(jas_matrix_t)))) {		return 0;	}	matrix->flags_ = 0;	matrix->numrows_ = numrows;	matrix->numcols_ = numcols;	matrix->rows_ = 0;	matrix->maxrows_ = numrows;	matrix->data_ = 0;	matrix->datasize_ = numrows * numcols;	if (matrix->maxrows_ > 0) {		if (!(matrix->rows_ = jas_malloc(matrix->maxrows_ *		  sizeof(jas_seqent_t *)))) {			jas_matrix_destroy(matrix);			return 0;		}	}	if (matrix->datasize_ > 0) {		if (!(matrix->data_ = jas_malloc(matrix->datasize_ *		  sizeof(jas_seqent_t)))) {			jas_matrix_destroy(matrix);			return 0;		}	}	for (i = 0; i < numrows; ++i) {		matrix->rows_[i] = &matrix->data_[i * matrix->numcols_];	}	for (i = 0; i < matrix->datasize_; ++i) {		matrix->data_[i] = 0;	}	matrix->xstart_ = 0;	matrix->ystart_ = 0;	matrix->xend_ = matrix->numcols_;	matrix->yend_ = matrix->numrows_;	return matrix;}void jas_matrix_destroy(jas_matrix_t *matrix){	if (matrix->data_) {		assert(!(matrix->flags_ & JAS_MATRIX_REF));		jas_free(matrix->data_);		matrix->data_ = 0;	}	if (matrix->rows_) {		jas_free(matrix->rows_);		matrix->rows_ = 0;	}	jas_free(matrix);}jas_seq2d_t *jas_seq2d_copy(jas_seq2d_t *x){	jas_matrix_t *y;	int i;	int j;	y = jas_seq2d_create(jas_seq2d_xstart(x), jas_seq2d_ystart(x), jas_seq2d_xend(x),	  jas_seq2d_yend(x));	assert(y);	for (i = 0; i < x->numrows_; ++i) {		for (j = 0; j < x->numcols_; ++j) {			*jas_matrix_getref(y, i, j) = jas_matrix_get(x, i, j);		}	}	return y;}jas_matrix_t *jas_matrix_copy(jas_matrix_t *x){	jas_matrix_t *y;	int i;	int j;	y = jas_matrix_create(x->numrows_, x->numcols_);	for (i = 0; i < x->numrows_; ++i) {		for (j = 0; j < x->numcols_; ++j) {			*jas_matrix_getref(y, i, j) = jas_matrix_get(x, i, j);		}	}	return y;}/******************************************************************************\* Bind operations.\******************************************************************************/void jas_seq2d_bindsub(jas_matrix_t *s, jas_matrix_t *s1, int xstart, int ystart,  int xend, int yend){	jas_matrix_bindsub(s, s1, ystart - s1->ystart_, xstart - s1->xstart_,	  yend - s1->ystart_ - 1, xend - s1->xstart_ - 1);}void jas_matrix_bindsub(jas_matrix_t *mat0, jas_matrix_t *mat1, int r0, int c0,  int r1, int c1){	int i;	if (mat0->data_) {		if (!(mat0->flags_ & JAS_MATRIX_REF)) {			jas_free(mat0->data_);		}		mat0->data_ = 0;		mat0->datasize_ = 0;	}	if (mat0->rows_) {		jas_free(mat0->rows_);		mat0->rows_ = 0;	}	mat0->flags_ |= JAS_MATRIX_REF;	mat0->numrows_ = r1 - r0 + 1;	mat0->numcols_ = c1 - c0 + 1;	mat0->maxrows_ = mat0->numrows_;	mat0->rows_ = jas_malloc(mat0->maxrows_ * sizeof(jas_seqent_t *));	for (i = 0; i < mat0->numrows_; ++i) {		mat0->rows_[i] = mat1->rows_[r0 + i] + c0;	}	mat0->xstart_ = mat1->xstart_ + c0;	mat0->ystart_ = mat1->ystart_ + r0;	mat0->xend_ = mat0->xstart_ + mat0->numcols_;	mat0->yend_ = mat0->ystart_ + mat0->numrows_;}/******************************************************************************\* Arithmetic operations.\******************************************************************************/int jas_matrix_cmp(jas_matrix_t *mat0, jas_matrix_t *mat1){	int i;	int j;	if (mat0->numrows_ != mat1->numrows_ || mat0->numcols_ !=	  mat1->numcols_) {		return 1;	}	for (i = 0; i < mat0->numrows_; i++) {		for (j = 0; j < mat0->numcols_; j++) {			if (jas_matrix_get(mat0, i, j) != jas_matrix_get(mat1, i, j)) {				return 1;			}		}	}	return 0;}void jas_matrix_divpow2(jas_matrix_t *matrix, int n){	int i;	int j;	jas_seqent_t *rowstart;	int rowstep;	jas_seqent_t *data;	rowstep = jas_matrix_rowstep(matrix);	for (i = matrix->numrows_, rowstart = matrix->rows_[0]; i > 0; --i,	  rowstart += rowstep) {		for (j = matrix->numcols_, data = rowstart; j > 0; --j,		  ++data) {			*data = (*data >= 0) ? ((*data) >> n) :			  (-((-(*data)) >> n));		}	}}void jas_matrix_clip(jas_matrix_t *matrix, jas_seqent_t minval, jas_seqent_t maxval){	int i;	int j;	jas_seqent_t v;	jas_seqent_t *rowstart;	jas_seqent_t *data;	int rowstep;	rowstep = jas_matrix_rowstep(matrix);	for (i = matrix->numrows_, rowstart = matrix->rows_[0]; i > 0; --i,	  rowstart += rowstep) {		data = rowstart;		for (j = matrix->numcols_, data = rowstart; j > 0; --j,		  ++data) {			v = *data;			if (v < minval) {				*data = minval;			} else if (v > maxval) {				*data = maxval;			}		}	}}void jas_matrix_asr(jas_matrix_t *matrix, int n){	int i;	int j;	jas_seqent_t *rowstart;	int rowstep;	jas_seqent_t *data;	assert(n >= 0);	rowstep = jas_matrix_rowstep(matrix);	for (i = matrix->numrows_, rowstart = matrix->rows_[0]; i > 0; --i,	  rowstart += rowstep) {		for (j = matrix->numcols_, data = rowstart; j > 0; --j,		  ++data) {			*data >>= n;		}	}}void jas_matrix_asl(jas_matrix_t *matrix, int n){	int i;	int j;	jas_seqent_t *rowstart;	int rowstep;	jas_seqent_t *data;	rowstep = jas_matrix_rowstep(matrix);	for (i = matrix->numrows_, rowstart = matrix->rows_[0]; i > 0; --i,	  rowstart += rowstep) {		for (j = matrix->numcols_, data = rowstart; j > 0; --j,		  ++data) {			*data <<= n;		}	}}/******************************************************************************\* Code.\******************************************************************************/int jas_matrix_resize(jas_matrix_t *matrix, int numrows, int numcols){	int size;	int i;	size = numrows * numcols;	if (size > matrix->datasize_ || numrows > matrix->maxrows_) {		return -1;	}	matrix->numrows_ = numrows;	matrix->numcols_ = numcols;	for (i = 0; i < numrows; ++i) {		matrix->rows_[i] = &matrix->data_[numcols * i];	}	return 0;}void jas_matrix_setall(jas_matrix_t *matrix, jas_seqent_t val){	int i;	int j;	jas_seqent_t *rowstart;	int rowstep;	jas_seqent_t *data;	rowstep = jas_matrix_rowstep(matrix);	for (i = matrix->numrows_, rowstart = matrix->rows_[0]; i > 0; --i,	  rowstart += rowstep) {		for (j = matrix->numcols_, data = rowstart; j > 0; --j,		  ++data) {			*data = val;		}	}}jas_matrix_t *jas_seq2d_input(FILE *in){	jas_matrix_t *matrix;	int i;	int j;	long x;	int numrows;	int numcols;	int xoff;	int yoff;	if (fscanf(in, "%d %d", &xoff, &yoff) != 2)		return 0;	if (fscanf(in, "%d %d", &numcols, &numrows) != 2)		return 0;	if (!(matrix = jas_seq2d_create(xoff, yoff, xoff + numcols, yoff + numrows)))		return 0;	if (jas_matrix_numrows(matrix) != numrows || jas_matrix_numcols(matrix) != numcols) {		abort();	}	/* Get matrix data. */	for (i = 0; i < jas_matrix_numrows(matrix); i++) {		for (j = 0; j < jas_matrix_numcols(matrix); j++) {			if (fscanf(in, "%ld", &x) != 1) {				jas_matrix_destroy(matrix);				return 0;			}			jas_matrix_set(matrix, i, j, JAS_CAST(jas_seqent_t, x));		}	}	return matrix;}int jas_seq2d_output(jas_matrix_t *matrix, FILE *out){#define MAXLINELEN	80	int i;	int j;	jas_seqent_t x;	char buf[MAXLINELEN + 1];	char sbuf[MAXLINELEN + 1];	int n;	fprintf(out, "%d %d\n", jas_seq2d_xstart(matrix),	  jas_seq2d_ystart(matrix));	fprintf(out, "%d %d\n", jas_matrix_numcols(matrix),	  jas_matrix_numrows(matrix));	buf[0] = '\0';	for (i = 0; i < jas_matrix_numrows(matrix); ++i) {		for (j = 0; j < jas_matrix_numcols(matrix); ++j) {			x = jas_matrix_get(matrix, i, j);			sprintf(sbuf, "%s%4ld", (strlen(buf) > 0) ? " " : "",			  JAS_CAST(long, x));			n = strlen(buf);			if (n + strlen(sbuf) > MAXLINELEN) {				fputs(buf, out);				fputs("\n", out);				buf[0] = '\0';			}			strcat(buf, sbuf);			if (j == jas_matrix_numcols(matrix) - 1) {				fputs(buf, out);				fputs("\n", out);				buf[0] = '\0';			}		}	}	fputs(buf, out);	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
婷婷久久综合九色综合伊人色| 国产成人精品免费看| 午夜在线电影亚洲一区| 狠狠色综合色综合网络| 欧美一级在线观看| 亚洲国产欧美日韩另类综合| 色94色欧美sute亚洲线路一ni| 亚洲欧洲日产国码二区| av成人免费在线| 国产精品久久777777| av一区二区三区| 国产精品护士白丝一区av| 国产九九视频一区二区三区| www国产成人| 国产精品一区一区| 久久精品一区蜜桃臀影院| 国产成人亚洲综合a∨婷婷| 国产欧美一区二区精品性| 国产高清成人在线| 国产精品人成在线观看免费| 成人91在线观看| 综合欧美亚洲日本| 色哟哟在线观看一区二区三区| 亚洲色图制服丝袜| 91麻豆国产精品久久| 一区二区在线观看视频在线观看| 在线精品亚洲一区二区不卡| 亚洲国产精品人人做人人爽| 欧美伦理电影网| 看国产成人h片视频| 2023国产精品自拍| 国产成人精品aa毛片| 日韩毛片视频在线看| 欧美吻胸吃奶大尺度电影 | 日韩欧美国产综合| 久久国产人妖系列| 欧美国产国产综合| 99久久久无码国产精品| 亚洲一区精品在线| 日韩三级中文字幕| 国产老肥熟一区二区三区| 国产精品二三区| 欧美亚洲禁片免费| 免费xxxx性欧美18vr| 国产午夜亚洲精品午夜鲁丝片 | 国产一区二区三区四| 日本一区二区三区在线不卡| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲成人免费视频| 精品对白一区国产伦| av亚洲精华国产精华精华| 亚洲一区二区三区精品在线| 4438x成人网最大色成网站| 国模套图日韩精品一区二区| 久久久久久久久久久久久久久99| eeuss鲁片一区二区三区在线看| 亚洲国产一区二区三区青草影视 | 欧美伊人精品成人久久综合97| 日一区二区三区| 国产欧美日本一区视频| 欧美性猛交xxxx黑人交| 精品一区二区久久久| 国产精品成人免费在线| 欧美日本国产视频| 国产成人免费在线观看不卡| 一区二区三区中文字幕电影| 制服丝袜激情欧洲亚洲| 成人av免费在线| 日本女优在线视频一区二区| 国产女同互慰高潮91漫画| 欧美日韩一级片在线观看| 韩日av一区二区| 亚洲欧美二区三区| 精品国产不卡一区二区三区| 一本久久精品一区二区| 精品一区二区三区免费观看 | 日韩精品视频网| 国产精品国产自产拍高清av| 日韩一区二区免费视频| av在线播放一区二区三区| 在线观看日韩一区| 久久精品国产色蜜蜜麻豆| 一区二区三区丝袜| 日本一区二区三区国色天香| 91.麻豆视频| 色综合网色综合| 国产一区二区电影| 天堂影院一区二区| 亚洲日本韩国一区| 久久精品亚洲国产奇米99| 91精品欧美久久久久久动漫| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 91精品国产日韩91久久久久久| 成人av在线一区二区| 久久精品国产亚洲一区二区三区| 亚洲国产视频网站| 日韩美女啊v在线免费观看| 久久久国产综合精品女国产盗摄| 在线不卡的av| 欧美在线你懂得| 99精品在线免费| 国产成人免费av在线| 久久草av在线| 污片在线观看一区二区| 一区二区三区不卡视频| 国产精品久久久久久一区二区三区| 精品少妇一区二区三区在线视频| 欧美日韩精品一区二区三区| 99天天综合性| 国产超碰在线一区| 国产精品资源网站| 久久 天天综合| 蜜桃精品视频在线| 午夜视频一区在线观看| 亚洲自拍偷拍欧美| 亚洲老妇xxxxxx| 亚洲视频一区在线| 国产精品国模大尺度视频| 国产精品网曝门| 欧美国产精品中文字幕| 久久精品一区四区| 国产日韩影视精品| 久久你懂得1024| 久久精品视频一区二区三区| 久久综合狠狠综合| 久久一区二区三区四区| 欧美精品一区二区久久久| 欧美成人伊人久久综合网| 日韩欧美高清一区| 日韩精品最新网址| 精品久久久久久亚洲综合网 | 中文字幕中文字幕中文字幕亚洲无线 | 岛国一区二区三区| 国产99久久久国产精品潘金网站| 国产一区二区在线免费观看| 九色综合国产一区二区三区| 久久99久久精品欧美| 久久99精品国产91久久来源| 国内精品国产成人| 国产精品综合久久| 国产精品91xxx| 国产超碰在线一区| 97久久精品人人做人人爽50路| 91免费国产在线观看| 色视频成人在线观看免| 欧美性色aⅴ视频一区日韩精品| 欧美午夜精品免费| 欧美高清精品3d| 日韩欧美成人午夜| 久久久国产综合精品女国产盗摄| 欧美国产丝袜视频| 亚洲美女免费视频| 亚洲风情在线资源站| 日韩精品亚洲专区| 国产一本一道久久香蕉| 国产成人在线免费| 97久久人人超碰| 欧美精品久久久久久久多人混战| 欧美一二三区精品| 国产丝袜在线精品| 亚洲欧美另类在线| 亚洲国产精品一区二区尤物区| 日韩中文字幕不卡| 精品亚洲国产成人av制服丝袜 | 欧日韩精品视频| 91精品国产色综合久久不卡蜜臀| 精品盗摄一区二区三区| 国产精品久久久久久久久晋中 | 一区二区三区在线高清| 婷婷开心激情综合| 国产精品一卡二| 一本色道久久加勒比精品| 日韩一区二区三区免费看| 国产日韩欧美麻豆| 夜夜揉揉日日人人青青一国产精品 | 亚洲精品视频免费看| 日韩av午夜在线观看| 国产盗摄视频一区二区三区| 色8久久人人97超碰香蕉987| 91精品在线观看入口| 国产亚洲制服色| 亚洲综合免费观看高清完整版| 久久激五月天综合精品| 99久久精品费精品国产一区二区| 欧美日韩在线直播| 久久婷婷色综合| 亚洲一区电影777| 国产在线播放一区| 欧美在线观看一区| 久久婷婷一区二区三区| 亚洲一区二区三区视频在线| 美女视频黄免费的久久| 成人app网站| 欧美一级高清片| 亚洲欧美日韩电影| 国产一区二区三区久久久| 在线中文字幕不卡| 国产日韩欧美制服另类| 日韩国产欧美三级| 99久久久免费精品国产一区二区|