Дослідження зміни температури термопари за допомогою чисельних методів на ЕОМ
Варіантний аналіз чисельних методів моделювання зміни температури термопари. Основні сучасні вимоги до інтерфейсу та логічної структури програми. Суть сплайн-інтерполяції, лістинг програми та оцінка похибок результатів експериментальних досліджень.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курсовая работа |
Язык | украинский |
Дата добавления | 03.12.2009 |
Размер файла | 698,4 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
3 етап: розробка алгоритмів моделювання зміни температури термопари на ЕОМ (до 20.02.04).
4 етап: розробка керуючої програми, яка повинна працювати в режимі багато ієрархічного меню (до 10.03.04).
5 етап: об'єднання всіх програмних модулів та тестування керуючої програми (до 15.03.04).
6 етап: розробка тестів, тестування та демонстрація роботи всього комплексу (до 15.03.04).
7 етап: розробка технічної документації та пояснювальної записки (до 20.03.04).
8 етап: вимоги до безпеки: розроблене програмне забезпечення повинно відповідати вимогам Сніп та ДЕСТів до робочого місця оператора ЕОМ.
Додаток Б
Лістинги модулів
Лістинг модуля EDITS.H
#include <stdlib.h>
const coloredit=14; // цвет самого поля для ввода
const colordialog=7; //цвет окна диалог
const FEdit1=1;
const FEdit2=0;
const FEdit3=0;
const FEdit4=0;
const FEdit5=0;
const FEdit6=0;
void *arrow;
int size,xy1,xy2,yy1,yy2;
void *arrowp;
int sizep,xy1p,xy2p,yy1p,yy2p;
int FEdit=0;
class TEdit
{
public:
TEdit();
~TEdit(){};
void EditDrow();
void setwidth(int x){width=x;};
void setheight(int x){height=x;};
void settop(int x){top=x;};
void setleft(int x){left=x;};
void setonoff(int x,int k=1){
onoff=x;
if (k) EditDrow();
};
void setcol(int x){color=x;};
void setcapt(char *x){caption=x;};
void settext(char x[20]){strcpy(text,x);};
int getwidth()const {return width;};
int getheight()const {return height;};
int gettop()const {return top;};
int getleft()const {return left;};
int getonoff()const {return onoff;};
int getcol()const {return color;};
const char* getcapt(){return caption;};
const char* gettext(){return text;};
void mousemove(int i);
void onkeypress(int i);
void setpos(int x,int y, char* capt,char* texts,int i=0);
private:
int width;
int height;
int top;
int left;
int onoff;
int color;
char *caption;
char text[20];
};
void TEdit::setpos(int x,int y, char* capt,char* texts,int i)
{
strcpy(text,texts);
left=x;
top=y;
caption=capt;
if (i) EditDrow();
}
TEdit::TEdit()
{
caption='\0';
text[0]='2';
text[1]='3';
text[2]='\0';
width=170;
height=18;
top=0;
left=0;
color=coloredit;
onoff=0;
}
void TEdit::EditDrow()
{
int i;
int x=left;
int y=top;
int xx=width;
int yy=height;
setfillstyle(1,color);
setlinestyle(0,0,0);
mouseoff();
bar(x,y,x+xx,y+yy);
setcolor(8);
line(x-1,y-1,x-1,y+yy+1);
line(x-1,y-1,x+xx+1,y-1);
setcolor(15);
line(x,y+yy+1,x+xx+1,y+yy+1);
line(x+xx+1,y,x+xx+1,y+yy+1);
moveto(6+x,6+y);
setcolor(color+10);
outtext(text);
line(x+strlen(text)*8+6,y+15,x+strlen(text)*8+10,y+15);
moveto(x,y-15);
setcolor(color+13);
outtext(caption);
if (onoff) setcolor(11);
else setcolor(colordialog);
rectangle(x-4,y-4,x+xx+4,y+yy+4);
mouseon();
}
//////////////////////////////////////////////////////////////////
// ОБЪЯВЛЕНИЕ ОБЪЕКТОВ
//////////////////////////////////////////////////////////////////
TEdit *TempEdit, edit1[FEdit1];
// char *strrez[FEdit];
int exittru=1;
void TEdit::mousemove(int i)
{
if (mousein(left,top,left+width,top+height))
{
if (!onoff)
if (getbutton(1))
{
int j;
for ( j=0;j<FEdit;j++)
if ((i!=j)&&(TempEdit[j].getonoff())) TempEdit[j].setonoff(0);
setonoff(1);
}
}
}
void TEdit::onkeypress(int i)
{
if ((onoff)&&(kbhit()))
{
char c=getch();
switch (c)
{
case 8: if (strlen(text))
{
text[strlen(text)-1]='\0';
EditDrow();
}break;
case 9: setonoff(0);
if (i==(FEdit-1)) TempEdit[0].setonoff(1);
else TempEdit[i+1].setonoff(1);break;
case 13:exittru=13;break;
case 27:exittru=27;break;
case 0:
switch (getch())
{
case 72:
setonoff(0);
if (i==0) TempEdit[FEdit-1].setonoff(1);
else TempEdit[i-1].setonoff(1);
break;//up
case 80:
setonoff(0);
if (i==(FEdit-1)) TempEdit[0].setonoff(1);
else TempEdit[i+1].setonoff(1);
break;//down
};break;
}
if (((c>=32)||(c<0))&&(strlen(text)<19))
{
int slen=strlen(text);
text[slen]=c;
text[slen+1]='\0';
EditDrow();
}
}
}
void EditInitall()
{
edit1[0].setpos(200,200,"","");
}
void EditInit()
{
TempEdit[0].setonoff(1,0);
int i;
for (i=1;i<FEdit;i++)
TempEdit[i].setonoff(0,0);
xy1=TempEdit[0].getleft()-10;
yy1=TempEdit[0].gettop()-45;
xy2=TempEdit[FEdit-1].getleft()+TempEdit[FEdit-1].getwidth()+10;
yy2=TempEdit[FEdit-1].gettop()+TempEdit[FEdit-1].getheight()-yy1+10;
size = imagesize(xy1-2, yy1-2, xy2+4, yy1+yy2+2);
arrow = malloc(size);
mouseoff();
getimage(xy1-2, yy1-2, xy2+4, yy1+yy2+2, arrow);
mouseon();
windows(xy1,yy1,xy2-xy1+2,yy2,colordialog,"",0);
windows(xy1+2,yy1+2,xy2-xy1-2,18,1,"Ввiд",1);
for ( i=0;i<FEdit;i++)
{
TempEdit[i].EditDrow();
}
}
void EditEnter(TEdit *edit1, int rrr)
{
int i;
FEdit=rrr;
TempEdit=edit1;
EditInit();
exittru=0;
while (!exittru)
{
for (i=0; i<FEdit; i++)
{
TempEdit[i].onkeypress(i);
TempEdit[i].mousemove(i);
}
}
mouseoff();
putimage(xy1-2, yy1-2,arrow,0);
mouseon();
free(arrow);
}
/////////////////////// END DIALOG ////////////////////////////////
Лістинг модуля WIND.H
#include <graphics.h>
#include "mouse.h"
void windows(int x,int y,int xx,int yy,int color,char s[100],int p)
{
int i;
setfillstyle(1,color);
setlinestyle(0,0,0);
mouseoff();
bar(x,y,x+xx,y+yy);
if (p) setcolor(8);
else setcolor(15);
line(x-1,y-1,x-1,y+yy+1);
line(x-1,y-1,x+xx+1,y-1);
if (! p) setcolor(8);
else setcolor(15);
line(x,y+yy+1,x+xx+1,y+yy+1);
line(x+xx+1,y,x+xx+1,y+yy+1);
if (! p) moveto(5+x,5+y);
else moveto(6+x,6+y);
setcolor(color+10);
outtext(s);
mouseon();
}
Лістинг модуля CALC.H
#include <math.h>
#include <stdlib.h>
#include <string.h>
#include <process.h>
const N=6;
float x[N]={0, 20, 40, 60, 80, 100},
y[N]={-0.67, -0.254, 0.171, 0.609, 1.057, 1.517};
//float x[N]={1, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7},
// y[N]={1, 0.90909, 0.83333, 0.76923, 0.71329, 0.66667, 0.625, 0.58824};
float
dy0=y[1]-y[0];
int COO=0;
float H=x[1]-x[0];
double stepin(double x1,int f)
{
if (f==0) return 1.0;
double rez=x1;
for (int i=1;i<f;i++)
rez*=x1;
// printf("\nx1=%f ^=%d rez=%f if_0=%d",x1,f,rez, rez==0);
return rez;
}
double faktorial(int k)
{
double rez=1;
for (int i=1;i<=k;i++)
rez*=i;
// printf("\n fact(%d)=%f",k,rez);
return rez;
}
double GetA(int i)
{
// if (i) return (stepin(((y[i]-y[i-1])/H),i)*(1/faktorial(i)));
if (i) return (stepin((dy0),i)/(faktorial(i)*stepin(H,i)));
else
return y[0];
}
double IntNuton1(double X1) //Интерполяц по NUTON 1
{
// return 0;
double D,S;
S=0;
int i,j;
for (i=0;i<N;i++)
{
D=GetA(i);
for (j=0;j<i;j++)
{
D*=(X1-x[j]);
}
S+=D;
// printf("\nS=%10.10f",S);
}
return S;
}
double GetB(int i)
{
if (i) return (stepin(((y[N-i]-y[N-i-1])/H),i)*(1/faktorial(i)));
else
return y[N-1];
}
double IntNuton2(double X1) //Интерполяц по NUTON 2
{
// return 0;
double D,S;
S=0;
int i,j;
for (i=0;i<N;i++)
{
D=GetB(i);
for (j=(N-1);j>=(N-i);j--)
{
D*=(X1-x[j]);
}
S+=D;
}
return S;
}
double IntLang(double X1) //Интерполяц по Лагранджу
{
// return 0;
// printf("\n%d",COO++);
double D,S;
S=0;
int i,j;
for (i=0;i<N;i++)
{
D=1;
for (j=0;j<N;j++)
{
if (i!=j) D*=(X1-x[j])/(x[i]-x[j]);
}
S+=D*y[i];
}
return S;
}
Лістинг модуля MOUSE.H
#include <dos.h>
#include <conio.h>
#include <stdio.h>
#include <process.h>
struct REGPACK reg;
//инициализирует мышу
int mouseinit()
{ reg.r_ax=0;
intr(0x33,®);
if (!reg.r_ax) {
textcolor(15+128);
gotoxy(23,10);printf("г=========E R R O R=========¬");
gotoxy(23,11);printf("¦ MOUSE IS NOT PRESENT! ¦");
gotoxy(23,12);printf("¦ Press any key ..... ¦");
gotoxy(23,13);printf("L===========================-");
getch();
textcolor(7);
return 1;
}
return 0;
}
//показывает курсор мыши
void mouseon()
{
reg.r_ax=1;
intr(0x33,®);
}
//прячет курсор мыши
void mouseoff()
{
reg.r_ax=2;
intr(0x33,®);
}
// возвращает координаты мыши
void getmousexy(int *x,int *y)
{
reg.r_ax=3;
intr(0x33,®);
*x=reg.r_cx;
*y=reg.r_dx;
}
//устанавливает координаты
void setmousexy(int x,int y)
{
reg.r_cx=x;
reg.r_dx=y;
reg.r_ax=4;
intr(0x33,®);
}
const left=1;
const right=2;
int getbutton(int but)
{
reg.r_ax=5;
reg.r_bx=but;
intr(0x33,®);
return (reg.r_ax)==but;
}
int mousein(int x1,int y1,int x2,int y2)
{
int x,y;
getmousexy(&x,&y);
if (x>=x1 & x<=x2 & y>=y1 & y<=y2) return 1; else return 0;
}
Додаток В
Структура дискети
Подобные документы
Огляд та варіантний аналіз чисельних методів моделювання, основні поняття і визначення. Опис методів моделювання на ЕОМ, метод прямокутників і трапецій. Планування вхідних та вихідних даних, аналіз задач, які вирішуються при дослідженні об’єкта на ЕОМ.
курсовая работа [373,6 K], добавлен 30.11.2009Дослідження методу сплайнів для вирішення задачі інтерполяції. Вибір методів технічних та інструментальних засобів вирішення задачі, їх алгоритми. Розробка логічної частини програми, результати обчислень. Розв’язання задачі в пакетах прикладних програм.
курсовая работа [278,5 K], добавлен 03.12.2009Огляд та варіантний аналіз чисельних методів дослідження еліптичного інтегралу першого порядку. Опис методів дослідження еліптичного інтегралу першого порядку на ЕОМ. Планування вхідних та вихідних даних, описовий алгоритм головної програми, його схема.
курсовая работа [148,0 K], добавлен 30.11.2009Варіантний аналіз та вибір методів розв’язування, основні поняття та визначення, особливості розробки баз даних. Описовий алгоритм головної програми та її структури, опис авторської заставки. Структура модулів та опис функцій, лістинг програми.
курсовая работа [2,6 M], добавлен 30.11.2009Дослідження методів чисельного інтегрування Чебишева та Трапеції, порівняння їх точності. Способи розробки програми на компіляторі Turbo C++, яка знаходить чисельне значення вказаного інтегралу. Обґрунтування вибору інструментальних засобів програми.
курсовая работа [262,4 K], добавлен 18.09.2010В роботі розглянуто наближені методи розв'язку нелінійних рівнянь для методів Ньютона та хорд, складено блок-схеми та написано програму, за допомогою якої розв'язується задане рівняння. Аналіз рівняння, методів його розв'язання і результатів обрахунку.
курсовая работа [380,9 K], добавлен 30.11.2009Методи інтерполяції: ітераційний та метод розподілених різниць. Інтерполяційна формула Лагранжа. Алгоритмізація та реалізація методів на ЕОМ в середовищі мови програмування Turbo Pascal 7.0. Аналіз результатів моделювання, інструкція користувачеві.
курсовая работа [680,9 K], добавлен 11.02.2010Розробка структурної схеми системи управління, головні вимоги до основних елементів. Обґрунтування та вибір елементної бази. Блок-схема алгоритму і програми реалізації закону управління (лістинг програми). Зміст програми керування мікроконтроллером.
курсовая работа [170,7 K], добавлен 28.08.2012Загальна характеристика методів проектування та документації додатків. Розробка інтерфейсу програми для медичного діагностичного центру. Вибір архітектури. Описання логічної структури програми. Розробка структури бази даних проекту, полів таблиць.
курсовая работа [2,0 M], добавлен 21.08.2015Використання мови програмуванння Java при виконанні "задачі лінійного програмування": її лексична структура і типи даних. Методи розв’язання задачі. Особливості логічної структури програми, побудова її зручного інтерфейсу за допомогою симплекс методу.
курсовая работа [437,9 K], добавлен 24.01.2011