| 
							- /*
 - ** Copyright (c) 2002-2016, Erik de Castro Lopo <erikd@mega-nerd.com>
 - ** All rights reserved.
 - **
 - ** This code is released under 2-clause BSD license. Please see the
 - ** file at : https://github.com/erikd/libsamplerate/blob/master/COPYING
 - */
 - 
 - #include <stdio.h>
 - #include <stdlib.h>
 - #include <string.h>
 - #include <ctype.h>
 - #include <math.h>
 - 
 - #include	"util.h"
 - 
 - #ifndef	M_PI
 - #define	M_PI			3.14159265358979323846264338
 - #endif
 - 
 - void
 - gen_windowed_sines (int freq_count, const double *freqs, double max, float *output, int output_len)
 - {	int 	k, freq ;
 - 	double	amplitude, phase ;
 - 
 - 	amplitude = max / freq_count ;
 - 
 - 	for (k = 0 ; k < output_len ; k++)
 - 		output [k] = 0.0 ;
 - 
 - 	for (freq = 0 ; freq < freq_count ; freq++)
 - 	{	phase = 0.9 * M_PI / freq_count ;
 - 
 - 		if (freqs [freq] <= 0.0 || freqs [freq] >= 0.5)
 - 		{	printf ("\n%s : Error : freq [%d] == %g is out of range. Should be < 0.5.\n", __FILE__, freq, freqs [freq]) ;
 - 			exit (1) ;
 - 			} ;
 - 
 - 		for (k = 0 ; k < output_len ; k++)
 - 			output [k] += amplitude * sin (freqs [freq] * (2 * k) * M_PI + phase) ;
 - 		} ;
 - 
 - 	/* Apply Hanning Window. */
 - 	for (k = 0 ; k < output_len ; k++)
 - 		output [k] *= 0.5 - 0.5 * cos ((2 * k) * M_PI / (output_len - 1)) ;
 - 
 - 	/*	data [k] *= 0.3635819 - 0.4891775 * cos ((2 * k) * M_PI / (output_len - 1))
 - 					+ 0.1365995 * cos ((4 * k) * M_PI / (output_len - 1))
 - 					- 0.0106411 * cos ((6 * k) * M_PI / (output_len - 1)) ;
 - 		*/
 - 
 - 	return ;
 - } /* gen_windowed_sines */
 - 
 - void
 - save_oct_float (char *filename, float *input, int in_len, float *output, int out_len)
 - {	FILE 	*file ;
 - 	int		k ;
 - 
 - 	printf ("Dumping input and output data to file : %s.\n\n", filename) ;
 - 
 - 	if (! (file = fopen (filename, "w")))
 - 		return ;
 - 
 - 	fprintf (file, "# Not created by Octave\n") ;
 - 
 - 	fprintf (file, "# name: input\n") ;
 - 	fprintf (file, "# type: matrix\n") ;
 - 	fprintf (file, "# rows: %d\n", in_len) ;
 - 	fprintf (file, "# columns: 1\n") ;
 - 
 - 	for (k = 0 ; k < in_len ; k++)
 - 		fprintf (file, "% g\n", input [k]) ;
 - 
 - 	fprintf (file, "# name: output\n") ;
 - 	fprintf (file, "# type: matrix\n") ;
 - 	fprintf (file, "# rows: %d\n", out_len) ;
 - 	fprintf (file, "# columns: 1\n") ;
 - 
 - 	for (k = 0 ; k < out_len ; k++)
 - 		fprintf (file, "% g\n", output [k]) ;
 - 
 - 	fclose (file) ;
 - 	return ;
 - } /* save_oct_float */
 - 
 - void
 - save_oct_double (char *filename, double *input, int in_len, double *output, int out_len)
 - {	FILE 	*file ;
 - 	int		k ;
 - 
 - 	printf ("Dumping input and output data to file : %s.\n\n", filename) ;
 - 
 - 	if (! (file = fopen (filename, "w")))
 - 		return ;
 - 
 - 	fprintf (file, "# Not created by Octave\n") ;
 - 
 - 	fprintf (file, "# name: input\n") ;
 - 	fprintf (file, "# type: matrix\n") ;
 - 	fprintf (file, "# rows: %d\n", in_len) ;
 - 	fprintf (file, "# columns: 1\n") ;
 - 
 - 	for (k = 0 ; k < in_len ; k++)
 - 		fprintf (file, "% g\n", input [k]) ;
 - 
 - 	fprintf (file, "# name: output\n") ;
 - 	fprintf (file, "# type: matrix\n") ;
 - 	fprintf (file, "# rows: %d\n", out_len) ;
 - 	fprintf (file, "# columns: 1\n") ;
 - 
 - 	for (k = 0 ; k < out_len ; k++)
 - 		fprintf (file, "% g\n", output [k]) ;
 - 
 - 	fclose (file) ;
 - 	return ;
 - } /* save_oct_double */
 - 
 - void
 - interleave_data (const float *in, float *out, int frames, int channels)
 - {	int fr, ch ;
 - 
 - 	for (fr = 0 ; fr < frames ; fr++)
 - 		for (ch = 0 ; ch < channels ; ch++)
 - 			out [ch + channels * fr] = in [fr + frames * ch] ;
 - 
 - 	return ;
 - } /* interleave_data */
 - 
 - void
 - deinterleave_data (const float *in, float *out, int frames, int channels)
 - {	int fr, ch ;
 - 
 - 	for (ch = 0 ; ch < channels ; ch++)
 - 		for (fr = 0 ; fr < frames ; fr++)
 - 			out [fr + frames * ch] = in [ch + channels * fr] ;
 - 
 - 	return ;
 - } /* deinterleave_data */
 - 
 - void
 - reverse_data (float *data, int datalen)
 - {	int left, right ;
 - 	float temp ;
 - 
 - 	left = 0 ;
 - 	right = datalen - 1 ;
 - 
 - 	while (left < right)
 - 	{	temp = data [left] ;
 - 		data [left] = data [right] ;
 - 		data [right] = temp ;
 - 		left ++ ;
 - 		right -- ;
 - 		} ;
 - 
 - } /* reverse_data */
 - 
 - const char *
 - get_cpu_name (void)
 - {
 - 	const char *name = "Unknown", *search = NULL ;
 - 	static char buffer [512] ;
 - 	FILE * file = NULL ;
 - 	int is_pipe = 0 ;
 - 
 - #if defined (__linux__)
 - 	file = fopen ("/proc/cpuinfo", "r") ;
 - 	search = "model name" ;
 - #elif defined (__APPLE__)
 - 	file = popen ("/usr/sbin/system_profiler -detailLevel full SPHardwareDataType", "r") ;
 - 	search = "Processor Name" ;
 - 	is_pipe = 1 ;
 - #elif defined (__FreeBSD__)
 - 	file = popen ("sysctl -a", "r") ;
 - 	search = "hw.model" ;
 - 	is_pipe = 1 ;
 - #else
 - 	file = NULL ;
 - #endif
 - 
 - 	if (file == NULL)
 - 		return name ;
 - 
 - 	if (search == NULL)
 - 	{	printf ("Error : search is NULL in function %s.\n", __func__) ;
 - 		return name ;
 - 		} ;
 - 
 - 	while (fgets (buffer, sizeof (buffer), file) != NULL)
 - 		if (strstr (buffer, search))
 - 		{	char *src, *dest ;
 - 
 - 			if ((src = strchr (buffer, ':')) != NULL)
 - 			{	src ++ ;
 - 				while (isspace (src [0]))
 - 					src ++ ;
 - 				name = src ;
 - 
 - 				/* Remove consecutive spaces. */
 - 				src ++ ;
 - 				for (dest = src ; src [0] ; src ++)
 - 				{	if (isspace (src [0]) && isspace (dest [-1]))
 - 						continue ;
 - 					dest [0] = src [0] ;
 - 					dest ++ ;
 - 					} ;
 - 				dest [0] = 0 ;
 - 				break ;
 - 				} ;
 - 			} ;
 - 
 - 	if (is_pipe)
 - 		pclose (file) ;
 - 	else
 - 		fclose (file) ;
 - 
 - 	return name ;
 - } /* get_cpu_name */
 
 
  |