#include <math.h>
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
//функции для взешенного вещества и сухого остатка
double tranc( double x, int n = 4 )
{
int temp;
temp = x * pow ( 10 , n + 1 ) ;
if ( temp % 10 < 5 )
{
temp = temp / 10 ;
}
else
{
temp = temp / 10 + 1 ;
}
return ( temp / pow ( 10.0 , n) ) ;
}
void massa_and_result( double & m1, double & m2, double & m_dushes, int & final_res, bool part1 = true , int lower_lim = 0 , int high_lim = 1 , int var_for_result2 = 0 , int n = 19 )
{
double difference;
int temp1, temp2;
if ( part1)
{
final_res = lower_lim + rand ( ) % ( high_lim- lower_lim) ;
if ( final_res % 2 == 1 )
{
final_res++ ;
}
}
else
{
final_res = var_for_result2 + ( 4 + rand ( ) % 4 ) ;
if ( final_res % 2 ! = var_for_result2 % 2 )
{
final_res = final_res + 1 ;
}
}
difference = final_res * 50 / 1000.0 / 1000.0 ;
temp1 = difference * 10000 ;
temp2 = ( 1000 + temp1) + rand ( ) % 8700 ;
m2= n + temp2 / 10000.0 ;
m1 = m2 + 0.0001 ;
m_dushes = m2 - difference;
return ;
}
void show_begin( double m1, double m2, double m_dushes, int final_res, int v, bool part1= true )
{
setlocale( LC_ALL, "Russian" ) ;
if ( part1)
cout << " V= " << v << " мл Mпуст=" << m_dushes << "; m1=" << m1 << "; m2=" << m2 << ";" << endl
<< " (" << m2 << "-" << m_dushes << ")/" << v << "*1000*1000=" << final_res<< endl;
else
cout << " V= " << v << " мл Mпуст=" << m_dushes << "; m1=" << m1 << "; m2=" << m2 << ";" << endl
<< " (" << m2 << "-" << m_dushes << ") *1000*1000/" << v<< "=" << final_res << endl;
}
void show_end( int res1, int res2)
{
cout << "\t \t (" << res1 << " + " << res2 << ")/2 =" << ( res1 + res2) / 2 << endl
<< "\t \t \t c=" << ( res1 + res2) / 2 << "(мг/дм3)\n " ;
}
//__________________________________________________________________________________________________________________________________
////функции для азота нитрийного(azot)
void D_and_result_azot_nitrit( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 1000.0 ; //с*1000 всегда должно быть нечетное
d1 = tranc( ( c1 - 0.0032 ) / 1.9677 ,3 ) ;
c1 = tranc( 1.9677 * d1 + 0.0032 , 3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c2 = tranc( 1.9677 * d2 + 0.0032 ,3 ) ;
return ;
}
void show_begin_azot_nitr( double d1, double d2, double c1, double c2, int v = 50 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " (1.9677*" << d1 << " ) + 0.0032) *" << v << "/ 50=" << c1 << endl
<< " (1.9677*" << d2 << " ) + 0.0032) *" << v<< "/ 50=" << c2 << endl;
return ;
}
void show_end_azot_nitr( double res1, double res2, double & c)
{
c = tranc( ( res1 + res2) / 2 * 0.304 ,3 ) ;
cout << "\t \t (" << res1 << " + " << res2 << ")/ 2 * 0,304 =" << c << endl
<< "\t \t \t c=" << c<< "(мг/дм3)\n "
<< "\t \t \t c=" << ( res1 + res2) / 2 * 0.304 << "(мг/дм3)\n " ;
}
void azot_nitr( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Азот нитрийный\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_azot_nitrit( d1_input, d2_input, c1_input, c2_input,263 ,559 ) ;
show_begin_azot_nitr( d1_input, d2_input, c1_input, c2_input) ;
show_end_azot_nitr( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_azot_nitrit( d1_bior, d2_bior, c1_bior, c2_bior, ( int ) ( ( c_input * 1000 + 30 ) / 0.304 ) , ( int ) ( ( c_input * 1000 + 60 ) / 0.304 ) ) ;
show_begin_azot_nitr( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_azot_nitr( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_azot_nitrit( d1_secondary, d2_secondary, c1_secondary, c2_secondary, ( int ) ( ( c_bior * 1000 + 25 ) / 0.304 ) , ( int ) ( ( c_bior * 1000 + 40 ) / 0.304 ) ) ;
show_begin_azot_nitr( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_azot_nitr( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_azot_nitrit( d1_output, d2_output, c1_output, c2_output, ( int ) ( ( c_secondary * 1000 + 45 ) / 0.304 ) , ( int ) ( ( c_secondary * 1000 + 85 ) / 0.304 ) ) ;
show_begin_azot_nitr( d1_output, d2_output, c1_output, c2_output) ;
show_end_azot_nitr( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//функции для нитратов
void D_and_result_nitrat( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 1000.0 ;
d1 = tranc( ( c1 - 0.091 ) / 11.821 , 3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c1 = tranc( 11.821 * d1 + 0.091 , 3 ) ;
c2 = tranc( 11.821 * d2 + 0.091 ,3 ) ;
return ;
}
void show_begin_nitrat( double d1, double d2, double c1, double c2, int v = 20 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " (11.821*" << d1 << " + 0.091) =" << c1 << endl
<< " (11.821*" << d2 << " + 0.091) =" << c2 << endl;
return ;
}
void show_end_nitrat( double res1, double res2, double & c)
{
c = tranc( ( res1 + res2) / 2.0 ,3 ) ;
cout << "\t \t (" << res1 << " + " << res2 << ")/ 2 =" << c << endl
<< "\t \t \t c=" << c << "(мг/дм3)\n "
<< "\t \t \t c=" << ( res1 + res2) / 2.0 << "(мг/дм3)\n " ;
}
void nitrat( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Нитраты\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_nitrat( d1_input, d2_input, c1_input, c2_input, 4500 , 7800 ) ;
show_begin_nitrat( d1_input, d2_input, c1_input, c2_input) ;
show_end_nitrat( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_nitrat( d1_bior, d2_bior, c1_bior, c2_bior, ( int ) ( ( c_input - 1.90 ) * 1000 ) , ( int ) ( ( c_input - 1.20 ) * 1000 ) ) ;
show_begin_nitrat( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_nitrat( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_nitrat( d1_secondary, d2_secondary, c1_secondary, c2_secondary, ( int ) ( ( c_bior - 1.5 ) * 1000 ) , ( int ) ( ( c_bior - 0.7 ) * 1000 ) ) ;
show_begin_nitrat( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_nitrat( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_nitrat( d1_output, d2_output, c1_output, c2_output, ( int ) ( ( 0.5 * c_input - 0.8 ) * 1000 ) , ( int ) ( ( 0.5 * c_input - 0.2 ) * 1000 ) ) ;
show_begin_nitrat( d1_output, d2_output, c1_output, c2_output) ;
show_end_nitrat( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//азот амонийный
void D_and_result_azot_amon( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 100.0 ;
d1 = tranc( ( ( c1/ 100.0 ) - 0.00017 ) / 8.8994 ,3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c1 = tranc( ( 8.8994 * d1 + 0.0017 ) * 100 , 2 ) ;
c2 = tranc( ( 8.8994 * d2 + 0.0017 ) * 100 ,2 ) ;
return ;
}
void show_begin_azot_amon( double d1, double d2, double c1, double c2, double v = 0.5 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " ((8.8994*" << d1 << ") + 0.0017)*50/ 0.5 =" << c1 << endl
<< " ((8.8994*" << d2 << ") + 0.0017)*50/ 0.5 =" << c2 << endl;
return ;
}
void show_end_azot_amon_and_hlor( double res1, double res2, double & c)
{
c = tranc( ( res1+ res2) / 2.0 ,2 ) ;
cout << "\t \t (" << res1 << " + " << res2 << ")/ 2 =" << c << endl
<< "\t \t \t c=" << c << "(мг/дм3)\n "
<< "\t \t \t c=" << ( res1 + res2) / 2.0 << "(мг/дм3)\n " ;
}
void amon( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary;
double c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Азот амонийный\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_azot_amon( d1_input, d2_input, c1_input, c2_input, 4200 , 6000 ) ;
show_begin_azot_amon( d1_input, d2_input, c1_input, c2_input) ;
show_end_azot_amon_and_hlor( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_azot_amon( d1_bior, d2_bior, c1_bior, c2_bior, ( c_input - 15 ) * 100 ,( c_input - 11 ) * 100 ) ;
show_begin_azot_amon( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_azot_amon_and_hlor( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_azot_amon( d1_secondary, d2_secondary, c1_secondary, c2_secondary, 2000 , 2700 ) ;
show_begin_azot_amon( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_azot_amon_and_hlor( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_azot_amon( d1_output, d2_output, c1_output, c2_output, 1700 , 1890 ) ;
show_begin_azot_amon( d1_output, d2_output, c1_output, c2_output) ;
show_end_azot_amon_and_hlor( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//хлориды
void D_and_result_hlor( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 100.0 ;
d1 = tranc( c1/ 354.5 / 0.05 / 0.9990 ,1 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 10.0 ;
c1 = tranc( d1* 0.05 * 354.5 * 0.9990 , 2 ) ;
c2 = tranc( d2* 0.05 * 354.5 * 0.9990 ,2 ) ;
return ;
}
void show_begin_hlor( double d1, double d2, double c1, double c2, int v= 100 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл X1=" << d1 << "; X2=" << d2 << "; " << endl
<< " (" << d1 << "*0.05) *35.45)*0.9990)*1000/100 =" << c1 << endl
<< " (" << d2 << "*0.05) *35.45)*0.9990)*1000/100 =" << c2 << endl;
return ;
}
void hlor( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary;
double c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Хлориды\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_hlor( d1_input, d2_input, c1_input, c2_input, 11000 , 19000 ) ;
show_begin_hlor( d1_input, d2_input, c1_input, c2_input) ;
show_end_azot_amon_and_hlor( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_hlor( d1_bior, d2_bior, c1_bior, c2_bior, ( 0.7 * c_input - 10 ) * 100 , ( 0.7 * c_input + 10 ) * 100 ) ;
show_begin_hlor( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_azot_amon_and_hlor( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_hlor( d1_secondary, d2_secondary, c1_secondary, c2_secondary,( 0.5 * c_input - 3 ) * 100 , ( 0.5 * c_input + 15 ) * 100 ) ;
show_begin_hlor( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_azot_amon_and_hlor( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_hlor( d1_output, d2_output, c1_output, c2_output, ( c_secondary - 20 ) * 100 , ( c_secondary- 10 ) * 100 ) ;
show_begin_hlor( d1_output, d2_output, c1_output, c2_output) ;
show_end_azot_amon_and_hlor( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//cульфаты
void D_and_result_sylfat( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 100.0 ;
d1 = tranc( ( ( c1 / 100.0 ) - 0.0608 ) / 18.468 , 3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c1 = tranc( ( 18.468 * d1 + 0.0608 ) * 100 , 2 ) ;
c2 = tranc( ( 18.468 * d2 + 0.0608 ) * 100 , 2 ) ;
return ;
}
void show_begin_sylfat( double d1, double d2, double c1, double c2, double v = 0.5 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " ((18.468*" << d1 << ") + 0.0608)*1000/ 10 =" << c1 << endl
<< " ((18.468*" << d2 << ") + 0.0608)*1000/ 10 =" << c2 << endl;
return ;
}
void sylfat( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary;
double c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Сульфаты\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_sylfat( d1_input, d2_input, c1_input, c2_input, 16000 , 21000 ) ;
show_begin_sylfat( d1_input, d2_input, c1_input, c2_input) ;
show_end_azot_amon_and_hlor( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_sylfat( d1_bior, d2_bior, c1_bior, c2_bior, ( 0.65 * c_input - 15 ) * 100 , ( 0.65 * c_input - 5 ) * 100 ) ;
show_begin_sylfat( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_azot_amon_and_hlor( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_sylfat( d1_secondary, d2_secondary, c1_secondary, c2_secondary, ( c_bior - 40 ) * 100 , ( c_bior - 30 ) * 100 ) ;
show_begin_sylfat( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_azot_amon_and_hlor( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_sylfat( d1_output, d2_output, c1_output, c2_output, ( c_secondary- 8 ) * 100 ,( c_secondary- 15 ) * 100 ) ;
show_begin_sylfat( d1_output, d2_output, c1_output, c2_output) ;
show_end_azot_amon_and_hlor( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//фосфар фосфатный
void D_and_result_fosfar( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 100.0 ;
d1 = tranc( ( c1/ 10.0 + 0.0038 ) / 3.818 , 3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c1 = tranc( ( 3.818 * d1 - 0.0038 ) * 10.0 , 2 ) ;
c2 = tranc( ( 3.818 * d2 - 0.0038 ) * 10.0 , 2 ) ;
return ;
}
void show_begin_fosfar( double d1, double d2, double c1, double c2, int v = 5 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " ((3.818*" << d1 << ") - 0.0038)*50/" << v<< "=" << c1 << endl
<< " ((3.818*" << d2 << " )- 0.0038)*50/" << v << "=" << c2 << endl;
return ;
}
void show_end_fosfar( double res1, double res2, double & c)
{
c = tranc( ( res1 + res2) / 2.0 * 0.326 , 2 ) ;
cout << "\t \t (" << res1 << " + " << res2 << ")/ 2*0.326 =" << c << endl
<< "\t \t \t c=" << c << "(мг/дм3)\n "
<< "\t \t \t c=" << ( res1 + res2) / 2.0 * 0.326 << "(мг/дм3)\n " ;
}
void fosfar( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Фосфар фосфатный\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_fosfar( d1_input, d2_input, c1_input, c2_input, 250 / 0.304 , 390 / 0.304 ) ;
show_begin_fosfar( d1_input, d2_input, c1_input, c2_input) ;
show_end_fosfar( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_fosfar( d1_bior, d2_bior, c1_bior, c2_bior, ( int ) ( ( 0.65 * c_input - 0.22 ) * 100 / 0.304 ) , ( int ) ( ( 0.65 * c_input + 0.35 ) * 100 / 0.304 ) ) ;
show_begin_fosfar( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_fosfar( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_fosfar( d1_secondary, d2_secondary, c1_secondary, c2_secondary, ( int ) ( ( 0.56 * c_bior - 0.15 ) * 100 / 0.304 ) , ( int ) ( ( 0.56 * c_bior + 0.15 ) * 100 / 0.304 ) ) ;
show_begin_fosfar( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_fosfar( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_fosfar( d1_output, d2_output, c1_output, c2_output, ( int ) ( ( c_secondary - 0.3 ) * 100 / 0.304 ) , ( int ) ( ( c_secondary - 0.1 ) * 100 / 0.304 ) ) ;
show_begin_fosfar( d1_output, d2_output, c1_output, c2_output) ;
show_end_fosfar( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
//железо(ferum)
void D_and_result_ferum( double & d1, double & d2, double & c1, double & c2, int lower_lim = 0 , int high_lim = 1 )
{
c1 = ( lower_lim + rand ( ) % ( high_lim - lower_lim) ) / 100.0 ;
d1 = tranc( ( c1 * 8 / 10.0 + 0.2511 ) / 56.582 , 3 ) ;
d2 = d1 + ( - 1 + rand ( ) % 3 ) / 1000.0 ;
c1 = tranc( ( 56.582 * d1 - 0.2511 ) * 10 / 8.0 , 2 ) ;
c2 = tranc( ( 56.582 * d2 - 0.2511 ) * 10 / 8.0 , 2 ) ;
return ;
}
void show_begin_ferum( double d1, double d2, double c1, double c2, int v = 80 )
{
setlocale( LC_ALL, "Russian" ) ;
cout << " V= " << v << " мл D1=" << d1 << "; D2=" << d2 << "; " << endl
<< " ((56.582*" << d1 << ") - 0.2511)*100/" << v << "=" << c1 << endl
<< " ((56.582*" << d2 << " )- 0.2511)*100/" << v << "=" << c2 << endl;
return ;
}
void show_end_ferum( double res1, double res2, double & c)
{
c = tranc( ( res1 + res2) / 2.0 , 2 ) ;
cout << "\t \t (" << res1 << " + " << res2 << ")/ 2=" << c << endl
<< "\t \t \t c=" << c << "(мг/дм3)\n "
<< "\t \t \t c=" << ( res1 + res2) / 2.0 << "(мг/дм3)\n " ;
}
void ferum( )
{
double d1_input, d2_input, c1_input, c2_input, c_input; //вход
double d1_bior, d2_bior, c1_bior, c2_bior, c_bior; //bior
double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary; //вторичная
double d1_output, d2_output, c1_output, c2_output, c_output; //выход
cout << "\t \t Железо общее\n \n " ; //решение для входа
cout << " Вход " ;
D_and_result_ferum( d1_input, d2_input, c1_input, c2_input, 120 , 310 ) ;
show_begin_ferum( d1_input, d2_input, c1_input, c2_input) ;
show_end_ferum( c1_input, c2_input, c_input) ;
cout << " После биор" ; //решение для биора
D_and_result_ferum( d1_bior, d2_bior, c1_bior, c2_bior, ( int ) ( ( 0.65 * c_input - 0.1 ) * 100 ) , ( int ) ( ( 0.65 * c_input + 0.2 ) * 100 ) ) ;
show_begin_ferum( d1_bior, d2_bior, c1_bior, c2_bior) ;
show_end_ferum( c1_bior, c2_bior, c_bior) ;
cout << " После вторичной" ; //решение для вторичной
D_and_result_ferum( d1_secondary, d2_secondary, c1_secondary, c2_secondary, ( int ) ( ( 0.75 * c_bior - 0.15 ) * 100 ) , ( int ) ( ( 0.75 * c_bior + 0.15 ) * 100 ) ) ;
show_begin_ferum( d1_secondary, d2_secondary, c1_secondary, c2_secondary) ;
show_end_ferum( c1_secondary, c2_secondary, c_secondary) ;
cout << " Выход" ; //решение для выхода
D_and_result_ferum( d1_output, d2_output, c1_output, c2_output, ( int ) ( ( c_secondary - 0.2 ) * 100 ) , ( int ) ( ( c_secondary - 0.1 ) * 100 ) ) ;
show_begin_ferum( d1_output, d2_output, c1_output, c2_output) ;
show_end_ferum( c1_output, c2_output, c_output) ;
cout << "________________________________________________________________________________\n \n " ;
return ;
}
int main( int argc, char * argv[ ] )
{
srand ( time ( NULL ) ) ;
setlocale( LC_ALL, "Russian" ) ;
const int Value = 50 ;
int final_res1= 0 , final_res2= 0 ;
double m1_1 = 0 , m2_1 = 0 , m_dushes_1 = 0 ;
double m1_2 = 0 , m2_2 = 0 , m_dushes_2 = 0 ; //для входа перменые
int result_1_bior = 0 , result_2_bior = 0 ; //для биора
double m1_1_bior = 0 , m2_1_bior = 0 , m_dushes_1_bior = 0 ;
double m1_2_bior = 0 , m2_2_bior = 0 , m_dushes_2_bior = 0 ;
int result_1_secondary = 0 , result_2_secondary = 0 ; //для вторичеой
double m1_1_secondary = 0 , m2_1_secondary = 0 , m_dushes_1_secondary = 0 ;
double m1_2_secondary = 0 , m2_2_secondary = 0 , m_dushes_2_secondary = 0 ;
int result_1_output = 0 , result_2_output = 0 ; //для выхода
double m1_1_output = 0 , m2_1_output = 0 , m_dushes_1_output = 0 ;
double m1_2_output = 0 , m2_2_output = 0 , m_dushes_2_output = 0 ;
cout << "\t \t Взвешивание вещества\n \n " ;
massa_and_result( m1_1, m2_1, m_dushes_1, final_res1,true ,230 ,370 ) ; //решение задачи для входа
cout << " Вход " ;
show_begin( m1_1, m2_1, m_dushes_1, final_res1, Value) ;
massa_and_result( m1_2, m2_2, m_dushes_2, final_res2, false ,230 ,370 , final_res1) ;
show_begin( m1_2, m2_2, m_dushes_2, final_res2, Value) ;
show_end( final_res1, final_res2) ;
cout << " После биор. " ; //решение задачи биор
massa_and_result( m1_1_bior, m2_1_bior, m_dushes_1_bior, result_1_bior, true , 90 , 140 , 0 , 20 ) ;
show_begin( m1_1_bior, m2_1_bior, m_dushes_1_bior, result_1_bior, Value) ;
massa_and_result( m1_2_bior, m2_2_bior, m_dushes_2_bior, result_2_bior, false , 90 , 140 , result_1_bior, 20 ) ;
show_begin( m1_2_bior, m2_2_bior, m_dushes_2_bior, result_2_bior, Value) ;
show_end( result_1_bior, result_2_bior) ;
cout << " После втор. " ; //Решение для вторичной
massa_and_result( m1_1_secondary, m2_1_secondary, m_dushes_1_secondary, result_1_secondary, true , 40 , 60 ) ;
show_begin( m1_1_secondary, m2_1_secondary, m_dushes_1_secondary, result_1_secondary, Value) ;
massa_and_result( m1_2_secondary, m2_2_secondary, m_dushes_2_secondary, result_2_secondary, false , 40 , 60 , result_1_secondary) ;
show_begin( m1_2_secondary, m2_2_secondary, m_dushes_2_secondary, result_2_secondary, Value) ;
show_end( result_1_secondary, result_2_secondary) ;
cout << " Выход " ; //Решение для выхода
massa_and_result( m1_1_output, m2_1_output, m_dushes_1_output, result_1_output, true , 16 , 24 ) ;
show_begin( m1_1_output, m2_1_output, m_dushes_1_output, result_1_output, Value) ;
massa_and_result( m1_2_output, m2_2_output, m_dushes_2_output, result_2_output, false , 0 , 0 , result_1_output ) ;
show_begin( m1_2_output, m2_2_output, m_dushes_2_output, result_2_output, Value) ;
show_end( result_1_output, result_2_output) ;
cout << "________________________________________________________________________________\n \n " ;
//____________________________________________Сухой остаток(dry)__________________________________________________________________
int final_res1_dry = 0 , final_res2_dry = 0 ;
double m1_1_dry = 0 , m2_1_dry = 0 , m_dushes_1_dry = 0 ;
double m1_2_dry = 0 , m2_2_dry = 0 , m_dushes_2_dry = 0 ; //для входа перменые(сухой остаток)
int result_1_bior_dry = 0 , result_2_bior_dry = 0 ; //для биора(сухой остаток)
double m1_1_bior_dry = 0 , m2_1_bior_dry = 0 , m_dushes_1_bior_dry = 0 ;
double m1_2_bior_dry = 0 , m2_2_bior_dry = 0 , m_dushes_2_bior_dry = 0 ;
int result_1_secondary_dry = 0 , result_2_secondary_dry = 0 ; //для вторичеой(сухой остаток)
double m1_1_secondary_dry = 0 , m2_1_secondary_dry = 0 , m_dushes_1_secondary_dry = 0 ;
double m1_2_secondary_dry = 0 , m2_2_secondary_dry = 0 , m_dushes_2_secondary_dry = 0 ;
int result_1_output_dry = 0 , result_2_output_dry = 0 ; //для выхода(сухой остаток)
double m1_1_output_dry = 0 , m2_1_output_dry = 0 , m_dushes_1_output_dry = 0 ;
double m1_2_output_dry = 0 , m2_2_output_dry = 0 , m_dushes_2_output_dry = 0 ;
cout << "\t \t \t Сухой остаток\n \n " ;
massa_and_result( m1_1_dry, m2_1_dry, m_dushes_1_dry, final_res1_dry, true , 500 , 700 ,0 ,75 ) ; //решение задачи для входа(сухой остаток)
cout << " Вход " ;
show_begin( m1_1_dry, m2_1_dry, m_dushes_1_dry, final_res1_dry, Value, false ) ;
massa_and_result( m1_2_dry, m2_2_dry, m_dushes_2_dry, final_res2_dry, false , 500 , 700 , final_res1_dry,75 ) ;
show_begin( m1_2_dry, m2_2_dry, m_dushes_2_dry, final_res2_dry, Value,false ) ;
show_end( final_res1_dry, final_res2_dry) ;
cout << " После биор. " ; //решение задачи биор(сухой остаток)
massa_and_result( m1_1_bior_dry, m2_1_bior_dry, m_dushes_1_bior_dry, result_1_bior_dry, true , final_res1_dry- 180 , final_res1_dry- 120 , 0 , 76 ) ;
show_begin( m1_1_bior_dry, m2_1_bior_dry, m_dushes_1_bior_dry, result_1_bior_dry, Value,false ) ;
massa_and_result( m1_2_bior_dry, m2_2_bior_dry, m_dushes_2_bior_dry, result_2_bior_dry, false , final_res1_dry - 180 , final_res1_dry - 120 , result_1_bior_dry,76 ) ;
show_begin( m1_2_bior_dry, m2_2_bior_dry, m_dushes_2_bior_dry, result_2_bior_dry, Value,false ) ;
show_end( result_1_bior_dry, result_2_bior_dry) ;
//Решение для выхода(сухой остаток)
massa_and_result( m1_1_output_dry, m2_1_output_dry, m_dushes_1_output_dry, result_1_output_dry, true , final_res1_dry / 2 - 15 , final_res1_dry / 2 ,0 ,75 ) ;
massa_and_result( m1_2_output_dry, m2_2_output_dry, m_dushes_2_output_dry, result_2_output_dry, false , 0 , 0 , result_1_output_dry,75 ) ;
cout << " После втор. " ; //Решение для вторичной(сухой остаток)
massa_and_result( m1_1_secondary_dry, m2_1_secondary_dry, m_dushes_1_secondary_dry, result_1_secondary_dry, true , result_1_output_dry + 35 , result_1_output_dry + 70 , 0 ,75 ) ;
show_begin( m1_1_secondary_dry, m2_1_secondary_dry, m_dushes_1_secondary_dry, result_1_secondary_dry, Value,false ) ;
massa_and_result( m1_2_secondary_dry, m2_2_secondary_dry, m_dushes_2_secondary_dry, result_2_secondary_dry, false , 0 , 0 , result_1_secondary_dry,75 ) ;
show_begin( m1_2_secondary_dry, m2_2_secondary_dry, m_dushes_2_secondary_dry, result_2_secondary_dry, Value,false ) ;
show_end( result_1_secondary_dry, result_2_secondary_dry) ;
cout << " Выход " ;
show_begin( m1_1_output_dry, m2_1_output_dry, m_dushes_1_output_dry, result_1_output_dry, Value,false ) ;
show_begin( m1_2_output_dry, m2_2_output_dry, m_dushes_2_output_dry, result_2_output_dry, Value,false ) ;
show_end( result_1_output_dry, result_2_output_dry) ;
cout << "________________________________________________________________________________\n \n " ;
azot_nitr( ) ;
nitrat( ) ;
amon( ) ;
hlor( ) ;
sylfat( ) ;
fosfar( ) ;
ferum( ) ;
system ( "pause" ) ;
return 0 ;
}

#include <math.h>
#include <iostream>
#include <cstdlib>
#include <ctime>

using namespace std;
//функции для взешенного вещества и сухого остатка

double tranc(double x, int n = 4)
{
	int temp;

	temp = x * pow(10, n + 1);
	if (temp % 10 < 5)
	{
		temp = temp / 10;
	}
	else
	{
		temp = temp / 10 + 1;
	}
	return (temp / pow(10.0, n));

}
void massa_and_result(double &m1, double &m2, double &m_dushes, int &final_res, bool part1 = true, int lower_lim = 0, int high_lim = 1, int var_for_result2 = 0, int n = 19)
{
	
	double difference;
	int temp1, temp2;
	if (part1)
	{
		final_res = lower_lim + rand() % (high_lim-lower_lim);
		if (final_res % 2 == 1)
		{
			final_res++;
		}
	}
	else
	{
		final_res = var_for_result2 + (4 + rand() % 4);
		if (final_res % 2 != var_for_result2 % 2)
		{
			final_res = final_res + 1;
		}
	}
	difference = final_res * 50 / 1000.0 / 1000.0;
	temp1 = difference * 10000;
	temp2 = (1000 + temp1)+rand() % 8700 ;
	m2=n + temp2 / 10000.0;
	m1 = m2 + 0.0001;
	m_dushes = m2 - difference;
	return;

}
void show_begin(double m1, double m2, double m_dushes, int final_res, int v, bool part1=true )
{
	setlocale(LC_ALL, "Russian");
	if (part1)
	cout << "  V= " << v << " мл  Mпуст=" << m_dushes << ";  m1=" << m1 << ";  m2=" << m2 << ";" << endl
		<< "  (" << m2 << "-" << m_dushes << ")/" << v << "*1000*1000=" << final_res<<endl;
	else
		cout << "  V= " << v << " мл  Mпуст=" << m_dushes << ";  m1=" << m1 << ";  m2=" << m2 << ";" << endl
		<< "  (" << m2 << "-" << m_dushes << ") *1000*1000/"<<v<<"=" << final_res << endl;


}
void show_end(int res1, int res2)
{
	cout << "\t\t(" << res1 << " + " << res2 << ")/2 =" << (res1 + res2) / 2 << endl
		<< "\t\t\tc=" << (res1 + res2) / 2 << "(мг/дм3)\n";
}
//__________________________________________________________________________________________________________________________________
////функции для азота нитрийного(azot)

void D_and_result_azot_nitrit(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{

	c1 = (lower_lim + rand() % (high_lim - lower_lim))/1000.0;//с*1000 всегда должно быть нечетное 
	d1 = tranc((c1 - 0.0032) / 1.9677,3);
	c1 = tranc(1.9677*d1 + 0.0032, 3);
	d2 = d1 + (-1+rand() % 3) / 1000.0;
	c2 = tranc(1.9677*d2 + 0.0032,3);
	return;
}
void show_begin_azot_nitr(double d1, double d2, double c1, double c2, int v = 50)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  (1.9677*" << d1 << " ) + 0.0032) *" <<v <<"/ 50=" << c1 << endl
		<< "  (1.9677*" << d2 << " ) + 0.0032) *" <<v<<"/ 50=" << c2 << endl;
	return;
}
void show_end_azot_nitr(double res1, double res2, double &c)
{
	c = tranc((res1 + res2) / 2 * 0.304,3);
	cout << "\t\t(" << res1 << " + " << res2 << ")/ 2 * 0,304 =" << c << endl
		<< "\t\t\tc=" << c<< "(мг/дм3)\n"
	<< "\t\t\tc=" << (res1 + res2) / 2 * 0.304 << "(мг/дм3)\n";
}
void  azot_nitr()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход
	
	cout << "\t\t   Азот нитрийный\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_azot_nitrit(d1_input, d2_input, c1_input, c2_input,263,559);
	show_begin_azot_nitr(d1_input, d2_input, c1_input, c2_input);
	show_end_azot_nitr(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_azot_nitrit(d1_bior, d2_bior, c1_bior, c2_bior, (int)((c_input * 1000 + 30) / 0.304), (int)((c_input * 1000 + 60) / 0.304));
	show_begin_azot_nitr(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_azot_nitr(c1_bior, c2_bior, c_bior);

	cout << "  После вторичной"; //решение для вторичной
	D_and_result_azot_nitrit(d1_secondary, d2_secondary, c1_secondary, c2_secondary, (int)((c_bior * 1000 + 25) / 0.304), (int)((c_bior * 1000 + 40) / 0.304));
	show_begin_azot_nitr(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_azot_nitr(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_azot_nitrit(d1_output, d2_output, c1_output, c2_output, (int)((c_secondary * 1000 + 45) / 0.304), (int)((c_secondary * 1000 + 85) / 0.304));
	show_begin_azot_nitr(d1_output, d2_output, c1_output, c2_output);
	show_end_azot_nitr(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//функции для нитратов
void D_and_result_nitrat(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{
	c1 = (lower_lim + rand() % (high_lim - lower_lim)) / 1000.0;
	d1 = tranc((c1 - 0.091) / 11.821, 3);
	d2 = d1 + (-1 + rand() % 3) / 1000.0;
	c1 = tranc(11.821*d1 + 0.091, 3);
	c2 = tranc(11.821*d2 + 0.091,3);
	return;
}
void show_begin_nitrat(double d1, double d2, double c1, double c2, int v = 20)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  (11.821*" << d1 << " + 0.091) =" << c1 << endl
		<< "  (11.821*" << d2 << " + 0.091) =" << c2 << endl;
	return;
}
void show_end_nitrat(double res1, double res2, double &c)
{
	c = tranc((res1 + res2) / 2.0 ,3);
	cout << "\t\t(" << res1 << " + " << res2 << ")/ 2 =" << c << endl
		<< "\t\t\tc=" << c << "(мг/дм3)\n"
	<< "\t\t\tc=" << (res1 + res2) / 2.0 << "(мг/дм3)\n";
}

void  nitrat()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Нитраты\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_nitrat(d1_input, d2_input, c1_input, c2_input, 4500, 7800);
	show_begin_nitrat(d1_input, d2_input, c1_input, c2_input);
	show_end_nitrat(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_nitrat(d1_bior, d2_bior, c1_bior, c2_bior, (int)((c_input - 1.90) * 1000), (int)((c_input - 1.20) * 1000));
	show_begin_nitrat(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_nitrat(c1_bior, c2_bior, c_bior);

	cout << "  После вторичной"; //решение для вторичной
	D_and_result_nitrat(d1_secondary, d2_secondary, c1_secondary, c2_secondary, (int)((c_bior - 1.5) * 1000), (int)((c_bior - 0.7) * 1000));
	show_begin_nitrat(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_nitrat(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_nitrat(d1_output, d2_output, c1_output, c2_output, (int)((0.5*c_input - 0.8) * 1000), (int)((0.5*c_input - 0.2) * 1000));
	show_begin_nitrat(d1_output, d2_output, c1_output, c2_output);
	show_end_nitrat(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//азот амонийный



void D_and_result_azot_amon(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{	
	c1 = (lower_lim + rand() % (high_lim - lower_lim))/100.0;
	d1 = tranc(((c1/100.0)-0.00017)/8.8994,3);
	d2 = d1 + (-1 + rand() % 3) / 1000.0;
	c1 = tranc((8.8994*d1 + 0.0017) * 100, 2);
	c2 =tranc( (8.8994*d2 + 0.0017)*100,2);
	return;
}

void show_begin_azot_amon(double d1, double d2, double c1, double c2, double v = 0.5)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  ((8.8994*" << d1 << ") + 0.0017)*50/ 0.5 =" << c1 << endl
		<< "  ((8.8994*" << d2 << ") + 0.0017)*50/ 0.5 =" << c2 << endl;
	return;
}
void show_end_azot_amon_and_hlor(double res1, double res2, double &c)
{
	c = tranc((res1+res2)/2.0,2);
	cout << "\t\t(" << res1 << " + " << res2 << ")/ 2 =" << c << endl
		<< "\t\t\tc=" << c << "(мг/дм3)\n"
	<< "\t\t\tc=" << (res1 + res2) / 2.0 << "(мг/дм3)\n";
}
void  amon()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary;
	double c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Азот амонийный\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_azot_amon(d1_input, d2_input, c1_input, c2_input, 4200, 6000);
	show_begin_azot_amon(d1_input, d2_input, c1_input, c2_input);
	show_end_azot_amon_and_hlor(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_azot_amon(d1_bior, d2_bior, c1_bior, c2_bior, (c_input - 15)*100,( c_input - 11)*100);
	show_begin_azot_amon(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_azot_amon_and_hlor(c1_bior, c2_bior, c_bior);
	cout << "  После вторичной"; //решение для вторичной
	D_and_result_azot_amon(d1_secondary, d2_secondary, c1_secondary, c2_secondary, 2000, 2700);
	show_begin_azot_amon(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_azot_amon_and_hlor(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_azot_amon(d1_output, d2_output, c1_output, c2_output, 1700, 1890);
	show_begin_azot_amon(d1_output, d2_output, c1_output, c2_output);
	show_end_azot_amon_and_hlor(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//хлориды

void D_and_result_hlor(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{
	c1 = (lower_lim + rand() % (high_lim - lower_lim))/100.0;
	d1 = tranc(c1/354.5/0.05/0.9990,1);
	d2 = d1 + (-1 + rand() % 3) / 10.0;
	c1 = tranc(d1*0.05*354.5*0.9990, 2);
	c2 = tranc(d2*0.05*354.5*0.9990,2);
	return;
}
void show_begin_hlor(double d1, double d2, double c1, double c2, int v=100)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  X1=" << d1 << ";  X2=" << d2 << "; " << endl
		<< "  (" << d1 << "*0.05) *35.45)*0.9990)*1000/100 =" << c1 << endl
		<< "  (" << d2 << "*0.05) *35.45)*0.9990)*1000/100 =" << c2 << endl;
	return;
}
void  hlor()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary;
	double c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Хлориды\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_hlor(d1_input, d2_input, c1_input, c2_input, 11000, 19000);
	show_begin_hlor(d1_input, d2_input, c1_input, c2_input);
	show_end_azot_amon_and_hlor(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_hlor(d1_bior, d2_bior, c1_bior, c2_bior, (0.7* c_input - 10)*100, (0.7* c_input + 10)*100);
	show_begin_hlor(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_azot_amon_and_hlor(c1_bior, c2_bior, c_bior);
	cout << "  После вторичной"; //решение для вторичной
	D_and_result_hlor(d1_secondary, d2_secondary, c1_secondary, c2_secondary,( 0.5* c_input - 3)*100, (0.5* c_input +15)*100);
	show_begin_hlor(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_azot_amon_and_hlor(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_hlor(d1_output, d2_output, c1_output, c2_output, (c_secondary - 20)*100, (c_secondary-10)*100);
	show_begin_hlor(d1_output, d2_output, c1_output, c2_output);
	show_end_azot_amon_and_hlor(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//cульфаты
void D_and_result_sylfat(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{
	c1 = (lower_lim + rand() % (high_lim - lower_lim))/100.0;
	d1 = tranc(((c1 / 100.0) - 0.0608) / 18.468, 3);
	d2 = d1 + (-1 + rand() % 3) / 1000.0;
	c1 = tranc((18.468*d1 + 0.0608) * 100, 2);
	c2 = tranc((18.468*d2 + 0.0608) * 100, 2);
	return;
}
void show_begin_sylfat(double d1, double d2, double c1, double c2, double v = 0.5)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  ((18.468*" << d1 << ") + 0.0608)*1000/ 10 =" << c1 << endl
		<< "  ((18.468*" << d2 << ") + 0.0608)*1000/ 10 =" << c2 << endl;
	return;
}
void  sylfat()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary;
	double c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Сульфаты\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_sylfat(d1_input, d2_input, c1_input, c2_input, 16000, 21000);
	show_begin_sylfat(d1_input, d2_input, c1_input, c2_input);
	show_end_azot_amon_and_hlor(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_sylfat(d1_bior, d2_bior, c1_bior, c2_bior, (0.65* c_input - 15)*100, (0.65* c_input -5)*100);
	show_begin_sylfat(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_azot_amon_and_hlor(c1_bior, c2_bior, c_bior);
	cout << "  После вторичной"; //решение для вторичной
	D_and_result_sylfat(d1_secondary, d2_secondary, c1_secondary, c2_secondary,  (c_bior - 40)*100,  (c_bior - 30)*100);
	show_begin_sylfat(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_azot_amon_and_hlor(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_sylfat(d1_output, d2_output, c1_output, c2_output, (c_secondary-8)*100,(c_secondary-15)*100);
	show_begin_sylfat(d1_output, d2_output, c1_output, c2_output);
	show_end_azot_amon_and_hlor(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//фосфар фосфатный
void D_and_result_fosfar(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{
	c1 = (lower_lim + rand() % (high_lim - lower_lim)) / 100.0;
	d1 = tranc((c1/10.0 + 0.0038) / 3.818, 3);
	d2 = d1 + (-1 + rand() % 3) / 1000.0;
	c1 = tranc((3.818*d1 - 0.0038)*10.0, 2);
	c2 = tranc((3.818*d2 - 0.0038)*10.0, 2);
	return;
}
void show_begin_fosfar(double d1, double d2, double c1, double c2, int v = 5)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  ((3.818*" << d1 << ") - 0.0038)*50/"<<v<<"=" << c1 << endl
		<< "  ((3.818*" << d2 << " )- 0.0038)*50/" << v << "="<< c2 << endl;
	return;
}
void show_end_fosfar(double res1, double res2, double &c)
{
	c = tranc((res1 + res2) / 2.0*0.326, 2);
	cout << "\t\t(" << res1 << " + " << res2 << ")/ 2*0.326 =" << c << endl
		<< "\t\t\tc=" << c << "(мг/дм3)\n"
	<< "\t\t\tc=" << (res1 + res2) / 2.0*0.326 << "(мг/дм3)\n";
}

void  fosfar()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Фосфар фосфатный\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_fosfar(d1_input, d2_input, c1_input, c2_input, 250/0.304, 390/0.304);
	show_begin_fosfar(d1_input, d2_input, c1_input, c2_input);
	show_end_fosfar(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_fosfar(d1_bior, d2_bior, c1_bior, c2_bior, (int)((0.65*c_input - 0.22) * 100/0.304), (int)((0.65*c_input + 0.35) * 100/0.304));
	show_begin_fosfar(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_fosfar(c1_bior, c2_bior, c_bior);

	cout << "  После вторичной"; //решение для вторичной
	D_and_result_fosfar(d1_secondary, d2_secondary, c1_secondary, c2_secondary, (int)((0.56*c_bior - 0.15) * 100/0.304), (int)((0.56*c_bior +0.15) * 100/0.304));
	show_begin_fosfar(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_fosfar(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_fosfar(d1_output, d2_output, c1_output, c2_output, (int)((c_secondary - 0.3) * 100/0.304), (int)((c_secondary - 0.1) * 100/0.304));
	show_begin_fosfar(d1_output, d2_output, c1_output, c2_output);
	show_end_fosfar(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}
//железо(ferum)
void D_and_result_ferum(double &d1, double &d2, double &c1, double &c2, int lower_lim = 0, int high_lim = 1)
{
	c1 = (lower_lim + rand() % (high_lim - lower_lim)) / 100.0;
	d1 = tranc((c1 *8/ 10.0 + 0.2511) / 56.582, 3);
	d2 = d1 + (-1 + rand() % 3) / 1000.0;
	c1 = tranc((56.582*d1 - 0.2511) * 10 / 8.0, 2);
	c2 = tranc((56.582*d2 - 0.2511)*10/8.0, 2);
	return;
}
void show_begin_ferum(double d1, double d2, double c1, double c2, int v = 80)
{
	setlocale(LC_ALL, "Russian");
	cout << "  V= " << v << " мл  D1=" << d1 << ";  D2=" << d2 << "; " << endl
		<< "  ((56.582*" << d1 << ") - 0.2511)*100/" << v << "=" << c1 << endl
		<< "  ((56.582*" << d2 << " )- 0.2511)*100/" << v << "=" << c2 << endl;
	return;
}
void show_end_ferum(double res1, double res2, double &c)
{
	c = tranc((res1 + res2) / 2.0 , 2);
	cout << "\t\t(" << res1 << " + " << res2 << ")/ 2=" << c << endl
		<< "\t\t\tc=" << c << "(мг/дм3)\n"
	<< "\t\t\tc=" << (res1 + res2) / 2.0 << "(мг/дм3)\n";
}	

void  ferum()
{
	double d1_input, d2_input, c1_input, c2_input, c_input;//вход

	double d1_bior, d2_bior, c1_bior, c2_bior, c_bior;//bior

	double d1_secondary, d2_secondary, c1_secondary, c2_secondary, c_secondary;//вторичная

	double d1_output, d2_output, c1_output, c2_output, c_output;//выход

	cout << "\t\t   Железо общее\n\n";//решение для входа
	cout << "   Вход  ";
	D_and_result_ferum(d1_input, d2_input, c1_input, c2_input, 120, 310);
	show_begin_ferum(d1_input, d2_input, c1_input, c2_input);
	show_end_ferum(c1_input, c2_input, c_input);

	cout << "  После биор"; //решение для биора
	D_and_result_ferum(d1_bior, d2_bior, c1_bior, c2_bior, (int)((0.65*c_input - 0.1) * 100), (int)((0.65*c_input + 0.2) * 100));
	show_begin_ferum(d1_bior, d2_bior, c1_bior, c2_bior);
	show_end_ferum(c1_bior, c2_bior, c_bior);

	cout << "  После вторичной"; //решение для вторичной
	D_and_result_ferum(d1_secondary, d2_secondary, c1_secondary, c2_secondary, (int)((0.75*c_bior - 0.15) * 100), (int)((0.75*c_bior + 0.15) * 100));
	show_begin_ferum(d1_secondary, d2_secondary, c1_secondary, c2_secondary);
	show_end_ferum(c1_secondary, c2_secondary, c_secondary);

	cout << "  Выход"; //решение для выхода
	D_and_result_ferum(d1_output, d2_output, c1_output, c2_output, (int)((c_secondary - 0.2) * 100), (int)((c_secondary - 0.1) * 100));
	show_begin_ferum(d1_output, d2_output, c1_output, c2_output);
	show_end_ferum(c1_output, c2_output, c_output);
	cout << "________________________________________________________________________________\n\n";
	return;
}

int main(int argc, char* argv[])
{  
	srand(time(NULL));
	setlocale(LC_ALL, "Russian");
	const int Value = 50;
	int final_res1=0, final_res2=0;
	double m1_1 = 0, m2_1 = 0, m_dushes_1 = 0;
	double m1_2 = 0, m2_2 = 0, m_dushes_2 = 0;//для входа перменые

	int result_1_bior = 0, result_2_bior = 0;//для биора
	double m1_1_bior = 0, m2_1_bior = 0, m_dushes_1_bior = 0;
	double m1_2_bior = 0, m2_2_bior = 0, m_dushes_2_bior = 0;

	int result_1_secondary = 0, result_2_secondary = 0;//для вторичеой
	double m1_1_secondary = 0, m2_1_secondary = 0, m_dushes_1_secondary = 0;
	double m1_2_secondary = 0, m2_2_secondary = 0, m_dushes_2_secondary = 0;

	int result_1_output = 0, result_2_output = 0;//для выхода
	double m1_1_output = 0, m2_1_output = 0, m_dushes_1_output = 0;
	double m1_2_output = 0, m2_2_output = 0, m_dushes_2_output = 0;
	cout << "\t\t   Взвешивание вещества\n\n";
	massa_and_result(m1_1, m2_1, m_dushes_1, final_res1,true,230,370);//решение задачи для входа
	cout << "   Вход  ";
	show_begin(m1_1, m2_1, m_dushes_1, final_res1, Value);
	massa_and_result(m1_2, m2_2, m_dushes_2, final_res2, false,230,370, final_res1);
	show_begin(m1_2, m2_2, m_dushes_2, final_res2, Value);
	show_end(final_res1, final_res2);

	cout << "  После биор.  ";//решение задачи биор
	massa_and_result(m1_1_bior, m2_1_bior, m_dushes_1_bior, result_1_bior, true, 90, 140, 0, 20);
	show_begin(m1_1_bior, m2_1_bior, m_dushes_1_bior, result_1_bior, Value);
	massa_and_result(m1_2_bior, m2_2_bior, m_dushes_2_bior, result_2_bior, false, 90, 140, result_1_bior, 20);
	show_begin(m1_2_bior, m2_2_bior, m_dushes_2_bior, result_2_bior, Value);
	show_end(result_1_bior, result_2_bior);

	cout << "  После втор. ";//Решение для вторичной
	massa_and_result(m1_1_secondary, m2_1_secondary, m_dushes_1_secondary, result_1_secondary, true, 40, 60 );
	show_begin(m1_1_secondary, m2_1_secondary, m_dushes_1_secondary, result_1_secondary, Value);
	massa_and_result(m1_2_secondary, m2_2_secondary, m_dushes_2_secondary, result_2_secondary, false, 40, 60, result_1_secondary);
	show_begin(m1_2_secondary, m2_2_secondary, m_dushes_2_secondary, result_2_secondary, Value);
	show_end(result_1_secondary, result_2_secondary);

	cout << "  Выход  ";//Решение для выхода
	massa_and_result(m1_1_output, m2_1_output, m_dushes_1_output, result_1_output, true, 16, 24);
	show_begin(m1_1_output, m2_1_output, m_dushes_1_output, result_1_output, Value);
	massa_and_result(m1_2_output, m2_2_output, m_dushes_2_output, result_2_output, false, 0, 0, result_1_output );
	show_begin(m1_2_output, m2_2_output, m_dushes_2_output, result_2_output, Value);
	show_end(result_1_output, result_2_output);
	cout << "________________________________________________________________________________\n\n";

	//____________________________________________Сухой остаток(dry)__________________________________________________________________

	int final_res1_dry = 0, final_res2_dry = 0;
	double m1_1_dry = 0, m2_1_dry = 0, m_dushes_1_dry = 0;
	double m1_2_dry = 0, m2_2_dry = 0, m_dushes_2_dry = 0;//для входа перменые(сухой остаток)

	int result_1_bior_dry = 0, result_2_bior_dry = 0;//для биора(сухой остаток)
	double m1_1_bior_dry = 0, m2_1_bior_dry = 0, m_dushes_1_bior_dry = 0;
	double m1_2_bior_dry = 0, m2_2_bior_dry = 0, m_dushes_2_bior_dry = 0;

	int result_1_secondary_dry = 0, result_2_secondary_dry = 0;//для вторичеой(сухой остаток)
	double m1_1_secondary_dry = 0, m2_1_secondary_dry = 0, m_dushes_1_secondary_dry = 0;
	double m1_2_secondary_dry = 0, m2_2_secondary_dry = 0, m_dushes_2_secondary_dry = 0;

	int result_1_output_dry = 0, result_2_output_dry = 0;//для выхода(сухой остаток)
	double m1_1_output_dry = 0, m2_1_output_dry = 0, m_dushes_1_output_dry = 0;
	double m1_2_output_dry = 0, m2_2_output_dry = 0, m_dushes_2_output_dry = 0;
	cout << "\t\t\t   Сухой остаток\n\n";
	massa_and_result(m1_1_dry, m2_1_dry, m_dushes_1_dry, final_res1_dry, true, 500, 700,0,75);//решение задачи для входа(сухой остаток)
	cout << "   Вход  ";
	show_begin(m1_1_dry, m2_1_dry, m_dushes_1_dry, final_res1_dry, Value, false);
	massa_and_result(m1_2_dry, m2_2_dry, m_dushes_2_dry, final_res2_dry, false, 500, 700, final_res1_dry,75);
	show_begin(m1_2_dry, m2_2_dry, m_dushes_2_dry, final_res2_dry, Value,false);
	show_end(final_res1_dry, final_res2_dry);

	cout << "  После биор.  ";//решение задачи биор(сухой остаток)
	massa_and_result(m1_1_bior_dry, m2_1_bior_dry, m_dushes_1_bior_dry, result_1_bior_dry, true, final_res1_dry-180, final_res1_dry-120, 0, 76);
	show_begin(m1_1_bior_dry, m2_1_bior_dry, m_dushes_1_bior_dry, result_1_bior_dry, Value,false);
	massa_and_result(m1_2_bior_dry, m2_2_bior_dry, m_dushes_2_bior_dry, result_2_bior_dry, false, final_res1_dry - 180, final_res1_dry - 120, result_1_bior_dry,76 );
	show_begin(m1_2_bior_dry, m2_2_bior_dry, m_dushes_2_bior_dry, result_2_bior_dry, Value,false);
	show_end(result_1_bior_dry, result_2_bior_dry);

	//Решение для выхода(сухой остаток)
	massa_and_result(m1_1_output_dry, m2_1_output_dry, m_dushes_1_output_dry, result_1_output_dry, true, final_res1_dry / 2 - 15, final_res1_dry / 2 ,0,75);
	
	massa_and_result(m1_2_output_dry, m2_2_output_dry, m_dushes_2_output_dry, result_2_output_dry, false, 0, 0, result_1_output_dry,75);
	

	cout << "  После втор. ";//Решение для вторичной(сухой остаток)
	massa_and_result(m1_1_secondary_dry, m2_1_secondary_dry, m_dushes_1_secondary_dry, result_1_secondary_dry, true, result_1_output_dry + 35, result_1_output_dry + 70, 0,75);
	show_begin(m1_1_secondary_dry, m2_1_secondary_dry, m_dushes_1_secondary_dry, result_1_secondary_dry, Value,false);
	massa_and_result(m1_2_secondary_dry, m2_2_secondary_dry, m_dushes_2_secondary_dry, result_2_secondary_dry, false, 0, 0, result_1_secondary_dry,75);
	show_begin(m1_2_secondary_dry, m2_2_secondary_dry, m_dushes_2_secondary_dry, result_2_secondary_dry, Value,false);
	show_end(result_1_secondary_dry, result_2_secondary_dry);
	cout << "  Выход  ";
	show_begin(m1_1_output_dry, m2_1_output_dry, m_dushes_1_output_dry, result_1_output_dry, Value,false);
	show_begin(m1_2_output_dry, m2_2_output_dry, m_dushes_2_output_dry, result_2_output_dry, Value,false);
	show_end(result_1_output_dry, result_2_output_dry);
	cout << "________________________________________________________________________________\n\n";
	azot_nitr();
	nitrat();
	amon();
	hlor();
	sylfat();
	fosfar();
	ferum();
	
	system("pause");
	return 0;
}
