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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sbc.c

?? bluetooth 開發(fā)應(yīng)用bluez-utils-2.23
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
		for (k = 0; k < 16; k++)			state->S[ch][i] += anamatrix8[i][k] * state->Y[ch][k];	}	/* Output 8 Subband Samples */	for (i = 0; i < 8; i++)		frame->sb_sample[blk][ch][i] = state->S[ch][i];}static int sbc_analyze_audio(struct sbc_encoder_state *state, struct sbc_frame *frame){	int ch, blk;	switch (frame->subbands) {	case 4:		for (ch = 0; ch < frame->channels; ch++)			for (blk = 0; blk < frame->blocks; blk++) {				memset(frame->sb_sample[blk][ch], 0,					sizeof(frame->sb_sample[blk][ch]));				sbc_analyze_four(state, frame, ch, blk);			}		return frame->blocks * 4;	case 8:		for (ch = 0; ch < frame->channels; ch++)			for (blk = 0; blk < frame->blocks; blk++) {				memset(frame->sb_sample[blk][ch], 0,					sizeof(frame->sb_sample[blk][ch]));				sbc_analyze_eight(state, frame, ch, blk);			}		return frame->blocks * 8;	default:		return -EIO;	}}/* * Packs the SBC frame from frame into the memory at data. At most len * bytes will be used, should more memory be needed an appropriate  * error code will be returned. Returns the length of the packed frame * on success or a negative value on error.  * * The error codes are: * -1 Not enough memory reserved * -2 Unsupported sampling rate * -3 Unsupported number of blocks * -4 Unsupported number of subbands * -5 Bitpool value out of bounds * -99 not implemented */static int sbc_pack_frame(u_int8_t * data, struct sbc_frame *frame, size_t len){	int produced;	/* Will copy the header parts for CRC-8 calculation here */	u_int8_t crc_header[11] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };	int crc_pos = 0;	u_int8_t sf;		/* Sampling frequency as temporary value for table lookup */	int ch, sb, blk, bit;	/* channel, subband, block and bit counters */	int bits[2][8];		/* bits distribution */	int levels[2][8];	/* levels are derived from that */	double scalefactor[2][8];	/* derived from frame->scale_factor */	if (len < 4) {		return -1;	}	/* Clear first 4 bytes of data (that's the constant length part of the SBC header) */	memset(data, 0, 4);	data[0] = SBC_SYNCWORD;	if (frame->sampling_frequency == 16) {		data[1] |= (SBC_FS_16 & 0x03) << 6;		sf = SBC_FS_16;	} else if (frame->sampling_frequency == 32) {		data[1] |= (SBC_FS_32 & 0x03) << 6;		sf = SBC_FS_32;	} else if (frame->sampling_frequency == 44.1) {		data[1] |= (SBC_FS_44 & 0x03) << 6;		sf = SBC_FS_44;	} else if (frame->sampling_frequency == 48) {		data[1] |= (SBC_FS_48 & 0x03) << 6;		sf = SBC_FS_48;	} else {		return -2;	}	switch (frame->blocks) {	case 4:		data[1] |= (SBC_NB_4 & 0x03) << 4;		break;	case 8:		data[1] |= (SBC_NB_8 & 0x03) << 4;		break;	case 12:		data[1] |= (SBC_NB_12 & 0x03) << 4;		break;	case 16:		data[1] |= (SBC_NB_16 & 0x03) << 4;		break;	default:		return -3;		break;	}	data[1] |= (frame->channel_mode & 0x03) << 2;	data[1] |= (frame->allocation_method & 0x01) << 1;	switch (frame->subbands) {	case 4:		/* Nothing to do */		break;	case 8:		data[1] |= 0x01;		break;	default:		return -4;		break;	}	data[2] = frame->bitpool;	if (((frame->channel_mode == MONO || frame->channel_mode == DUAL_CHANNEL)	     && frame->bitpool > 16 * frame->subbands)	    || ((frame->channel_mode == STEREO || frame->channel_mode == JOINT_STEREO)		&& frame->bitpool > 32 * frame->subbands)) {		return -5;	}	/* Can't fill in crc yet */	produced = 32;	crc_header[0] = data[1];	crc_header[1] = data[2];	crc_pos = 16;	for (ch = 0; ch < frame->channels; ch++) {		for (sb = 0; sb < frame->subbands; sb++) {			frame->scale_factor[ch][sb] = 0;			scalefactor[ch][sb] = 2;			for (blk = 0; blk < frame->blocks; blk++) {				while (scalefactor[ch][sb] < fabs(frame->sb_sample[blk][ch][sb])) {					frame->scale_factor[ch][sb]++;					scalefactor[ch][sb] *= 2;				}			}		}	}	if (frame->channel_mode == JOINT_STEREO) {		float sb_sample_j[16][2][7]; /* like frame->sb_sample but joint stereo */		int scalefactor_j[2][7], scale_factor_j[2][7]; /* scalefactor and scale_factor in joint case */		/* Calculate joint stereo signal */		for (sb = 0; sb < frame->subbands - 1; sb++) {			for (blk = 0; blk < frame->blocks; blk++) {				sb_sample_j[blk][0][sb] = (frame->sb_sample[blk][0][sb] 							   + frame->sb_sample[blk][1][sb]) / 2;				sb_sample_j[blk][1][sb] = (frame->sb_sample[blk][0][sb] 							   - frame->sb_sample[blk][1][sb]) / 2;			}		}		/* calculate scale_factor_j and scalefactor_j for joint case */		for (ch = 0; ch < 2; ch++) {			for (sb = 0; sb < frame->subbands - 1; sb++) {				scale_factor_j[ch][sb] = 0;				scalefactor_j[ch][sb] = 2;				for (blk = 0; blk < frame->blocks; blk++) {					while (scalefactor_j[ch][sb] < fabs(sb_sample_j[blk][ch][sb])) {						scale_factor_j[ch][sb]++;						scalefactor_j[ch][sb] *= 2;					}				}			}		}		/* decide which subbands to join */		frame->join = 0;		for (sb = 0; sb < frame->subbands - 1; sb++) {			if ( (scalefactor[0][sb] + scalefactor[1][sb]) > 			     (scalefactor_j[0][sb] + scalefactor_j[1][sb]) ) {				/* use joint stereo for this subband */				frame->join |= 1 << sb;				frame->scale_factor[0][sb] = scale_factor_j[0][sb];				frame->scale_factor[1][sb] = scale_factor_j[1][sb];				scalefactor[0][sb] = scalefactor_j[0][sb];				scalefactor[1][sb] = scalefactor_j[1][sb];				for (blk = 0; blk < frame->blocks; blk++) {					frame->sb_sample[blk][0][sb] = sb_sample_j[blk][0][sb];					frame->sb_sample[blk][1][sb] = sb_sample_j[blk][1][sb];				}			}		}  		if (len * 8 < produced + frame->subbands) {			return -1;		} else {			data[4] = 0;			for (sb = 0; sb < frame->subbands - 1; sb++) {				data[4] |= ((frame->join >> sb) & 0x01) << (7 - sb);			}			if (frame->subbands == 4) {				crc_header[crc_pos / 8] = data[4] & 0xf0;			} else {				crc_header[crc_pos / 8] = data[4];			}			produced += frame->subbands;			crc_pos += frame->subbands;		}	}	if (len * 8 < produced + (4 * frame->subbands * frame->channels)) {		return -1;	} else {		for (ch = 0; ch < frame->channels; ch++) {			for (sb = 0; sb < frame->subbands; sb++) {				if (produced % 8 == 0)					data[produced / 8] = 0;				data[produced / 8] |= ((frame->scale_factor[ch][sb] & 0x0F) << (4 - (produced % 8)));				crc_header[crc_pos / 8] |=				    ((frame->scale_factor[ch][sb] & 0x0F) << (4 - (crc_pos % 8)));				produced += 4;				crc_pos += 4;			}		}	}	data[3] = sbc_crc8(crc_header, crc_pos);	sbc_calculate_bits(frame, bits, sf);	for (ch = 0; ch < frame->channels; ch++) {		for (sb = 0; sb < frame->subbands; sb++) {			levels[ch][sb] = (1 << bits[ch][sb]) - 1;		}	}	for (blk = 0; blk < frame->blocks; blk++) {		for (ch = 0; ch < frame->channels; ch++) {			for (sb = 0; sb < frame->subbands; sb++) {				if (levels[ch][sb] > 0) {					frame->audio_sample[blk][ch][sb] =					    (u_int16_t) (((frame->sb_sample[blk][ch][sb] / scalefactor[ch][sb] +							   1.0) * levels[ch][sb]) / 2.0);				} else {					frame->audio_sample[blk][ch][sb] = 0;				}			}		}	}	for (blk = 0; blk < frame->blocks; blk++) {		for (ch = 0; ch < frame->channels; ch++) {			for (sb = 0; sb < frame->subbands; sb++) {				if (bits[ch][sb] != 0) {					for (bit = 0; bit < bits[ch][sb]; bit++) {						int b;	/* A bit */						if (produced > len * 8) {							return -1;						}						if (produced % 8 == 0) {							data[produced / 8] = 0;						}						b = ((frame->audio_sample[blk][ch][sb]) >> (bits[ch][sb] - bit -											    1)) & 0x01;						data[produced / 8] |= b << (7 - (produced % 8));						produced++;					}				}			}		}	}	if (produced % 8 != 0) {		produced += 8 - (produced % 8);	}	return produced / 8;}struct sbc_priv {	int init;	struct sbc_frame frame;	struct sbc_decoder_state dec_state;	struct sbc_encoder_state enc_state;};int sbc_init(sbc_t *sbc, unsigned long flags){	if (!sbc)		return -EIO;	memset(sbc, 0, sizeof(sbc_t));	sbc->priv = malloc(sizeof(struct sbc_priv));	if (!sbc->priv)		return -ENOMEM;	memset(sbc->priv, 0, sizeof(struct sbc_priv));	sbc->rate     = 44100;	sbc->channels = 2;	sbc->subbands = 8;	sbc->blocks   = 16;	sbc->bitpool  = 32;	return 0;}int sbc_decode(sbc_t *sbc, void *data, int count){	struct sbc_priv *priv;	char *ptr;	int i, ch, framelen, samples;	if (!sbc)		return -EIO;	priv = sbc->priv;	framelen = sbc_unpack_frame(data, &priv->frame, count);	if (!priv->init) {		sbc_decoder_init(&priv->dec_state, &priv->frame);		priv->init = 1;		sbc->rate     = priv->frame.sampling_frequency * 1000;		sbc->channels = priv->frame.channels;		sbc->subbands = priv->frame.subbands;		sbc->blocks   = priv->frame.blocks;		sbc->bitpool  = priv->frame.bitpool;	}	samples = sbc_synthesize_audio(&priv->dec_state, &priv->frame);	if (!sbc->data) {		sbc->size = samples * priv->frame.channels * 2;		sbc->data = malloc(sbc->size);	}	if (sbc->size < samples * priv->frame.channels * 2) {		sbc->size = samples * priv->frame.channels * 2;		sbc->data = realloc(sbc->data, sbc->size);	}	if (!sbc->data) {		sbc->size = 0;		return -ENOMEM;	}	ptr = sbc->data;	for (i = 0; i < samples; i++) {		for (ch = 0; ch < priv->frame.channels; ch++) {			int16_t s = (int16_t)(priv->frame.pcm_sample[ch][i]);			*ptr++ = (s & 0xff00) >> 8;			*ptr++ = (s & 0x00ff);		}	}	sbc->len = samples * priv->frame.channels * 2;	sbc->duration = (1000000 * priv->frame.subbands * priv->frame.blocks) / sbc->rate;	return framelen;}int sbc_encode(sbc_t *sbc, void *data, int count){	struct sbc_priv *priv;	char *ptr;	int i, ch, framelen, samples;	if (!sbc)		return -EIO;	priv = sbc->priv;	if (!priv->init) {		priv->frame.sampling_frequency = ((double) sbc->rate) / 1000;		priv->frame.channels = sbc->channels;		if (sbc->channels > 1)			priv->frame.channel_mode = STEREO;		else			priv->frame.channel_mode = MONO;		priv->frame.allocation_method = SNR;		priv->frame.subbands = sbc->subbands;		priv->frame.blocks   = sbc->blocks;		priv->frame.bitpool  = sbc->bitpool;		sbc_encoder_init(&priv->enc_state, &priv->frame);		priv->init = 1;	}	ptr = data;	for (i = 0; i < priv->frame.subbands * priv->frame.blocks; i++) {		for (ch = 0; ch < sbc->channels; ch++) {			//int16_t s = (ptr[0] & 0xff) << 8 | (ptr[1] & 0xff);			int16_t s = (ptr[1] & 0xff) << 8 | (ptr[2] & 0xff);			ptr += 2;			priv->frame.pcm_sample[ch][i] = ((double) s);		}	}	samples = sbc_analyze_audio(&priv->enc_state, &priv->frame);	if (!sbc->data) {		sbc->size = 1024;		sbc->data = malloc(sbc->size);	}	if (!sbc->data) {		sbc->size = 0;		return -ENOMEM;	}	framelen = sbc_pack_frame(sbc->data, &priv->frame, sbc->size);	sbc->len = framelen;	sbc->duration = (1000000 * priv->frame.subbands * priv->frame.blocks) / sbc->rate;	return samples * sbc->channels * 2;}void sbc_finish(sbc_t *sbc){	if (!sbc)		return;	if (sbc->data)		free(sbc->data);	if (sbc->priv)		free(sbc->priv);	memset(sbc, 0, sizeof(sbc_t));}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成熟亚洲日本毛茸茸凸凹| 亚洲电影一级片| 国产成人午夜99999| 国产午夜精品一区二区三区嫩草| 奇米色一区二区| 精品粉嫩超白一线天av| 国产精品主播直播| 中文av一区二区| 日本韩国精品在线| 五月婷婷久久综合| 精品美女在线观看| 粉嫩一区二区三区性色av| √…a在线天堂一区| 在线观看视频欧美| 奇米777欧美一区二区| xfplay精品久久| av成人免费在线| 亚洲成人自拍一区| 欧美精品一区二区久久婷婷 | 一本色道久久综合亚洲精品按摩| 自拍偷拍欧美精品| 欧美系列日韩一区| 激情深爱一区二区| 国产精品天干天干在观线| 欧美综合一区二区| 捆绑调教美女网站视频一区| 中文字幕成人av| 欧美日韩国产一二三| 韩国成人福利片在线播放| 日韩一区欧美一区| 制服.丝袜.亚洲.另类.中文| 风间由美一区二区av101| 亚洲成人精品一区二区| 精品国产免费人成在线观看| 色婷婷av一区二区三区大白胸| 奇米影视在线99精品| 亚洲区小说区图片区qvod| 日韩一区二区三区电影| 99国产精品久久久久久久久久| 日本中文一区二区三区| 国产精品国产三级国产aⅴ入口| 91精品国产福利在线观看| bt欧美亚洲午夜电影天堂| 麻豆91精品视频| 亚洲精品视频在线| 久久久久久久久久久99999| 欧美亚洲动漫另类| 成人综合在线观看| 国产最新精品免费| 视频在线观看一区二区三区| 1区2区3区国产精品| 久久久久国产精品人| 在线观看91av| 欧美自拍偷拍一区| 99久久er热在这里只有精品15| 免费不卡在线观看| 亚洲成人中文在线| 亚洲综合视频在线| 国产精品久久网站| 日本一区二区三区dvd视频在线| 日韩欧美国产精品| 欧美高清视频在线高清观看mv色露露十八| 成人久久视频在线观看| 国产精品一区二区三区99| 日韩成人精品在线| 亚洲高清视频中文字幕| 一区二区三区色| 亚洲视频一区在线观看| 国产精品国产自产拍在线| 国产偷v国产偷v亚洲高清| 欧美zozo另类异族| 精品乱人伦小说| 精品成人a区在线观看| 日韩欧美一级片| 日韩欧美激情一区| 欧美va亚洲va国产综合| 欧美电影免费观看高清完整版在线观看 | 国产一区二区调教| 美日韩一区二区三区| 奇米影视7777精品一区二区| 婷婷六月综合亚洲| 天天做天天摸天天爽国产一区| 亚洲自拍都市欧美小说| 亚洲图片自拍偷拍| 亚洲成人在线观看视频| 丝袜亚洲精品中文字幕一区| 天堂久久一区二区三区| 全部av―极品视觉盛宴亚洲| 日本不卡一区二区三区高清视频| 丝袜国产日韩另类美女| 蜜臀av一区二区在线免费观看| 蜜臀久久99精品久久久久宅男| 麻豆国产欧美一区二区三区| 经典三级在线一区| 大胆欧美人体老妇| 色综合久久久久久久久| 欧美美女bb生活片| 欧美mv和日韩mv的网站| 久久久美女毛片| 亚洲婷婷在线视频| 亚洲国产精品麻豆| 美国三级日本三级久久99| 国产精品1区2区3区在线观看| www.亚洲激情.com| 91麻豆swag| 3d成人h动漫网站入口| 久久久久久99久久久精品网站| 国产精品久久久久7777按摩| 午夜精品福利一区二区三区av| 精品一区二区三区香蕉蜜桃| 风间由美一区二区三区在线观看| 色欧美88888久久久久久影院| 欧美日韩国产首页| 国产亚洲福利社区一区| 亚洲在线观看免费视频| 麻豆freexxxx性91精品| 波多野洁衣一区| 欧美美女一区二区在线观看| 久久噜噜亚洲综合| 一区二区三区资源| 狠狠网亚洲精品| 欧美性感一区二区三区| 久久久久久久网| 午夜精品久久久久久久99樱桃| 国产ts人妖一区二区| 欧美视频一区二区在线观看| 久久久久亚洲综合| 午夜精品久久久久影视| 成人福利视频在线| 日韩三级在线免费观看| 一区二区三区四区精品在线视频| 韩国欧美国产一区| 欧美日韩视频第一区| 久久久久免费观看| 首页国产欧美久久| 色视频一区二区| 欧美国产日韩在线观看| 五月天网站亚洲| 色综合婷婷久久| 久久久国际精品| 五月婷婷久久丁香| 在线视频欧美区| 国产女人18水真多18精品一级做 | 免费人成黄页网站在线一区二区| www.欧美日韩| 久久一区二区视频| 日韩国产在线观看一区| 色猫猫国产区一区二在线视频| 国产日韩欧美精品在线| 久久超碰97中文字幕| 欧美乱妇一区二区三区不卡视频| 亚洲欧美电影院| www.欧美日韩| 中文字幕一区二区三| 国产九色精品成人porny| 91精品国产91久久久久久最新毛片 | 精品一区二区三区香蕉蜜桃| 欧美精品亚洲一区二区在线播放| 日韩毛片视频在线看| 成人一区二区视频| 国产亚洲人成网站| 国产成人免费视频网站 | 欧美精品一区二区不卡| 蜜臀av性久久久久蜜臀av麻豆| 欧美日韩激情在线| 亚洲国产精品久久久久婷婷884 | 欧美日韩免费视频| 一区二区三区日韩精品视频| 99re免费视频精品全部| 中国色在线观看另类| 成人高清免费观看| 中文字幕日韩一区| 91免费看视频| 亚洲已满18点击进入久久| 欧美综合亚洲图片综合区| 亚洲午夜在线观看视频在线| 欧美在线你懂的| 五月天视频一区| 日韩一区二区三区高清免费看看| 日韩av一二三| 欧美va天堂va视频va在线| 精品午夜久久福利影院| 国产亚洲婷婷免费| 91亚洲精品久久久蜜桃| 一区二区三区不卡视频| 欧美人与禽zozo性伦| 久久综合综合久久综合| 久久久亚洲精华液精华液精华液 | 蜜桃精品视频在线观看| 久久亚洲一级片| 99这里都是精品| 亚洲国产美国国产综合一区二区| 8x福利精品第一导航| 精品系列免费在线观看| 国产精品污污网站在线观看| 色偷偷久久人人79超碰人人澡| 午夜视频一区在线观看| 久久综合五月天婷婷伊人| 成人激情黄色小说| 亚洲一区二区精品视频|