Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

(КУРСОВАЯ) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Функции!!!!!! http://www.cyberforum.ru/cpp-beginners/thread148043.html
Используя функции написать программу которая общитует формулу формула кто знает помогите гарююююююю!!!!!
C++ Из файла содержащего 65536 целых чисел записать в другой файл значения больше 150 Дан файл File_in.dat, содержащий 65536 целых чисел. Записать в файл File_out.dat значения больше 150. текст программы примерно такой #include<iostream.h> #include<fstream.h> #include<stdlib.h>... http://www.cyberforum.ru/cpp-beginners/thread148035.html
C++ Переделать по условию
вот есть такой код программы: #include<iostream.h> #include<math.h> void main() {double x1,t,x2,dx,x,eps,f,uk; int i,n,q=0; cout<<"введите интервал: "; cin>>x1>>x2; cout<<"введите шаг:...
Перевести эту программу на С++ с паскаля C++
Кто может перевести эту программу на С++ вот задание 1 определит колличество строк без нуле 2 сложить характеристические ряды (это суммы негативных элементов) и переставить ряды матриц...
C++ Дописать код http://www.cyberforum.ru/cpp-beginners/thread148012.html
Хочу, чтобы программа считала: 1) сумму элементов в тех строках, которые не содержат отрицательных элементов 2) минимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы. ...
C++ Создаю форму. Где разместить функциональную часть Здравствуйте, вопрос и состоит в том, где правильно размещать функциональную часть. В консоли все понятно: объявления функций и глобальных переменных до main'а, в main'е локальные переменные. А где... подробнее

Показать сообщение отдельно
RJAVOI
0 / 0 / 0
Регистрация: 19.06.2010
Сообщений: 6

(КУРСОВАЯ) - C++

21.06.2010, 15:46. Просмотров 378. Ответов 0
Метки (Все метки)

в общем такая программа. в ней меняется параметр ТЕМПЕРАТУРА по формуле 0.9*t*t*t+0.2*t*t... Надо чтобы менялся ещё один любой параметр(или КОНЦЕНТРАЦИЯ или УРОВЕНЬ или ДАВЛЕНИЯ) по любому уравнению.
В программе есть классы 1.Технологический объект 2. Датчик 3. Контроллер


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
#include "stdafx.h"
#include "iostream.h"
#include "stdio.h"
//класс технологического объекта
class tech_object 
{
    float param[4];//вектор параметров
    int regim;//режим работы
public:
    void Set_param(int index,float p) { param[index]=p; }//метод установки параметров
    void Set_regim(int r)  { regim=r;}//метод установки режима
    //метод обновления значений параметров в момент t, через промежуток времени dt
    void Update_param(float t, float dt)
    { param[3]+= (float)(regim*(0.9*t*t*t+0.2*t*t-0.9*(t-dt)*(t-dt)*(t-dt)-0.2*(t-dt)*(t-dt))); }
    float Get_param(int index) {return param[index];}//метод получения значения параметра
    int Get_regim(){return regim;}//метод получения текущего режима работы
};
//класс абстрактного датчика
class datchik{
protected:
    char* name;//имя датчика
    tech_object* parent_obj;//указатель на техн. объект к которому привязан датчик
public:
    datchik(char* n,tech_object* t_o){name=n; parent_obj=t_o;}//конструктор датчика
    virtual float Get(){return 0;}//виртуальный метод получения значения параметра
    char* get_name(){ return name;}//метод получения имени датчика
};
//класс датчика температуры, производный от абстрактного датчика
class datchik_temperature:public datchik{
public:
    //конструктор датчика темп-ры, насл-ый от конструктора абстрактного датчика 
    datchik_temperature(char* n,tech_object* t_o):datchik(n,t_o){}
    //метод получения показаний датчика
    float Get(){ return parent_obj->Get_param(0);}
};
//класс датчика давления, наследуемый от абстрактного датчика
class datchik_davlenie:public datchik{
public:
    //конструктор датчика давления, насл-ый от конструктора абстрактного датчика 
    datchik_davlenie(char* n,tech_object* t_o):datchik(n,t_o){}
    //метод получения показаний датчика
    float Get(){ return parent_obj->Get_param(1);}
};
//класс датчика концентрации, производный от абстрактного датчика
class datchik_koncentration:public datchik{
public:
    //конструктор датчика конц-ии, насл-ый от конструктора абстрактного датчика 
    datchik_koncentration(char* n,tech_object* t_o):datchik(n,t_o){}
    //метод получения показаний датчика
    float Get(){ return parent_obj->Get_param(2);}
};
//класс датчика уровня, производный от абстрактного датчика
class datchik_uroven:public datchik{
public:
    //конструктор датчика уровня, насл-ый от конструктора абстрактного датчика 
    datchik_uroven(char* n,tech_object* t_o):datchik(n,t_o){}
    //метод получения показаний датчика
    float Get(){ return parent_obj->Get_param(3);}
};
//Класс контроллера
class controller{
    float graniza[8];//массив границ
    datchik* datch[4];//массив указателей на датчики
    tech_object* tech_obj1;//указатель на технологический  объект
    float iter;//внутреннее время работы
public:
    //конструктор контроллера
    controller(float g[8],datchik* d[4],tech_object* t_o, float timer);
    //получение значения параметра
    float Get_param(int index) {return datch[index]->Get();}
    //получит имя датчика
    char* Get_name(int index){return datch[index]->get_name();}
    //обновление значений параметров через промежуток времени dt
    void Update_obj(float t, float dt) {iter += dt; tech_obj1->Update_param(iter, dt);}
    //метод контроля - переключения режима работы
    void Control();
    //получить режим работы
    int Get_regim() {return tech_obj1->Get_regim();}
};
//конструктор контроллера
controller::controller(float g[8],datchik* d[4],tech_object* t_o, float timer){
    iter = timer;//внутренний таймер равен внешнему
    for(int i=0;i<8;i++) graniza[i]=g[i];//установка границ параметров
    for(i=0;i<4;i++)    datch[i]=d[i];//установка адресов датчиков
    tech_obj1=t_o;//установка адреса технологического объекта
};
//метод контроля - переключения режима работы
void controller::Control(){
    //получаем значение уровня
    float urov=datch[3]->Get();
    //если показатель вышел за правую границу
    if(urov >=graniza[7] && tech_obj1->Get_regim()==1){
        tech_obj1->Set_regim(-1);
        iter = 0;
        cout<<"\nRegim izmenen : umenshenie";
      }
    //если показатель вышел за левую границу
    else
        if(urov<=graniza[6] && tech_obj1->Get_regim()==-1){
            iter = 0;
            tech_obj1->Set_regim(1);
            cout<<"\nRegim izmenen : uvelichenie";
        }
};
//главная функция
void main(int argc, char* argv[])
{
char urov;
//установка промежутка времени между обновлением параметров
float dt = 1, timer;
int regim;
timer=0;
//технологический объект колонна
  tech_object kolonna;
//установка параметров колонны
  kolonna.Set_param(0,2);
  kolonna.Set_param(1,10000);
  kolonna.Set_param(2,0.2);
  kolonna.Set_param(3,0);
//установка режима
  kolonna.Set_regim(1);
//датчики температуры, давления, концентрации, уровня
  datchik_temperature       dat_temp("Temperature",&kolonna);
  datchik_davlenie      dat_davl("Davlenie",&kolonna);
  datchik_koncentration     dat_konc("Koncentration",&kolonna);
  datchik_uroven        dat_urov("Uroven",&kolonna);
//массив указателей на датчики
  datchik* arr_dat[4];
//массив границ параметров
  float g[8];
//установка параметров
  arr_dat[0]=&dat_temp;
  arr_dat[1]=&dat_davl;
  arr_dat[2]=&dat_konc;
  arr_dat[3]=&dat_urov;
//установка границ параметров
  g[0]=1;   g[1]=10;
  g[2]=0;   g[3]=50000;
  g[4]=0;   g[5]=5;
  g[6]=0;   g[7]=500;
//контроллер
  controller Base_controller(g,arr_dat,&kolonna,timer);
//бесконечное количество итераций
while(1){
    cout<<"\nVremja raboty:"<<timer;
    cout<<"\nParametri raboty:";
    //вывод имени и значения параметра датчиков
    for(int i=0;i<4;i++) 
    cout<<"\n"<<i+1<<"."<<Base_controller.Get_name(i)
        <<" = "<<Base_controller.Get_param(i);
    //проверка на выход параметра за границу - переключение режима
    Base_controller.Control();
    //получение режима работы
    regim=Base_controller.Get_regim();
    //эмулируем изменеие времени
    timer+=dt;
    //обновляем параметры
    Base_controller.Update_obj(timer, dt);
    cout<<"\nRegim raboty:";
    if(regim==1) cout<<" uvelichenie parametra";
    else if(regim==-1) cout<<" umenshenie parametra";
    urov='0';
    cout<<"\n\nVvedite podtvergdenie\nProdolgit iteracii?(da/net) - y/n\n";
    //проверка сигнала с клавиатуры
    while((urov!='y')&&(urov!='Y')&&(urov!='n')&&(urov!='N'))
      cin>>urov;
    //если сигнал на завершение, то прерываем итерации
    if((urov =='n')||(urov =='N')) break;
    //если сигнал на продолжение, то продолжаем
    if((urov =='y')||(urov =='Y')) continue;
  }
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru