0 / 0 / 0
Регистрация: 13.11.2015
Сообщений: 10

Построение графика в Exel по данным из файла полученного в ходе выполнения программы

15.05.2016, 15:54. Показов 1315. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Допустим есть программа которая вычисляет значения системы диф ур I(t) и U(t) , затем выводи их в файл xls который создается в папке проекта visual studio 2015 pro, в нем четыре графы i(порядковый номер) t I(t) U(t) выходит по 2000 значений каждого параметра, так вот как по этим значениям построить два графика в этом же файле , графики зависимости I(t) и U(t) , заранее весьма благодарен
Код
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
#include "stdafx.h"
 
 
#include <iostream>
#include <fstream>
#include <iomanip>
#include <math.h>
 
using namespace std;
 
int n;
double f, fi, R1, R2, R3, R4, R5, R6, t0, t1, t2, L, C, h, hz, E0, w, pi, D1, D2, D3, FI, FU, T1, T2, R7, B1, B2, B3, FIz, FUz;
double I[2000], U[2000], t[2000], tz[2000], Iz[2000], Uz[2000];
double E(double tl)
{
    if (tl>t1) { return 0; }
    else { return E0 + E0*sin(w*tl + fi); }
}
double fI(double tl, double Il, double Ul)
{
    return (1/(L*D1))*(L*D2*E(tl)+E(tl)*(D3*R4+((R2*(R6+R7))/(R7*(R1+R2))))- Il*(R6+D1*R4+((L*D2)/C)+((R6+R7)/R7)*(R3+((R1*R2)/(R1+R2))))- Ul*(D2*R4+((R7+R6)/R7)));
}
double fU(double tl, double Il, double Ul)
{
    return (1 / C)*(Il);
}
double fIz(double tzl, double Izl, double Uzl)
{
    return -Izl *(B1/B3)-Uzl*(B2/B3);
}
double fUz(double tzl, double Izl, double Uzl)
{
    return (1 / C)*(Izl);
}
int main()
{
    setlocale(LC_ALL, "Russian");
    int i;
    pi = acos(-1.0);
    f = 15;
    fi = 0;
    R1 = 32;
    R2 = 22;
    R3 = 48;
    R4 = 1.75;
    R5 = 16;
    R6 = 10;
    R7 = 25.6;
    t0 = 0;   t1 = 0.2;   t2 = 0.4;
    E0 = 30;     L = 10.3*pow(10.0, -3);    C = 28 * pow(10.0, -6);
    w = 2 * pi*f; n = 2000;    h = (t1 - t0) / n;
    cout << endl;
    cout << "h= " << h << endl;
    cout << endl;
    cout << "i=" << setw(15) << "t=" << setw(15) << "I(t)=" << setw(15) << "U(t)=" << endl;
    U[1] = 0; I[1] = 0; t[1] = 0;
    D1 = 1+((R3+R6)/R5)+((R1*R2)/((R1+R2)*R5))+((R5+R6)/(R5*R7))*(((R1*R2)/(R1+R2))+R3);  
    D2 = (1 / R5)+((R5-R6)/(R5*R7));  
    D3 = (R2*(R5+R6))/(R5*R7*(R1+R2))+((R2)/(R1*R5));
    ofstream f,fx;
    f.open("file.txt");
    fx.open("file.xls");
    f << "i" << setw(15) << "t[i]" << setw(15) << "I[i]" << setw(15) << "U[i]" << endl;
    fx << "i" << "\t" <<  "\t" << "t[i]" << "\t" << "\t"  << "I[i]" << "\t" << "\t" << "U[i]" << endl;
    
    for (i = 0; i <= n; i++)
    {
        t[i + 1] = t[i] + h;
        FI = fI(t[i], I[i], U[i]);
        FU = fU(t[i], I[i], U[i]);
        I[i + 1] = I[i] + h *( U[i]+ (h/2)*FI);
        U[i + 1] = U[i] +h*fI(t[i]+(h/2),I[i]+(h/2)*U[i],U[i]+(h/2)*FU) ;
        cout << i << setw(15) << t[i] << setw(15) << I[i] << setw(15) << U[i] << endl;
        f << i << setw(15) << t[i] << setw(15) << I[i] << setw(15) << U[i] << endl;
        fx << i << "\t" << "\t" << t[i] << "\t" << "\t" << I[i] << "\t" << "\t" << U[i] << endl;
    }
    f.close(); fx.close();
    ofstream z, zx;
    z.open("file2.txt");
    zx.open("file2.xls");
    cout << "Без учета E(t)" << endl;
    z << "Без учета E(t)" << endl;
    zx << "Без учета E(t)" << endl;
    cout<< "i" << setw(15) << "t[i]" << setw(15) << "I[i]" << setw(15) << "U[i]" << endl;
    z << "i" << setw(15) << "t[i]" << setw(15) << "I[i]" << setw(15) << "U[i]" << endl;
    zx << "i" << "\t" << "\t" << "t[i]" << "\t" << "\t" << "I[i]" << "\t" << "\t" << "U[i]" << endl;
    Uz[0] = U[2000]; Iz[0] = I[2000]; tz[0] = t[2000];
    B1 = (((R3 + R2)*R5) / (R5 + R6)) + (R4 + ((R5*R6) / (R5 + R6)))*(((R5 + R6)*(R7 + R3 + R2)) / (R5*R7) + ((R3 + R2) / R5)) + (L / C)*((R5 + R6 + R7) / (R5*R7));
    B2 = (R5 / (R5 + R6)) + (R4 + ((R5*R6) /( R5 + R6)))*((R5 + R6 + R7) / (R5*R7));
    B3 = L*(((R5 + R6)*(R7 + R3 + R2) + R7*(R3 + R2)) / (R5*R7));
    hz = (t2 - t1) / n;
    for (i = 0; i <= n; i++)
    {
        tz[i + 1] = tz[i] + hz;
        FIz = fIz(tz[i], Iz[i], Uz[i]);
        FUz = fUz(tz[i], Iz[i], Uz[i]);
        Iz[i + 1] = Iz[i] + hz *(Uz[i] + (hz / 2)*fIz(tz[i],Iz[i],Uz[i]));
        Uz[i + 1] = Uz[i] + hz*fIz(tz[i] + (hz / 2), Iz[i] + (hz / 2)*Uz[i], Uz[i] + (hz / 2)*fUz(tz[i],Iz[i],Uz[i]));
        cout << i << setw(15) << tz[i] << setw(15) << Iz[i] << setw(15) << Uz[i] << endl;
        z << i << setw(15) << tz[i] << setw(15) << Iz[i] << setw(15) << Uz[i] << endl;
        zx << i << "\t" << "\t" << tz[i] << "\t" << "\t" << Iz[i] << "\t" << "\t" << Uz[i] << endl;
    }
    z.close();
    zx.close();
 
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.05.2016, 15:54
Ответы с готовыми решениями:

Построение графика по данным из файла
Доброго времени суток!!!у меня такой вопрос , возможно ли перевести массив чисел &quot;arr1&quot; в одну переменную &quot;a&quot;? ...

Построение графика по данным из файла
доброго времени...=), в .txt записываются числа построчно. для примера: 1 0 0 1 1 0 0

Построение графика по данным из текстового файла
Доброго времени суток уважаемые форумчане! я обучаюсь заочно и нам программу показали на 1 паре на слайде и на этом спасибо. мне особо...

1
Модератор
 Аватар для vxg
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,429
16.05.2016, 10:51
Цитата Сообщение от Verger Посмотреть сообщение
Допустим
подготовьте файл - заполните его типичным данными, постройте и настройте графики и сохраните его как шаблон - программа создаст на его базе новый файл и заполнит его актуальными данными - графики построятся сами
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.05.2016, 10:51
Помогаю со студенческими работами здесь

Построение графика по данным из txt файла
11.09.2014 10:20:17;1389; 11.09.2014 10:21:17;1390; 11.09.2014 10:22:17;1387; 11.09.2014 10:23:17;1399; 11.09.2014 10:24:17;1365; ...

Выполнение кода, полученного в ходе работы программы
Доброго времени суток! Имеется приложение, в котором пользователь, в соответствующее поле, заносит свой код (например, создание фреймика...

Задание имени переменной в ходе выполнения программы
Вопрос в следующем. Можно ли задавать имена переменным, созданным в ходе выполнения программы? Что-то вроде: string str; ...

Изменение свойств компонентов в ходе выполнения программы
Здравствуйте! Проблема в следующем. Есть собственный WPF-контрол. В нем свойство Property1 и Label примерно так: public double...

как создать компонент в ходе выполнения программы
собственно,вопрос:как создать компонент в ходе выполнения программы? то есть ,например,нужно при нажатии на кнопку,создать компонент...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
PostgreSQL в Kubernetes: Подготовка кластера и настройка
Mr. Docker 20.03.2025
Когда доходит до контейнеризации баз данных и особенно таких требовательных к ресурсам системах как PostgreSQL, многие команды до сих пор колеблются, прежде чем перенести их в контейнерную. . .
C++26: Индексирование пакетов и метапрограммиро­вание
bytestream 20.03.2025
Эволюция C++ продолжается стремительными темпами – каждый новый стандарт приносит функциональность, о которой мы мечтали годами. Звучит слишком громко? Если вы когда-либо боролись с вариадическими. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru