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

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

?? sbc.c

?? Bluezan implementation of the Bluetooth&#8482 wireless standards specifications for Linux. The code
?? C
?? 第 1 頁 / 共 3 頁
字號:
		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));}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级一级性生活免费录像| 福利91精品一区二区三区| 色婷婷亚洲精品| 椎名由奈av一区二区三区| av电影天堂一区二区在线观看| 中文在线一区二区| 99久久综合色| 伊人开心综合网| 欧美精品久久一区| 国内精品免费**视频| 国产色91在线| 色一情一伦一子一伦一区| 亚洲最色的网站| 91精品国产综合久久婷婷香蕉 | 一区二区三区欧美| 在线亚洲精品福利网址导航| 亚洲国产成人tv| 日韩一二三区不卡| 成人午夜电影网站| 亚洲九九爱视频| 91精品国产黑色紧身裤美女| 国产在线精品一区二区| 中文字幕永久在线不卡| 欧美视频第二页| 久久精品国产精品亚洲红杏 | 欧美丰满少妇xxxxx高潮对白| 日产国产欧美视频一区精品| 精品国产1区二区| 成人久久18免费网站麻豆| 亚洲图片欧美视频| 久久久99精品久久| 欧美三级资源在线| 国产一区999| 亚洲午夜精品一区二区三区他趣| 欧美成va人片在线观看| 不卡av在线免费观看| 日本欧美肥老太交大片| 国产精品美女久久久久久2018| 欧美色窝79yyyycom| 国产一区二区不卡在线| 亚洲午夜视频在线| 国产日韩精品一区| 欧美精品色综合| av电影天堂一区二区在线| 青草av.久久免费一区| 国产精品视频yy9299一区| 欧美乱妇15p| av电影在线观看不卡| 精品无人码麻豆乱码1区2区| 夜夜亚洲天天久久| 欧美国产精品中文字幕| 欧美电影精品一区二区| 91福利在线观看| 成人av手机在线观看| 免费观看91视频大全| 亚洲国产精品久久久男人的天堂| 国产精品日日摸夜夜摸av| 日韩精品一区二区三区蜜臀 | 成人综合激情网| 免费看欧美女人艹b| 悠悠色在线精品| **网站欧美大片在线观看| 久久婷婷国产综合国色天香| 777午夜精品视频在线播放| 91在线播放网址| 国产不卡一区视频| 韩国av一区二区三区| 麻豆一区二区三| 日本美女一区二区三区| 无吗不卡中文字幕| 夜夜精品浪潮av一区二区三区| 最新热久久免费视频| 欧美激情一区在线观看| 国产亚洲欧美一级| 久久久久久久久久久电影| 精品成人一区二区三区四区| 日韩欧美一级片| 日韩小视频在线观看专区| 欧美日韩国产成人在线免费| 欧美视频在线一区| 欧美性色aⅴ视频一区日韩精品| 91美女片黄在线| 一本一本久久a久久精品综合麻豆| 成人av资源网站| 99re免费视频精品全部| 99久久精品免费看国产免费软件| aaa国产一区| av电影一区二区| 日本韩国欧美国产| 欧美日韩精品专区| 7878成人国产在线观看| 欧美本精品男人aⅴ天堂| 欧美r级电影在线观看| 久久久久久免费| 中文字幕一区二区三| 亚洲精品中文在线影院| 天天色综合天天| 久久精品国产澳门| 国产成人欧美日韩在线电影| 成人激情电影免费在线观看| 99免费精品在线观看| 欧美亚洲愉拍一区二区| 91 com成人网| 国产欧美日本一区视频| 自拍视频在线观看一区二区| 性久久久久久久久久久久| 久久99久久99小草精品免视看| 国产精品一品二品| 91麻豆精品在线观看| 欧美日韩国产小视频在线观看| 精品人伦一区二区色婷婷| 亚洲国产精品99久久久久久久久| 亚洲免费伊人电影| 人禽交欧美网站| 成人h动漫精品一区二区| 日本韩国一区二区三区视频| 精品少妇一区二区三区日产乱码| 欧美极品aⅴ影院| 亚洲不卡一区二区三区| 国产剧情一区二区| 欧洲一区二区三区在线| 精品国产91久久久久久久妲己| 亚洲欧洲韩国日本视频| 婷婷六月综合亚洲| www.欧美日韩国产在线| 欧美一区二区高清| 亚洲色图欧洲色图婷婷| 美女视频一区二区三区| 99国产精品视频免费观看| 制服丝袜中文字幕一区| 亚洲婷婷综合色高清在线| 免播放器亚洲一区| 91美女片黄在线| 久久在线观看免费| 图片区小说区国产精品视频| 国产91精品一区二区| 日韩一级二级三级精品视频| 亚洲精品日产精品乱码不卡| 精品一区二区精品| 欧美女孩性生活视频| 综合色中文字幕| 国产精品综合久久| 欧美电影免费提供在线观看| 亚洲高清中文字幕| 972aa.com艺术欧美| 国产视频一区在线观看| 精油按摩中文字幕久久| 欧美日本在线看| 亚洲第一会所有码转帖| 91在线观看美女| 国产精品久久毛片a| 国产成人av电影在线观看| 日韩精品中文字幕在线一区| 亚洲午夜电影在线| 一本色道久久综合亚洲91| 中文字幕中文字幕在线一区| 国产河南妇女毛片精品久久久| 欧美一区二区三区四区高清| 亚洲午夜在线观看视频在线| 成人免费精品视频| 欧美成人一级视频| 精品亚洲porn| 777奇米成人网| 亚洲一区二区三区四区五区黄 | 久久精品欧美日韩| 九九视频精品免费| 欧美一区二视频| 天天做天天摸天天爽国产一区| 国产老肥熟一区二区三区| 久久人人超碰精品| 精品亚洲国内自在自线福利| 欧美日韩国产经典色站一区二区三区| 夜夜操天天操亚洲| 91丝袜国产在线播放| 中文字幕不卡在线观看| 国产一区二区在线视频| 久久九九久久九九| 国产一区 二区| 欧美精品一区二区在线播放| 一个色在线综合| 欧美精品国产精品| 丝袜美腿成人在线| 欧美日韩国产另类一区| 午夜精品久久久久| 欧洲av在线精品| 亚洲成人av免费| 欧美日韩aaa| 男女男精品网站| 欧美国产精品一区二区| 高清beeg欧美| 欧美国产日韩一二三区| 91啪九色porn原创视频在线观看| 中文字幕av一区二区三区| aaa国产一区| 国产日韩欧美精品一区| 99国内精品久久| 亚洲国产视频直播| 91精品国产品国语在线不卡| 国产成人啪午夜精品网站男同| 日本一区二区综合亚洲|