#include <cmath>
#include <vector>
#include <limits>
#include <cstdint>
#include <fstream>
#include <random>
#include <string>
#include <algorithm>
//FMで自分が何をコントロールしているのかさっぱりわからん。。。Orz
//Becarefull wait a play generate file.
//it's easy crash the your ear.
static const int Sample_ = 44100 ;
template < class Float>
std:: vector < Float> MakeBuffer( std:: size_t SampleRate, std:: size_t MilliSec) {
std:: vector < Float> v( static_cast < std:: size_t > ( SampleRate* ( MilliSec / ( static_cast < Float> ( 1000.0 ) ) ) ) ) ;
return v;
}
template < class Float>
bool MakeSinWave( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
Float PI = 3.14159265359 ; //from google.
Float Rad = ( ( 2 * PI) / One) ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
D[ i] = std:: sin ( Rad* std:: fmod ( static_cast < Float> ( i) , One) ) ;
}
return true ;
}
template < class Float>
bool MakeSawWave( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
Float Value = 2.0 / One;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
D[ i] = std:: fmod ( Value* i,2 ) - 1 ;
}
return true ;
}
template < class Float>
bool MakeTriangleWave( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
Float Value = 1.0 / ( One/ 4 ) ;
Float B = - 1 ;
Float Sign = 1 ;
bool F = false ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
if ( std:: abs ( B + ( Value* Sign) ) > 1 ) {
B - = ( std:: fmod ( std:: abs ( B + ( Value* Sign) ) , 1 ) * Sign) ;
Sign * = - 1 ;
}
else {
B + = Value* Sign;
}
D[ i] = B;
}
return true ;
}
template < class Float>
bool MakeSquareWave( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
Float Value = 1 ;
Float Sign = 1 ;
Float A = 0 ;
Float B = 0 ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
if ( static_cast < int > ( A) > static_cast < int > ( B) ) {
B = A;
Sign * = - 1 ;
}
A = i / ( One/ 2 ) ;
D[ i] = Value* Sign;
}
return true ;
}
template < class Float>
bool MakeHzNoise( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
Float Value = 1 ;
Float A = 0 ;
Float B = 0 ;
std:: random_device rd;
std:: mt19937 mt( rd( ) ) ;
std:: uniform_real_distribution < Float> URD( - 1 , 1 ) ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
if ( static_cast < int > ( A) > static_cast < int > ( B) ) {
B = A;
Value = URD( mt) ;
}
A = i / ( One/ 2 ) ;
D[ i] = Value;
}
return true ;
}
template < class Float>
bool MakeParfectNoise( std:: vector < Float> & D,std:: size_t SampleRate, std:: size_t Hz ) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = SampleRate_ / Hz_;
std:: random_device rd;
std:: mt19937 mt( rd( ) ) ;
std:: uniform_real_distribution < Float> URD( - 1 , 1 ) ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
D[ i] = URD( mt) ;
}
return true ;
}
template < class Float>
Float Sin( const Float& D) { //[0,1]
Float PI = 3.14159265359 ; //from google.
Float Delta = std:: fmod ( std:: abs ( D) , 1 ) ;
return std:: sin ( 2 * PI* Delta) ;
}
template < class Float>
Float Saw( const Float& D) { //[0,1]
Float Delta = std:: fmod ( std:: abs ( D) + 0.5 , 1 ) ;
return - 1 + ( Delta * 2 ) ;
}
template < class Float>
Float Square( const Float& D) { //[0,1]
Float Delta = std:: fmod ( std:: abs ( D) , 1 ) ;
return Delta > 0.5 ? 1 : - 1 ;
}
template < class Float>
Float Triangle( const Float& D) { //[0,1]
Float Delta = std:: fmod ( std:: abs ( D) , 1 ) ;
std:: uint64_t F = static_cast < std:: uint64_t > ( Delta / 0.25 ) ;
Float V = std:: fmod ( Delta, 0.25 ) * 4 ;
switch ( F)
{
case 0 :
return V;
case 1 :
return 1 - V;
case 2 :
return - V;
case 3 :
return - 1 + V;
default :
break ;
}
return 0 ;
}
template < class Float>
Float Trapezoid( const Float& D) { //[0,1]
Float Delta = std:: fmod ( std:: abs ( D) , 1 ) ;
std:: uint64_t F = static_cast < std:: uint64_t > ( Delta / ( 1 / 8.0 ) ) ;
Float V = std:: fmod ( Delta, ( 1 / 8.0 ) ) * 8 ;
switch ( F)
{
case 0 :
return V;
case 1 :
case 2 :
return 1 ;
case 3 :
return 1 - V;
case 4 :
return - V;
case 5 :
case 6 :
return - 1 ;
case 7 :
return - 1 + V;
default :
break ;
}
return 0 ;
}
template < class Float>
Float Noize( const Float& D) { //[0,1]
Float Delta = std:: fmod ( std:: abs ( D) , 1 ) ;
std:: mt19937 mt( static_cast < unsigned int > ( std:: numeric_limits < unsigned int > :: max ( ) * Delta) ) ;
std:: uniform_real_distribution < Float> uid( - 1 , 1 ) ;
return uid( mt) ;
}
template < class Float>
Float PerfectNoize( const Float& D) { //[0,1]
std:: random_device rd;
std:: uniform_real_distribution < Float> uid( - 1 , 1 ) ;
return uid( rd) ;
}
template < class Float , class F>
bool GeneratorTmplate( std:: vector < Float> & D, std:: size_t SampleRate, std:: size_t Hz,F Fun) {
Float Hz_ = Hz;
Float SampleRate_ = SampleRate;
Float One = 1 / ( SampleRate_ / Hz_) ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
D[ i] = Fun( One* i) ;
}
return true ;
}
//https://e...content-available-to-author-only...a.org/wiki/Frequency_modulation_synthesis#Spectral_analysis
template < class Float>
std:: vector < Float> FM_( const std:: vector < Float> & D,const std:: vector < Float> & M, double FirstTheta, double SecandTheta ) { //, double Time) {
std:: vector < Float> R;
double PI = 3.14159265358979323846 ;
double Rad = 180.0 / PI;
for ( std:: size_t i = 1 ; i < D.size ( ) ; i++ ) {
//double T = (M[i % M.size()] * std::sin((FirstTheta*Rad) + (SecandTheta*Rad)*i ))*(static_cast<double>(D.size()) / static_cast<double>(i));
double T = ( static_cast < double > ( D.size ( ) ) / static_cast < double > ( i) ) ;
double Mul = std:: sin ( ( FirstTheta* Rad) * T + M[ i % M.size ( ) ] * std:: sin ( ( SecandTheta* Rad) ) * T) ;
R.push_back ( D[ i] * Mul) ;
}
return R;
}
template < class Float,class F1,class F2>
Float FMOne( const Float& A, const Float& B,const Float& InitA, const Float& InitB, const Float& Time, F1 Fun1, F2 Fun2) {
return A* Fun1( InitA* Time + B* Fun2( InitB* Time) ) ;
}
template < class Float,class F1,class F2>
std:: vector < Float> FM( const std:: vector < Float> & D, const std:: vector < Float> & M, const Float& InitA, const Float& InitB, F1 Fun1, F2 Fun2) {
std:: vector < Float> R;
for ( std:: size_t i = 1 ; i < D.size ( ) ; i++ ) {
Float V = FMOne( D[ i] , M[ i% M.size ( ) ] , InitA, InitB, i / static_cast < Float> ( D.size ( ) ) , Fun1, Fun2) ;
R.push_back ( V) ;
}
return R;
}
template < class Float,class F1,class F2,class F3>
Float FMOne2( const Float& A, F3 B,const Float& InitB, F1 Fun1,const Float& Init1, F2 Fun2,const Float& Init2 ,const Float& Time) {
return A* Fun1( Init1* Time + B( Time* InitB) * Fun2( Init2* Time) ) ;
}
template < class Float,class F1,class F2,class F3>
std:: vector < Float> FM2( const std:: vector < Float> & D, F3 B,const Float& InitB, F1 Fun1,const Float& Init1, F2 Fun2,const Float& Init2 ) {
std:: vector < Float> R;
for ( std:: size_t i = 1 ; i < D.size ( ) ; i++ ) {
Float V = FMOne2( D[ i] ,B,InitB,Fun1,Init1,Fun2,Init2, i / static_cast < Float> ( D.size ( ) ) ) ;
R.push_back ( V) ;
}
return R;
}
template < class Int,class Float>
std:: vector < Int> MakeWaveInstance( std:: vector < Float> & F,double Volume) {
std:: vector < Int> R;
for ( auto o : F) {
R.push_back ( static_cast < Int> ( o* ( std:: numeric_limits < Int> :: max ( ) ) * Volume) ) ;
}
return R;
}
template < class Int>
bool WriteWaveFile( std:: vector < Int> & D, std:: uint64_t Hz, std:: uint16_t Channel, std:: string Name = "out.wav" ) {
std:: ofstream ofs( Name, std:: ios :: binary ) ;
char RIFF[ ] = "RIFF" ;
char WAVE[ ] = "WAVE" ;
char fmt[ ] = "fmt " ;
char data[ ] = "data" ;
std:: uint32_t FSize = ( 44 - 8 ) + ( D.size ( ) * sizeof ( std:: vector < Int> :: value_type ) ) ;
std:: uint32_t ui32 = 0 ;
std:: uint16_t ui16 = 0 ;
ofs.write ( RIFF, 4 ) ;
ofs.write ( reinterpret_cast < const char * > ( & FSize) , 4 ) ; //fsize-8.
ofs.write ( WAVE, 4 ) ;
ofs.write ( fmt, 4 ) ;
ui32 = 16 ;
ofs.write ( reinterpret_cast < const char * > ( & ui32) , 4 ) ; //fmt chunk size
ui16 = 1 ;
ofs.write ( reinterpret_cast < const char * > ( & ui16) , 2 ) ; //sound type. PCM = 1.
ui16 = Channel;
ofs.write ( reinterpret_cast < const char * > ( & ui16) , 2 ) ; //Channnel count.
ui32 = static_cast < std:: uint32_t > ( Hz) ;
ofs.write ( reinterpret_cast < const char * > ( & ui32) , 4 ) ; //Sampling Hz.
ui32 = static_cast < std:: uint32_t > ( Hz* Channel* ( sizeof ( std:: vector < Int> :: value_type ) ) ) ;
ofs.write ( reinterpret_cast < const char * > ( & ui32) , 4 ) ; //data speed??
ui16 = Channel* ( sizeof ( std:: vector < Int> :: value_type ) ) ;
ofs.write ( reinterpret_cast < const char * > ( & ui16) , 2 ) ; //BlockSize??
ui16 = ( sizeof ( std:: vector < Int> :: value_type ) * 8 ) ;
ofs.write ( reinterpret_cast < const char * > ( & ui16) , 2 ) ; //Sampling Bit.
ofs.write ( data, 4 ) ;
ui32 = static_cast < std:: uint32_t > ( D.size ( ) * sizeof ( std:: vector < Int> :: value_type ) ) ;
ofs.write ( reinterpret_cast < const char * > ( & ui32) , 4 ) ; //Sample's ALL SIZE.max at 32bit.
ofs.write ( reinterpret_cast < const char * > ( & D[ 0 ] ) , D.size ( ) * sizeof ( std:: vector < Int> :: value_type ) ) ; //WriteSamples.
return true ;
}
template < class T>
bool VolumeChenger( std:: vector < T> & D ,double Percentage) { ///1.0 => 100 Percent;
for ( auto o : D) {
o * = Percentage;
}
return true ;
}
template < class Float>
bool VolumeNormalize( std:: vector < Float> & D ) {
Float Max= 0 ;
Float M = 0 ;
for ( std:: size_t i = 0 ; i < D.size ( ) ; i++ ) {
Max = std:: max < Float> ( Max, std:: abs ( D[ i] ) ) ;
}
M = 1 / Max;
for ( auto o : D) {
o * = M;
}
return true ;
}
void Test( std:: size_t SampleRate,std:: size_t MilliSec,double Volume) {
std:: vector < std:: int16_t > D;
std:: vector < double > B;
std:: string Path = "./wav/" ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSinWave( B, Sample_, 220 ) ;
//VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , ( Path+ "Sin.wav" ) ) ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSawWave( B, Sample_, 220 ) ;
//VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "Saw.wav" ) ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeTriangleWave( B, Sample_, 220 ) ;
//VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "Triangle.wav" ) ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSquareWave( B, Sample_, 220 ) ;
///VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "Square.wav" ) ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeHzNoise( B, Sample_, 220 ) ;
//VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "HzNoize.wav" ) ;
B = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeParfectNoise( B, Sample_, 220 ) ;
//VolumeChenger(B, Volume);
D = MakeWaveInstance< std:: int16_t > ( B, Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "PNoise.wav" ) ;
}
void GeneratorTest( ) {
std:: vector < std:: int16_t > D;
std:: vector < double > B1;
std:: vector < double > B2;
std:: vector < double > R;
std:: string Path = "./wav/" ;
std:: size_t SampleRate= Sample_;
std:: size_t MilliSec = 2000 ;
double Volume= 1.0 ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Sin< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "SinF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Saw< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "SawF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Square< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "SquareF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Triangle< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "TriangleF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Trapezoid< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "TrapezoidF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , Noize< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "NoizeF.wav" ) ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
GeneratorTmplate( B1, Sample_, 220 , PerfectNoize< double > ) ;
D = MakeWaveInstance< std:: int16_t > ( B1,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "PNoizeF.wav" ) ;
}
void FMTest( ) {
std:: vector < std:: int16_t > D;
std:: vector < double > B1;
std:: vector < double > B2;
std:: vector < double > R;
std:: string Path = "./wav/" ;
std:: size_t SampleRate= Sample_;
std:: size_t MilliSec = 2000 ;
double Volume= 0.8 ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSawWave( B1, Sample_, 220 ) ;
VolumeChenger( B1, 0.1 ) ;
B2 = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSinWave( B2, Sample_, 220 ) ;
//MakeHzNoise(B2, Sample_, 220);
//MakeSawWave(B2, Sample_, 220);
VolumeChenger( B2, 0.1 ) ;
R = FM_( B1, B2, 30 , 7 ) ;
//R = FM_(R, B1, 30, 120);
//VolumeNormalize<double>(R);
//VolumeChenger(B2, 1/3.0);
D = MakeWaveInstance< std:: int16_t > ( R,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "FM.wav" ) ;
}
void FMTest2( ) {
std:: vector < std:: int16_t > D;
std:: vector < double > B1;
std:: vector < double > B2;
std:: vector < double > R;
std:: string Path = "./wav/" ;
std:: size_t SampleRate= Sample_;
std:: size_t MilliSec = 2000 ;
double Volume= 0.8 ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSinWave( B1, Sample_, 220 ) ;
VolumeChenger( B1, 0.1 ) ;
B2 = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeTriangleWave( B2, Sample_, 220 ) ;
//MakeHzNoise(B2, Sample_, 220);
//MakeSawWave(B2, Sample_, 220);
//VolumeChenger(B2, 0.1);
R = FM< double > ( B1, B2, 30 / 360.0 ,3000 ,Sin< double > ,Sin< double > ) ;
//R = FM(R, B1, 30, 120);
//VolumeNormalize<double>(R);
//VolumeChenger(B2, 1/3.0);
D = MakeWaveInstance< std:: int16_t > ( R,Volume) ;
WriteWaveFile( D, Sample_, 1 , Path+ "FMG.wav" ) ;
}
void FMTest3( ) {
std:: vector < std:: int16_t > D;
std:: vector < double > B1;
std:: vector < double > R;
std:: string Path = "./wav/" ;
std:: size_t SampleRate= Sample_;
std:: size_t MilliSec = 2000 ;
double Volume= 0.8 ;
std:: uint16_t Channel = 1 ;
B1 = MakeBuffer< double > ( SampleRate, MilliSec) ;
MakeSinWave( B1, Sample_, 220 ) ;
R = FM2< double > ( B1,Sin< double > ,1 , Sin< double > ,30 / 360 , Sin< double > ,3000 ) ;
D = MakeWaveInstance< std:: int16_t > ( R,Volume) ;
WriteWaveFile( D, Sample_, Channel, Path+ "FMG2.wav" ) ;
}
int main( ) {
//Test(Sample_,2000,0.8);
//FMTest();
//GeneratorTest();
//FMTest2();
//FMTest3();
return true ;
}
#include <cmath>
#include <vector>
#include <limits>
#include <cstdint>
#include <fstream>
#include <random>
#include <string>
#include <algorithm>

//FMで自分が何をコントロールしているのかさっぱりわからん。。。Orz
//Becarefull wait a play generate file.
//it's easy crash the your ear.

static const int Sample_ = 44100;

template<class Float>
std::vector<Float> MakeBuffer(std::size_t SampleRate, std::size_t MilliSec) {
	std::vector<Float> v(static_cast<std::size_t>( SampleRate*(MilliSec / (static_cast<Float>(1000.0)))));
	return v;
}
template<class Float>
bool MakeSinWave(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	Float PI = 3.14159265359;//from google.
	Float Rad = ((2 * PI) / One);
	for (std::size_t i = 0; i < D.size(); i++) {
		D[i]=std::sin(Rad*std::fmod(static_cast<Float>(i), One));
	}
	
	return true;
}
template<class Float>
bool MakeSawWave(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	Float Value = 2.0 / One;

	for (std::size_t i = 0; i < D.size(); i++) {
		D[i]=std::fmod(Value*i,2)-1;
	}
	
	return true;
}
template<class Float>
bool MakeTriangleWave(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	Float Value = 1.0 /(One/4);
	Float B = -1;
	Float Sign = 1;
	bool F = false;
	for (std::size_t i = 0; i < D.size(); i++) {
		if (std::abs(B + (Value*Sign)) > 1) {
			B -= (std::fmod(std::abs(B + (Value*Sign)), 1)*Sign);
			Sign *= -1;
		}
		else {
			B += Value*Sign;
		}
		D[i] = B;
	}
	
	return true;
}
template<class Float>
bool MakeSquareWave(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	Float Value = 1;
	Float Sign = 1;
	Float A = 0;
	Float B = 0;
	for (std::size_t i = 0; i < D.size(); i++) {
		if (static_cast<int>(A) > static_cast<int>(B)) {
			B = A;
			Sign *= -1;
		}
		A = i / (One/2);
		D[i] = Value*Sign;
	}
	
	return true;
}
template<class Float>
bool MakeHzNoise(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	Float Value = 1;
	Float A = 0;
	Float B = 0;
	std::random_device rd;
	std::mt19937 mt(rd());
	std::uniform_real_distribution<Float> URD(-1, 1);
	for (std::size_t i = 0; i < D.size(); i++) {
		if (static_cast<int>(A) > static_cast<int>(B)) {
			B = A;
			Value = URD(mt);
		
		}
		A = i / (One/2);
		D[i] = Value;
	}
	
	return true;
}
template<class Float>
bool MakeParfectNoise(std::vector<Float>& D,std::size_t SampleRate, std::size_t Hz ) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = SampleRate_ / Hz_;
	std::random_device rd;
	std::mt19937 mt(rd());
	std::uniform_real_distribution<Float> URD(-1, 1);
	for (std::size_t i = 0; i < D.size(); i++) {
		D[i] = URD(mt);
	}
	
	return true;
}
template<class Float>
Float Sin(const Float& D) {//[0,1]
	Float PI = 3.14159265359;//from google.
	Float Delta = std::fmod(std::abs(D), 1);

	return std::sin(2*PI*Delta);
}
template<class Float>
Float Saw(const Float& D) {//[0,1]
	Float Delta = std::fmod(std::abs(D)+0.5, 1);

	return -1 + (Delta * 2);
}
template<class Float>
Float Square(const Float& D) {//[0,1]
	Float Delta = std::fmod(std::abs(D), 1);
	return Delta > 0.5 ? 1 : -1;
}
template<class Float>
Float Triangle(const Float& D) {//[0,1]	
	Float Delta = std::fmod(std::abs(D), 1);
	std::uint64_t F = static_cast<std::uint64_t>(Delta / 0.25);
	Float V = std::fmod(Delta, 0.25)*4;
	switch (F)
	{
		case 0:
			return V;
		case 1:
			return 1 - V;
		case 2:
			return -V;
		case 3:
			return -1 + V;
	default:
		break;
	}
	return 0;
}
template<class Float>
Float Trapezoid(const Float& D) {//[0,1]	
	Float Delta = std::fmod(std::abs(D), 1);
	std::uint64_t F = static_cast<std::uint64_t>(Delta / (1/8.0));
	Float V = std::fmod(Delta, (1/8.0))*8;
	switch (F)
	{
		case 0:
			return V;
		case 1:
		case 2:
			return 1;
		case 3:		
			return 1 - V;
		case 4:
			return - V;
		case 5:
		case 6:
			return -1;
		case 7:
			return -1 + V;
	default:
		break;
	}
	return 0;
}
template<class Float>
Float Noize(const Float& D) {//[0,1]
	Float Delta = std::fmod(std::abs(D), 1);
	std::mt19937 mt(static_cast<unsigned int>(std::numeric_limits<unsigned int>::max()*Delta));
	std::uniform_real_distribution<Float> uid(-1, 1);
	return uid(mt);
}
template<class Float>
Float PerfectNoize(const Float& D) {//[0,1]
	std::random_device rd;
	std::uniform_real_distribution<Float> uid(-1, 1);
	return uid(rd);
}
template <class Float , class F>
bool GeneratorTmplate(std::vector<Float>& D, std::size_t SampleRate, std::size_t Hz,F Fun) {
	Float Hz_ = Hz;
	Float SampleRate_ = SampleRate;
	Float One = 1/(SampleRate_ / Hz_);

	for (std::size_t i = 0; i < D.size(); i++) {
		D[i] = Fun(One*i);
	}

	return true;
}

//https://e...content-available-to-author-only...a.org/wiki/Frequency_modulation_synthesis#Spectral_analysis
template <class Float>
std::vector<Float> FM_(const std::vector<Float>& D,const std::vector<Float>& M, double FirstTheta, double SecandTheta ){     //, double Time) {
	std::vector<Float> R;
	double PI = 3.14159265358979323846;
	double Rad = 180.0 / PI;

	for (std::size_t i = 1; i < D.size(); i++) {
		//double T = (M[i % M.size()] * std::sin((FirstTheta*Rad) + (SecandTheta*Rad)*i ))*(static_cast<double>(D.size()) / static_cast<double>(i));
		double T = (static_cast<double>(D.size()) / static_cast<double>(i));
		double Mul = std::sin((FirstTheta*Rad)*T + M[i % M.size()] * std::sin((SecandTheta*Rad))*T);
		R.push_back(D[i] *Mul);
	}

	return R;

}

template<class Float,class F1,class F2>
Float FMOne(const Float& A, const Float& B,const Float& InitA, const Float& InitB, const Float& Time, F1 Fun1, F2 Fun2) {
	return A*Fun1(InitA*Time + B*Fun2(InitB*Time));
}
template<class Float,class F1,class F2>
std::vector<Float> FM(const std::vector<Float>& D, const std::vector<Float>& M, const Float& InitA, const Float& InitB, F1 Fun1, F2 Fun2) {	
	std::vector<Float> R;
	for (std::size_t i = 1; i < D.size(); i++) {
		Float V = FMOne(D[i], M[i%M.size()], InitA, InitB, i / static_cast<Float>(D.size()), Fun1, Fun2);
		R.push_back(V);
	}
	return R;
}
template<class Float,class F1,class F2,class F3>
Float FMOne2(const Float& A, F3 B,const Float& InitB, F1 Fun1,const Float& Init1,  F2 Fun2,const Float& Init2 ,const Float& Time) {
	return A*Fun1(Init1*Time + B(Time*InitB)*Fun2(Init2*Time));
}
template<class Float,class F1,class F2,class F3>
std::vector<Float> FM2(const std::vector<Float>& D, F3 B,const Float& InitB, F1 Fun1,const Float& Init1,  F2 Fun2,const Float& Init2 ) {	
	std::vector<Float> R;
	for (std::size_t i = 1; i < D.size(); i++) {
		Float V = FMOne2(D[i],B,InitB,Fun1,Init1,Fun2,Init2, i / static_cast<Float>(D.size()));
		R.push_back(V);
	}
	return R;
}
template<class Int,class Float>
std::vector<Int> MakeWaveInstance(std::vector<Float>& F,double Volume) {
	std::vector<Int> R;
	for (auto o : F) {
		R.push_back(static_cast<Int>(o*(std::numeric_limits<Int>::max())*Volume));
	}
	return R;
}
template<class Int>
bool WriteWaveFile(std::vector<Int>& D, std::uint64_t Hz, std::uint16_t Channel, std::string Name = "out.wav") {
	std::ofstream ofs(Name, std::ios::binary);
	char RIFF[] = "RIFF";
	char WAVE[] = "WAVE";
	char fmt[] = "fmt ";
	char data[] = "data";
	std::uint32_t FSize = (44 - 8) + (D.size() * sizeof(std::vector<Int>::value_type));
	std::uint32_t ui32 = 0;
	std::uint16_t ui16 = 0;
	ofs.write(RIFF, 4);
	ofs.write(reinterpret_cast<const char*>(&FSize), 4);//fsize-8.	
	ofs.write(WAVE, 4);
	ofs.write(fmt, 4);
	ui32 = 16;
	ofs.write(reinterpret_cast<const char*>(&ui32), 4);//fmt chunk size
	ui16 = 1;
	ofs.write(reinterpret_cast<const char*>(&ui16), 2);//sound type. PCM = 1.
	ui16 = Channel;
	ofs.write(reinterpret_cast<const char*>(&ui16), 2);//Channnel count.
	ui32 = static_cast<std::uint32_t>(Hz);
	ofs.write(reinterpret_cast<const char*>(&ui32), 4);//Sampling Hz.
	ui32 = static_cast<std::uint32_t>(Hz*Channel*(sizeof(std::vector<Int>::value_type)));
	ofs.write(reinterpret_cast<const char*>(&ui32), 4);//data speed??
	ui16 = Channel*(sizeof(std::vector<Int>::value_type));
	ofs.write(reinterpret_cast<const char*>(&ui16), 2);//BlockSize??
	ui16 = (sizeof(std::vector<Int>::value_type) * 8);
	ofs.write(reinterpret_cast<const char*>(&ui16), 2);//Sampling Bit.
	ofs.write(data, 4);
	ui32 = static_cast<std::uint32_t>(D.size() * sizeof(std::vector<Int>::value_type));
	ofs.write(reinterpret_cast<const char*>(&ui32), 4);//Sample's ALL SIZE.max at 32bit.

	ofs.write(reinterpret_cast<const char*>(&D[0]), D.size() * sizeof(std::vector<Int>::value_type));//WriteSamples.

	return true;
}
template<class T>
bool VolumeChenger(std::vector<T>& D ,double Percentage) {///1.0 => 100 Percent;
	for (auto o : D) {
		o *= Percentage;
	}
	return true;
}
template<class Float>
bool VolumeNormalize(std::vector<Float>& D ) {
	Float Max=0;
	Float M = 0;
	for (std::size_t i = 0; i < D.size();i++) {
		Max = std::max<Float>(Max, std::abs(D[i]));
	}
	M = 1 / Max;
	for (auto o : D) {
		o *= M;
	}
	return true;
}
void Test(std::size_t SampleRate,std::size_t MilliSec,double Volume) {
	std::vector<std::int16_t> D;
	std::vector<double> B;
	std::string Path = "./wav/";

	B = MakeBuffer<double>(SampleRate, MilliSec);
	MakeSinWave(B, Sample_, 220);
	//VolumeChenger(B, Volume);
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, (Path+"Sin.wav"));

	B = MakeBuffer<double>(SampleRate, MilliSec);
	MakeSawWave(B, Sample_, 220);	
	//VolumeChenger(B, Volume);
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, Path+"Saw.wav");	
	
	B = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeTriangleWave(B, Sample_, 220);
	//VolumeChenger(B, Volume);
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, Path+"Triangle.wav");	
	
	B = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeSquareWave(B, Sample_, 220);
	///VolumeChenger(B, Volume);	
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, Path+"Square.wav");	
	
	B = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeHzNoise(B, Sample_, 220);
	//VolumeChenger(B, Volume);
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, Path+"HzNoize.wav");	
	
	B = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeParfectNoise(B, Sample_, 220);
	//VolumeChenger(B, Volume);
	D = MakeWaveInstance<std::int16_t>(B, Volume);
	WriteWaveFile(D, Sample_, 1, Path+"PNoise.wav");

}
void GeneratorTest() {
std::vector<std::int16_t> D;
	std::vector<double> B1;
	std::vector<double> B2;
	std::vector<double> R;
	std::string Path = "./wav/";

	std::size_t SampleRate=Sample_;
	std::size_t MilliSec = 2000;
	double Volume=1.0;

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Sin<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"SinF.wav");

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Saw<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"SawF.wav");

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Square<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"SquareF.wav");

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Triangle<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"TriangleF.wav");

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Trapezoid<double>);
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"TrapezoidF.wav");

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, Noize<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"NoizeF.wav");
	
	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	GeneratorTmplate(B1, Sample_, 220, PerfectNoize<double>);	
	D = MakeWaveInstance<std::int16_t>(B1,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"PNoizeF.wav");
}
void FMTest() {
std::vector<std::int16_t> D;
	std::vector<double> B1;
	std::vector<double> B2;
	std::vector<double> R;
	std::string Path = "./wav/";

	std::size_t SampleRate=Sample_;
	std::size_t MilliSec = 2000;
	double Volume=0.8;

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeSawWave(B1, Sample_, 220);
	VolumeChenger(B1, 0.1);
	B2 = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeSinWave(B2, Sample_, 220);
	//MakeHzNoise(B2, Sample_, 220);
	//MakeSawWave(B2, Sample_, 220);
	VolumeChenger(B2, 0.1);

	R = FM_(B1, B2, 30, 7);
	//R = FM_(R, B1, 30, 120);

	//VolumeNormalize<double>(R);
	//VolumeChenger(B2, 1/3.0);
	D = MakeWaveInstance<std::int16_t>(R,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"FM.wav");
}
void FMTest2() {
std::vector<std::int16_t> D;
	std::vector<double> B1;
	std::vector<double> B2;
	std::vector<double> R;
	std::string Path = "./wav/";

	std::size_t SampleRate=Sample_;
	std::size_t MilliSec = 2000;
	double Volume=0.8;

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeSinWave(B1, Sample_, 220);
	VolumeChenger(B1, 0.1);
	B2 = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeTriangleWave(B2, Sample_, 220);
	//MakeHzNoise(B2, Sample_, 220);
	//MakeSawWave(B2, Sample_, 220);
	//VolumeChenger(B2, 0.1);

	R = FM<double>(B1, B2, 30/360.0,3000,Sin<double>,Sin<double>);
	//R = FM(R, B1, 30, 120);

	//VolumeNormalize<double>(R);
	//VolumeChenger(B2, 1/3.0);
	D = MakeWaveInstance<std::int16_t>(R,Volume);
	WriteWaveFile(D, Sample_, 1, Path+"FMG.wav");
}
void FMTest3() {
	std::vector<std::int16_t> D;
	std::vector<double> B1;
	std::vector<double> R;
	std::string Path = "./wav/";

	std::size_t SampleRate=Sample_;
	std::size_t MilliSec = 2000;
	double Volume=0.8;
	std::uint16_t Channel = 1;

	B1 = MakeBuffer<double>(SampleRate, MilliSec);	
	MakeSinWave(B1, Sample_, 220);
	
	R = FM2<double>(B1,Sin<double>,1, Sin<double>,30/360, Sin<double>,3000);
	D = MakeWaveInstance<std::int16_t>(R,Volume);
	WriteWaveFile(D, Sample_, Channel, Path+"FMG2.wav");
}

int main() {
	//Test(Sample_,2000,0.8);
	//FMTest();
	//GeneratorTest();
	//FMTest2();
	//FMTest3();
	return true;
	
}