#define _CRT_SECURE_NO_WARNINGS
# include <cstdlib>
# include <iostream>
# include <iomanip>
#include <string>
# include <fstream>
# include <ctime>
# include <cmath>
using namespace std;
int main();
void dtable_data_write(ofstream &output, int m, int n, double table[]);
void dtable_write(string output_filename, int m, int n, double table[],
bool header);
void f(double a, double b, double t0, double t, int n, double x[],
double value[]);
int r83_np_fa(int n, double a[]);
double *r83_np_sl(int n, double a_lu[], double b[], int job);
void timestamp();
void u0(double a, double b, double t0, int n, double x[], double value[]);
double ua(double a, double b, double t0, double t);
double ub(double a, double b, double t0, double t);
int main()
{
double *a;
double *b;
double *fvec;
bool header;
int i;
int info;
int j;
int job;
double k;
double *t;
double t_delt;
string t_file;
double t_max;
double t_min;
int t_num;
double *u;
string u_file;
double w;
double *x;
double x_delt;
string x_file;
double x_max;
double x_min;
int x_num;
setlocale(LC_ALL, "Russian");
timestamp();
cout << "\n";
cout << "FD1D_HEAT_IMPLICIT\n";
cout << " Язык разработки C++\n";
cout << "\n";
cout << " Конечно-разностное решение\n";
cout << " Зависимое от времени одномерное уравнение теплопроводности\n";
cout << "\n";
cout << " Ut - k * Uxx = F(x,t)\n";
cout << "\n";
cout << " для пространственного интервала А<=X <=B с граничными условиями\n";
cout << "\n";
cout << " U(A,t) = UA(t)\n";
cout << " U(B,t) = UB(t)\n";
cout << "\n";
cout << " и временной интервал T0 <= T <= T1 с начальным условием\n";
cout << "\n";
cout << " U(X,T0) = U0(X).\n";
cout << "\n";
k = 5.0E-07;
//
// Set X values.
//
x_min = 0.0;
x_max = 0.1;
x_num = 2;
x_delt = (x_max - x_min) / (double)(x_num - 1);
x = new double[x_num];
for (i = 0; i < x_num; i++)
{
x[i] = ((double)(x_num - i - 1) * x_min
+ (double)(i)* x_max)
/ (double)(x_num - 1);
}
//
// Set T values.
//
t_min = 0.0;
t_max = 5000.0;
t_num = 20;
t_delt = (t_max - t_min) / (double)(t_num - 1);
t = new double[t_num];
for (j = 0; j < t_num; j++)
{
t[j] = ((double)(t_num - j - 1) * t_min
+ (double)(j)* t_max)
/ (double)(t_num - 1);
}
//
// Set the initial data, for time T_MIN.
//
u = new double[x_num*t_num];
u0(x_min, x_max, t_min, x_num, x, u);
//
//
w = k * t_delt / x_delt / x_delt;
a = new double[3 * x_num];
a[0 + 0 * 3] = 0.0;
a[1 + 0 * 3] = 1.0;
a[0 + 1 * 3] = 0.0;
for (i = 1; i < x_num - 1; i++)
{
a[2 + (i - 1) * 3] = -w;
a[1 + i * 3] = 1.0 + 2.0 * w;
a[0 + (i + 1) * 3] = -w;
}
a[2 + (x_num - 2) * 3] = 0.0;
a[1 + (x_num - 1) * 3] = 1.0;
a[2 + (x_num - 1) * 3] = 0.0;
//
// Factor the matrix.
//
info = r83_np_fa(x_num, a);
b = new double[x_num];
fvec = new double[x_num];
for (j = 1; j < t_num; j++)
{
//
// Set the right hand side B.
//
b[0] = ua(x_min, x_max, t_min, t[j]);
f(x_min, x_max, t_min, t[j - 1], x_num, x, fvec);
for (i = 1; i < x_num - 1; i++)
{
b[i] = u[i + (j - 1)*x_num] + t_delt * fvec[i];
}
b[x_num - 1] = ub(x_min, x_max, t_min, t[j]);
delete[] fvec;
job = 0;
fvec = r83_np_sl(x_num, a, b, job);
for (i = 0; i < x_num; i++)
{
u[i + j*x_num] = fvec[i];
}
}
x_file = "x.txt";
header = false;
dtable_write(x_file, 1, x_num, x, header);
cout << "\n";
cout << " X data written to \"" << x_file << "\".\n";
t_file = "t.txt";
header = false;
dtable_write(t_file, 1, t_num, t, header);
cout << " T data written to \"" << t_file << "\".\n";
u_file = "u.txt";
header = false;
dtable_write(u_file, x_num, t_num, u, header);
cout << " U data written to \"" << u_file << "\".\n";
cout << "\n";
cout << "FD1D_HEAT_IMPLICIT\n";
cout << " Normal end of execution.\n";
cout << "\n";
timestamp();
delete[] a;
delete[] b;
delete[] fvec;
delete[] t;
delete[] u;
delete[] x;
return 0;
}
//****************************************************************************80
void dtable_data_write(ofstream &output, int m, int n, double table[])
{
int i;
int j;
for (j = 0; j < n; j++)
{
for (i = 0; i < m; i++)
{
output << setw(10) << table[i + j*m] << " ";
}
output << "\n";
}
return;
}
//****************************************************************************80
void dtable_write(string output_filename, int m, int n, double table[],
bool header)
{
ofstream output;
output.open(output_filename.c_str());
if (!output)
{
cerr << "\n";
cerr << "DTABLE_WRITE - Fatal error!\n";
cerr << " Could not open the output file.\n";
return;
}
if (header)
{
// dtable_header_write ( output_filename, output, m, n );
}
dtable_data_write(output, m, n, table);
output.close();
return;
}
//****************************************************************************80
void f(double a, double b, double t0, double t, int n, double x[],
double value[])
{
int i;
for (i = 0; i < n; i++)
{
value[i] = 0.0;
}
return;
}
//****************************************************************************80
int r83_np_fa(int n, double a[])
{
int i;
for (i = 1; i <= n - 1; i++)
{
if (a[1 + (i - 1) * 3] == 0.0)
{
cout << "\n";
cout << "R83_NP_FA - Fatal error!\n";
cout << " Zero pivot on step " << i << "\n";
return i;
}
//
// Store the multiplier in L.
//
a[2 + (i - 1) * 3] = a[2 + (i - 1) * 3] / a[1 + (i - 1) * 3];
//
// Modify the diagonal entry in the next column.
//
a[1 + i * 3] = a[1 + i * 3] - a[2 + (i - 1) * 3] * a[0 + i * 3];
}
if (a[1 + (n - 1) * 3] == 0.0)
{
cout << "\n";
cout << "R83_NP_FA - Fatal error!\n";
cout << " Zero pivot on step " << n << "\n";
return n;
}
return 0;
}
//****************************************************************************80
double *r83_np_sl(int n, double a_lu[], double b[], int job)
{
int i;
double *x;
x = new double[n];
for (i = 0; i < n; i++)
{
x[i] = b[i];
}
if (job == 0)
{
//
// Solve L * Y = B.
//
for (i = 1; i < n; i++)
{
x[i] = x[i] - a_lu[2 + (i - 1) * 3] * x[i - 1];
}
//
// Solve U * X = Y.
//
for (i = n; 1 <= i; i--)
{
x[i - 1] = x[i - 1] / a_lu[1 + (i - 1) * 3];
if (1 < i)
{
x[i - 2] = x[i - 2] - a_lu[0 + (i - 1) * 3] * x[i - 1];
}
}
}
else
{
//
// Solve U' * Y = B
//
for (i = 1; i <= n; i++)
{
x[i - 1] = x[i - 1] / a_lu[1 + (i - 1) * 3];
if (i < n)
{
x[i] = x[i] - a_lu[0 + i * 3] * x[i - 1];
}
}
//
// Solve L' * X = Y.
//
for (i = n - 1; 1 <= i; i--)
{
x[i - 1] = x[i - 1] - a_lu[2 + (i - 1) * 3] * x[i];
}
}
return x;
}
//****************************************************************************80
void timestamp()
/
{
# define TIME_SIZE 40
static char time_buffer[TIME_SIZE];
const struct tm *tm;
size_t len;
time_t now;
now = time(NULL);
tm = localtime(&now);
len = strftime(time_buffer, TIME_SIZE, "%d %B %Y %I:%M:%S %p", tm);
cout << time_buffer << "\n";
return;
# undef TIME_SIZE
}
//****************************************************************************80
void u0(double a, double b, double t0, int n, double x[], double value[])
{
int i;
for (i = 0; i < n; i++)
{
value[i] = 100.0;
}
return;
}
//****************************************************************************80
double ua(double a, double b, double t0, double t)
{
double value;
value = 20.0;
return value;
}
double ub(double a, double b, double t0, double t)
{
double value;
value = 20.0;
system("PAUSE");
return value;
}
#define _CRT_SECURE_NO_WARNINGS
# include <cstdlib>
# include <iostream>
# include <iomanip>
#include <string>

# include <fstream>
# include <ctime>
# include <cmath>
 

using namespace std;

int main();
void dtable_data_write(ofstream &output, int m, int n, double table[]);
void dtable_write(string output_filename, int m, int n, double table[],
	bool header);
void f(double a, double b, double t0, double t, int n, double x[],
	double value[]);
int r83_np_fa(int n, double a[]);
double *r83_np_sl(int n, double a_lu[], double b[], int job);
void timestamp();
void u0(double a, double b, double t0, int n, double x[], double value[]);
double ua(double a, double b, double t0, double t);
double ub(double a, double b, double t0, double t);


int main()



{
	double *a;
	double *b;
	double *fvec;
	bool header;
	int i;
	int info;
	int j;
	int job;
	double k;
	double *t;
	double t_delt;
	string t_file;
	double t_max;
	double t_min;
	int t_num;
	double *u;
	string u_file;
	double w;
	double *x;
	double x_delt;
	string x_file;
	double x_max;
	double x_min;
	int x_num;
	setlocale(LC_ALL, "Russian");
	timestamp();
	cout << "\n";
	cout << "FD1D_HEAT_IMPLICIT\n";
	cout << "  Язык разработки C++\n";
	cout << "\n";
	cout << "  Конечно-разностное решение\n";
	cout << "  Зависимое от времени одномерное уравнение теплопроводности\n";
	cout << "\n";
	cout << "    Ut - k * Uxx = F(x,t)\n";
	cout << "\n";
	cout << "  для пространственного интервала А<=X <=B с граничными условиями\n";
	cout << "\n";
	cout << "    U(A,t) = UA(t)\n";
	cout << "    U(B,t) = UB(t)\n";
	cout << "\n";
	cout << "  и временной интервал T0 <= T <= T1 с начальным условием\n";
	cout << "\n";
	cout << "    U(X,T0) = U0(X).\n";
	cout << "\n";


	k = 5.0E-07;
	//
	//  Set X values.
	//
	x_min = 0.0;
	x_max = 0.1;
	x_num = 2;
	x_delt = (x_max - x_min) / (double)(x_num - 1);

	x = new double[x_num];

	for (i = 0; i < x_num; i++)
	{
		x[i] = ((double)(x_num - i - 1) * x_min
			+ (double)(i)* x_max)
			/ (double)(x_num - 1);
	}
	// 
	//  Set T values.
	//
	t_min = 0.0;
	t_max = 5000.0;
	t_num = 20;
	t_delt = (t_max - t_min) / (double)(t_num - 1);

	t = new double[t_num];

	for (j = 0; j < t_num; j++)
	{
		t[j] = ((double)(t_num - j - 1) * t_min
			+ (double)(j)* t_max)
			/ (double)(t_num - 1);
	}
	//
	//  Set the initial data, for time T_MIN.
	//
	u = new double[x_num*t_num];

	u0(x_min, x_max, t_min, x_num, x, u);
	//

	//
	w = k * t_delt / x_delt / x_delt;

	a = new double[3 * x_num];

	a[0 + 0 * 3] = 0.0;

	a[1 + 0 * 3] = 1.0;
	a[0 + 1 * 3] = 0.0;

	for (i = 1; i < x_num - 1; i++)
	{
		a[2 + (i - 1) * 3] = -w;
		a[1 + i * 3] = 1.0 + 2.0 * w;
		a[0 + (i + 1) * 3] = -w;
	}

	a[2 + (x_num - 2) * 3] = 0.0;
	a[1 + (x_num - 1) * 3] = 1.0;

	a[2 + (x_num - 1) * 3] = 0.0;
	//
	//  Factor the matrix.
	//
	info = r83_np_fa(x_num, a);

	b = new double[x_num];
	fvec = new double[x_num];

	for (j = 1; j < t_num; j++)
	{
		//
		//  Set the right hand side B.
		//
		b[0] = ua(x_min, x_max, t_min, t[j]);

		f(x_min, x_max, t_min, t[j - 1], x_num, x, fvec);

		for (i = 1; i < x_num - 1; i++)
		{
			b[i] = u[i + (j - 1)*x_num] + t_delt * fvec[i];
		}

		b[x_num - 1] = ub(x_min, x_max, t_min, t[j]);

		delete[] fvec;

		job = 0;
		fvec = r83_np_sl(x_num, a, b, job);

		for (i = 0; i < x_num; i++)
		{
			u[i + j*x_num] = fvec[i];
		}
	}

	x_file = "x.txt";
	header = false;
	dtable_write(x_file, 1, x_num, x, header);

	cout << "\n";
	cout << "  X data written to \"" << x_file << "\".\n";

	t_file = "t.txt";
	header = false;
	dtable_write(t_file, 1, t_num, t, header);

	cout << "  T data written to \"" << t_file << "\".\n";

	u_file = "u.txt";
	header = false;
	dtable_write(u_file, x_num, t_num, u, header);

	cout << "  U data written to \"" << u_file << "\".\n";

	cout << "\n";
	cout << "FD1D_HEAT_IMPLICIT\n";
	cout << "  Normal end of execution.\n";
	cout << "\n";
	timestamp();

	delete[] a;
	delete[] b;
	delete[] fvec;
	delete[] t;
	delete[] u;
	delete[] x;

	return 0;
}
//****************************************************************************80

void dtable_data_write(ofstream &output, int m, int n, double table[])


{
	int i;
	int j;

	for (j = 0; j < n; j++)
	{
		for (i = 0; i < m; i++)
		{
			output << setw(10) << table[i + j*m] << "  ";
		}
		output << "\n";
	}

	return;
}
//****************************************************************************80

void dtable_write(string output_filename, int m, int n, double table[],
	bool header)

	
{
	ofstream output;

	output.open(output_filename.c_str());

	if (!output)
	{
		cerr << "\n";
		cerr << "DTABLE_WRITE - Fatal error!\n";
		cerr << "  Could not open the output file.\n";
		return;
	}

	if (header)
	{
		//  dtable_header_write ( output_filename, output, m, n );
	}

	dtable_data_write(output, m, n, table);

	output.close();

	return;
}
//****************************************************************************80

void f(double a, double b, double t0, double t, int n, double x[],
	double value[])

{
	int i;

	for (i = 0; i < n; i++)
	{
		value[i] = 0.0;
	}
	return;
}
//****************************************************************************80

int r83_np_fa(int n, double a[])


{
	int i;

	for (i = 1; i <= n - 1; i++)
	{
		if (a[1 + (i - 1) * 3] == 0.0)
		{
			cout << "\n";
			cout << "R83_NP_FA - Fatal error!\n";
			cout << "  Zero pivot on step " << i << "\n";
			return i;
		}
		//
		//  Store the multiplier in L.
		//
		a[2 + (i - 1) * 3] = a[2 + (i - 1) * 3] / a[1 + (i - 1) * 3];
		//
		//  Modify the diagonal entry in the next column.
		//
		a[1 + i * 3] = a[1 + i * 3] - a[2 + (i - 1) * 3] * a[0 + i * 3];
	}

	if (a[1 + (n - 1) * 3] == 0.0)
	{
		cout << "\n";
		cout << "R83_NP_FA - Fatal error!\n";
		cout << "  Zero pivot on step " << n << "\n";
		return n;
	}

	return 0;
}
//****************************************************************************80

double *r83_np_sl(int n, double a_lu[], double b[], int job)


{
	int i;
	double *x;

	x = new double[n];

	for (i = 0; i < n; i++)
	{
		x[i] = b[i];
	}

	if (job == 0)
	{
		//
		//  Solve L * Y = B.
		//
		for (i = 1; i < n; i++)
		{
			x[i] = x[i] - a_lu[2 + (i - 1) * 3] * x[i - 1];
		}
		//
		//  Solve U * X = Y.
		//
		for (i = n; 1 <= i; i--)
		{
			x[i - 1] = x[i - 1] / a_lu[1 + (i - 1) * 3];
			if (1 < i)
			{
				x[i - 2] = x[i - 2] - a_lu[0 + (i - 1) * 3] * x[i - 1];
			}
		}
	}
	else
	{
		//
		//  Solve U' * Y = B
		//
		for (i = 1; i <= n; i++)
		{
			x[i - 1] = x[i - 1] / a_lu[1 + (i - 1) * 3];
			if (i < n)
			{
				x[i] = x[i] - a_lu[0 + i * 3] * x[i - 1];
			}
		}
		//
		//  Solve L' * X = Y.
		//
		for (i = n - 1; 1 <= i; i--)
		{
			x[i - 1] = x[i - 1] - a_lu[2 + (i - 1) * 3] * x[i];
		}
	}

	return x;
}
//****************************************************************************80

void timestamp()

/
{
# define TIME_SIZE 40

	static char time_buffer[TIME_SIZE];
	const struct tm *tm;
	size_t len;
	time_t now;

	now = time(NULL);
	tm = localtime(&now);

	len = strftime(time_buffer, TIME_SIZE, "%d %B %Y %I:%M:%S %p", tm);

	cout << time_buffer << "\n";

	return;
# undef TIME_SIZE
}
//****************************************************************************80

void u0(double a, double b, double t0, int n, double x[], double value[])


{
	int i;

	for (i = 0; i < n; i++)
	{
		value[i] = 100.0;
	}
	return;
}
//****************************************************************************80

double ua(double a, double b, double t0, double t)


{
	double value;

	value = 20.0;

	return value;
}


double ub(double a, double b, double t0, double t)

{
	double value;

	value = 20.0;
	system("PAUSE");
	return value;
	

	
	
}