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

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

?? sbcinfo.c

?? SBC 編碼解碼算法,用C語言實現,不依賴與任何平臺,用語語音通訊等方面.
?? C
字號:
/* * *  Bluetooth low-complexity, subband codec (SBC) library * *  Copyright (C) 2004-2007  Marcel Holtmann <marcel@holtmann.org> * * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA * */#ifdef HAVE_CONFIG_H#include <config.h>#endif#include <stdio.h>#include <errno.h>#include <fcntl.h>#include <unistd.h>#include <stdlib.h>#include <stdint.h>#include <string.h>#include <libgen.h>#if __BYTE_ORDER == __LITTLE_ENDIANstruct sbc_frame_hdr {	uint8_t syncword:8;		/* Sync word */	uint8_t subbands:1;		/* Subbands */	uint8_t allocation_method:1;	/* Allocation method */	uint8_t channel_mode:2;		/* Channel mode */	uint8_t blocks:2;		/* Blocks */	uint8_t sampling_frequency:2;	/* Sampling frequency */	uint8_t bitpool:8;		/* Bitpool */	uint8_t crc_check:8;		/* CRC check */} __attribute__ ((packed));#elif __BYTE_ORDER == __BIG_ENDIANstruct sbc_frame_hdr {	uint8_t syncword:8;		/* Sync word */	uint8_t sampling_frequency:2;	/* Sampling frequency */	uint8_t blocks:2;		/* Blocks */	uint8_t channel_mode:2;		/* Channel mode */	uint8_t allocation_method:1;	/* Allocation method */	uint8_t subbands:1;		/* Subbands */	uint8_t bitpool:8;		/* Bitpool */	uint8_t crc_check:8;		/* CRC check */} __attribute__ ((packed));#else#error "Unknown byte order"#endifstatic int calc_frame_len(struct sbc_frame_hdr *hdr){	int tmp, nrof_subbands, nrof_blocks;	nrof_subbands = (hdr->subbands + 1) * 4;/*子帶數目4 /8*/	nrof_blocks = (hdr->blocks + 1) * 4;/*blocks number 4 /8/12/16*/	switch (hdr->channel_mode) {	case 0x00:/*MONO*/		nrof_subbands /= 2;		tmp = nrof_blocks * hdr->bitpool;		break;	case 0x01:/*DUAL_CHANNEL*/		tmp = nrof_blocks * hdr->bitpool * 2;		break;	case 0x02:/*STEREO*/		tmp = nrof_blocks * hdr->bitpool;		break;	case 0x03:/*JOIN_STEREO*/		tmp = nrof_blocks * hdr->bitpool + nrof_subbands;		break;	default:		return 0;	}	return (nrof_subbands + ((tmp + 7) / 8));}static double calc_bit_rate(struct sbc_frame_hdr *hdr){	int nrof_subbands, nrof_blocks;	double f;	nrof_subbands = (hdr->subbands + 1) * 4;	nrof_blocks = (hdr->blocks + 1) * 4;	switch (hdr->sampling_frequency) {	case 0:		f = 16;		break;	case 1:		f = 32;		break;	case 2:		f = 44.1;		break;	case 3:		f = 48;		break;	default:		return 0;	}	return ((8 * (calc_frame_len(hdr) + 4) * f) /			(nrof_subbands * nrof_blocks));}static char *freq2str(uint8_t freq){	switch (freq) {	case 0:		return "16 kHz";	case 1:		return "32 kHz";	case 2:		return "44.1 kHz";	case 3:		return "48 kHz";	default:		return "Unknown";	}}static char *mode2str(uint8_t mode){	switch (mode) {	case 0:		return "Mono";	case 1:		return "Dual Channel";	case 2:		return "Stereo";	case 3:		return "Joint Stereo";	default:		return "Unknown";	}}static ssize_t __read(int fd, void *buf, size_t count){	ssize_t len, pos = 0;	while (count > 0) {		len = read(fd, buf + pos, count);		if (len <= 0)			return len;		count -= len;		pos   += len;	}	return pos;}#define SIZE 32static int analyze_file(char *filename){	struct sbc_frame_hdr hdr;	unsigned char buf[64];	double rate;	int bitpool[SIZE], frame_len[SIZE];	int subbands, blocks, freq, mode, method;	int n, p1, p2, fd, len, size, count, num;	if (strcmp(filename, "-")) {		printf("Filename\t\t%s\n", basename(filename));		fd = open(filename, O_RDONLY);		if (fd < 0) {			perror("Can't open file");			return -1;		}	} else		fd = fileno(stdin);	len = __read(fd, &hdr, sizeof(hdr));/*READ THE HEAD OF THE FILE*/	if (len != sizeof(hdr) || hdr.syncword != 0x9c ) {		fprintf(stderr, "Not a SBC audio file\n");		return -1;	}    /*GET THE PARAMETER*/	subbands = (hdr.subbands + 1) * 4;	blocks = (hdr.blocks + 1) * 4;	freq = hdr.sampling_frequency;	mode = hdr.channel_mode;	method = hdr.allocation_method;	count = calc_frame_len(&hdr);	bitpool[0] = hdr.bitpool;	frame_len[0] = count + 4;	for (n = 1; n < SIZE; n++) {		bitpool[n] = 0;		frame_len[n] = 0;	}    /*count is frame len*/	if (lseek(fd, 0, SEEK_SET) < 0) {		num = 1;		rate = calc_bit_rate(&hdr);		while (count) {			size = count > sizeof(buf) ? sizeof(buf) : count;			len = __read(fd, buf, size);			if (len < 0)				break;			count -= len;		}	} else {		num = 0;		rate = 0;	}	while (1) {		len = __read(fd, &hdr, sizeof(hdr));		if (len < 0) {			fprintf(stderr, "Unable to read frame header"					" (error %d)\n", errno);			break;		}		if (len == 0)			break;		if (len < sizeof(hdr) || hdr.syncword != 0x9c) {			fprintf(stderr, "Corrupted SBC stream "					"(len %d syncword 0x%02x)\n",					len, hdr.syncword);			break;		}		count = calc_frame_len(&hdr);		len = count + 4;/*add the header len*/		p1 = -1;		p2 = -1;		for (n = 0; n < SIZE; n++) {			if (p1 < 0 && (bitpool[n] == 0 || bitpool[n] == hdr.bitpool))				p1 = n;			if (p2 < 0 && (frame_len[n] == 0 || frame_len[n] == len))				p2 = n;		}		if (p1 >= 0)			bitpool[p1] = hdr.bitpool;		if (p2 >= 0)			frame_len[p2] = len;		while (count) {			size = count > sizeof(buf) ? sizeof(buf) : count;			len = __read(fd, buf, size);			if (len != size) {				fprintf(stderr, "Unable to read frame data "						"(error %d)\n", errno);				break;			}			count -= len;		}		rate += calc_bit_rate(&hdr);		num++;	}	printf("Subbands\t\t%d\n", subbands);	printf("Block length\t\t%d\n", blocks);	printf("Sampling frequency\t%s\n", freq2str(freq));	printf("Channel mode\t\t%s\n", mode2str(hdr.channel_mode));	printf("Allocation method\t%s\n", method ? "SNR" : "Loudness");	printf("Bitpool\t\t\t%d", bitpool[0]);	for (n = 1; n < SIZE; n++)		if (bitpool[n] > 0)			printf(", %d", bitpool[n]);	printf("\n");	printf("Number of frames\t%d\n", num);	printf("Frame length\t\t%d", frame_len[0]);	for (n = 1; n < SIZE; n++)		if (frame_len[n] > 0)			printf(", %d", frame_len[n]);	printf(" Bytes\n");	if (num > 0)		printf("Bit rate\t\t%.3f kbps\n", rate / num);	if (fd > fileno(stderr))		close(fd);	printf("\n");	return 0;}int main(int argc, char *argv[]){	int i;	if (argc < 2) {		fprintf(stderr, "Usage: sbcinfo <file>\n");		exit(1);	}	for (i = 0; i < argc - 1; i++)		if (analyze_file(argv[i + 1]) < 0)			exit(1);	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品ⅴa在线观看| 亚洲婷婷国产精品电影人久久| 久久 天天综合| 欧美mv日韩mv国产| 国产一区二区三区蝌蚪| www日韩大片| 丁香网亚洲国际| 精品国产免费视频| 国产一区二区不卡老阿姨| 欧美高清在线一区二区| 成人福利视频在线| 亚洲日本免费电影| 精品婷婷伊人一区三区三| 天天综合日日夜夜精品| 日韩午夜精品视频| 国产福利不卡视频| 国产精品毛片大码女人| 91视频在线观看| 一区二区三区高清| 欧美日韩国产中文| 免费人成在线不卡| 久久精品夜色噜噜亚洲aⅴ| 不卡的av在线播放| 亚洲综合久久久久| 日韩一级片网址| 国产剧情一区在线| 中文字幕一区av| 欧美亚洲图片小说| 男女性色大片免费观看一区二区 | 日韩午夜激情av| 国产美女一区二区三区| 国产精品动漫网站| 欧美日韩国产一级| 国内精品伊人久久久久av一坑| 中文字幕av不卡| 色综合天天综合网天天看片| 一区二区三区91| 欧美一区二区三区白人| 国产成人自拍网| 国产精品妹子av| 色综合网站在线| 日本欧洲一区二区| 欧美国产一区二区在线观看 | 不卡一区二区三区四区| 亚洲一区二区精品视频| 久久综合久久99| 91丨porny丨首页| 三级一区在线视频先锋| 精品美女一区二区三区| 色综合一区二区| 加勒比av一区二区| 亚洲精品成人精品456| 欧美一区日本一区韩国一区| 成人激情开心网| 亚洲成人动漫在线免费观看| 久久久久久久久一| 欧美网站大全在线观看| 国产精品99久久不卡二区| 亚洲一区在线视频观看| 久久精品视频免费观看| 欧美日韩一区二区三区四区五区| 国产剧情一区二区| 亚洲香肠在线观看| 国产欧美日产一区| 欧洲中文字幕精品| 国产99精品国产| 亚洲超碰97人人做人人爱| 中文字幕免费不卡| 日韩一二三区视频| 在线看日韩精品电影| 国产盗摄女厕一区二区三区| 日韩精品免费专区| 国产精品高潮呻吟久久| 亚洲人成电影网站色mp4| 日韩美一区二区三区| 在线视频中文字幕一区二区| 国产成人午夜99999| 亚洲国产精品一区二区www在线| 国产日韩欧美综合在线| 56国语精品自产拍在线观看| 91亚洲大成网污www| 国内一区二区视频| 日韩成人精品视频| 一区二区三区在线视频播放| 亚洲国产精品成人久久综合一区| 欧美一区二区三区四区视频| 9i看片成人免费高清| 国产精品99久久久久久宅男| 秋霞午夜av一区二区三区| 亚洲精品水蜜桃| 日本一区二区三区高清不卡| 欧美成人在线直播| 欧美麻豆精品久久久久久| 色综合天天综合网天天狠天天 | 国内精品伊人久久久久av一坑| 调教+趴+乳夹+国产+精品| 欧美韩国日本综合| 久久婷婷成人综合色| 日韩一区二区麻豆国产| 欧美丝袜丝交足nylons图片| 色综合一个色综合亚洲| av中文字幕在线不卡| 久久99国产精品尤物| 五月天一区二区三区| 亚洲一二三四久久| 亚洲黄色av一区| 中文字幕综合网| 亚洲同性同志一二三专区| 国产精品美女www爽爽爽| 国产日韩欧美精品综合| 久久午夜色播影院免费高清| 精品日韩欧美在线| 精品免费一区二区三区| 欧美sm美女调教| 亚洲精品一区二区三区影院| 精品久久久久久久人人人人传媒| 欧美一区二区视频在线观看2020 | 国产麻豆精品视频| 狠狠色伊人亚洲综合成人| 久久99久久久久| 久久99久久99小草精品免视看| 久久国产精品99精品国产| 久久av资源站| 国产乱码精品一区二区三区av| 国产麻豆9l精品三级站| 国产传媒欧美日韩成人| 国产福利精品一区| 波多野洁衣一区| 不卡免费追剧大全电视剧网站| 色综合久久综合中文综合网| 欧美日韩国产一级片| 日韩一区二区免费视频| 国产视频一区二区三区在线观看| 国产精品久久网站| 亚洲一区二区在线播放相泽| 免费在线观看精品| 国产成人午夜高潮毛片| 色偷偷久久人人79超碰人人澡| 欧美日韩国产综合久久 | 91精品国产综合久久久蜜臀粉嫩| 欧美tickling网站挠脚心| 日本一二三不卡| 亚洲狠狠爱一区二区三区| 青青草91视频| 成人毛片在线观看| 在线精品视频免费播放| 日韩免费高清视频| 国产精品久久久久影视| 香蕉加勒比综合久久| 久久99精品久久久久婷婷| 不卡一区二区在线| 在线播放中文一区| 中文字幕不卡在线观看| 亚洲国产日韩在线一区模特| 韩国欧美国产1区| 色94色欧美sute亚洲线路一ni | 国产亚洲精品资源在线26u| 日韩美女久久久| 青娱乐精品视频| 欧美伦理影视网| 国产精品视频你懂的| 无码av免费一区二区三区试看| 国产精品一区二区久久不卡| 色综合天天性综合| 精品久久久影院| 亚洲综合在线第一页| 国产麻豆日韩欧美久久| 欧美三级中文字幕| 国产欧美一区二区精品仙草咪| 亚洲亚洲精品在线观看| 国产成人精品一区二| 欧美日韩一区二区三区在线| 国产欧美日韩在线| 日韩精品国产欧美| 成人精品鲁一区一区二区| 欧美久久久久免费| 中文字幕五月欧美| 美脚の诱脚舐め脚责91| 91免费精品国自产拍在线不卡| 精品国产乱码久久久久久牛牛| 亚洲另类一区二区| 国产精品亚洲成人| 91精品国产一区二区三区香蕉| 亚洲婷婷综合色高清在线| 国内偷窥港台综合视频在线播放| 欧美午夜电影网| 国产精品夫妻自拍| 韩国v欧美v日本v亚洲v| 欧美精品久久一区二区三区| 国产精品久久久久久久久免费相片 | 男女性色大片免费观看一区二区 | 欧美日韩精品电影| 亚洲欧洲日产国产综合网| 精品一区二区影视| 欧美日韩一区二区三区四区五区| 国产精品青草综合久久久久99| 经典三级一区二区| 337p亚洲精品色噜噜| 亚洲综合激情小说| 91丨九色丨黑人外教|