source: mmcs/mainwindow.H @ dfddb27

Last change on this file since dfddb27 was dfddb27, checked in by rboet <rboet@…>, 9 years ago

agregado menú de ayuda

  • Property mode set to 100644
File size: 10.9 KB
Line 
1#ifndef MAINWINDOW_H
2#define MAINWINDOW_H
3
4#include <QtGui>
5
6#include <formloadmatrix.H>
7#include <formviewmatrix.H>
8#include <formvariablesexogenas.h>
9#include <formexportmatrix.h>
10#include <formencadenamientos.h>
11#include <ui_formcompararresultados.h>
12#include <formcompararresultados.h>
13#include <ui_formcompararmnc.h>
14#include <formcompararmnc.h>
15#include "ui_formincidenciai.h"
16#include <formincidenciai.h>
17#include <formpreciosnohomogeneos.h>
18
19#include <sstream>
20#include <stackwidget.H>
21#include <stackvariablesexogenas.h>
22#include <stackencadenamientos.h>
23#include <stackpreciosnohomogeneos.h>
24
25#include <QTabWidget>
26
27#include <QMap>
28#include <QVector>
29
30#include <Eigen>
31
32
33class MainWindow : public QMainWindow
34{
35    Q_OBJECT
36
37    QMenu menuFile;
38    QMenu menuTools;
39    QMenu menuViews;
40    QMenu menuHelp;
41
42    QMenu CoeficientesTecnicos;
43    QMenu Encadenamientos;
44
45    QMenu Modelos;
46    QMenu PHClasico;
47    QMenu PHClasicoIncidencia;
48    QMenu PHNoClasico;
49    QMenu PHNoClasicoIncidencia;
50    QMenu PreciosNH;
51    QMenu PreciosNHIncidencia;
52
53    QAction actionLoadMatrix;
54    QAction actionExportMatrix;
55    QAction actionQuit;
56    QAction actionNewProject;
57
58    QAction actionCH;
59    QAction actionCV;
60    QAction actionVariableExogena;
61
62    QAction actionEncadenamiento;
63    QAction actionClasificarCuentas;
64
65    QAction actionModeloClasico;
66    QAction actionCompararResultados;
67    QAction actionModeloNoClasico;
68    QAction actionCompararResultadosMNC;
69
70    QAction actionPHClasicoIncidencia100;
71    QAction actionPHCIncidenciaCuenta;
72    QAction actionPHCIncidenciaComponente;
73
74    QAction actionPHNoClasicoIncidencia100;
75    QAction actionPHNCIncidenciaCuenta;
76    QAction actionPHNCIncidenciaComponente;
77
78    QAction actionPNHIncidencia100;
79    QAction actionPNHIncidenciaCuenta;
80    QAction actionPNHIncidenciaComponente;
81
82    QAction actionSeleccionarTabla;
83
84    QAction actionManual;
85    QAction actionAcercaDe;
86
87    QTableWidget * tableWidget;
88    QTabWidget * tabWidget;
89    QMap<QString,QStringList> diccCuentasExogenas;
90    QMap<int,QVector<QString> > diccCuentasEndogenas;
91    QMap<int,QVector<QString> > espacioCuentasExogenas;
92    QMap<int, QMap<QString,QStringList> > diccCuentasComponentes;
93    QMap<int, QMap<QString,QStringList> > diccCuentasEncadenamientos;
94    QMap<QString,double> totalCuentas;
95
96    QStringList ComponentesEndogenos;
97
98    QTableWidget *MatrizExgEnd;
99
100    stackVariablesExogenas *stackVE;
101    stackEncadenamientos *stackEncadenamiento;
102    StackPreciosNoHomogeneos *stackPNH;
103
104    Eigen::MatrixXd MatrixMa;
105    Eigen::MatrixXd MatrixMb;
106    Eigen::MatrixXd MatrizMat;
107    Eigen::MatrixXd MatrizMbt;
108
109
110    QString csvFilePath;
111    char csvSeparator;
112    int numAccounts;
113    int matrixSize;
114    int precission;
115    double  matrix[100][100];
116
117    QString componentePNH;
118
119    double MatrizEndogenaEndogena[200][200];
120
121    int opcionCuentaExogena;
122    int opcionVentanaExogena;
123    int opcionExportarMatriz;
124    int opcionEncadenamientos;
125    int opcionCuentaEncadenamientos;
126    int opcionMa;
127    int opcionMb;
128    int opcionFormCompararResultados;
129    int opcionFormCompararResultadosMNC;
130    int opcionMAT;
131    int opcionMBT;
132    int opcionPNHT;
133    int opcionFormPNH;
134
135    QVector<double> subtotalEnd;
136    QVector<double> subtotalExog;
137    QVector<double> subtotalExogEnd;
138    QVector<double> Vpond;
139
140    int cantidadSelecciones;
141    int cantidadEncadenamientos;
142    int cantidadEscenarios;
143    int cantidadResultados;
144    int cantidadMNC;//Cantidad de Modelos No Clasicos
145    int cantidadResultadosMNC;
146    //Cantidad de resultados de incidencia en modelo de precios homogéneos clásico
147    int cantidadPHCindidenciaiCuenta;
148    int cantidadPHCindidenciaiComponente;
149    //Cantidad de resultados de incidencia en modelo de precios homogéneos no clásico
150    int cantidadPHNCindidenciaiCuenta;
151    int cantidadPHNCindidenciaiComponente;
152    //Cantidad de resultados de incidencia en modelo de precios no homogéneos
153    int cantidadPNHincidencia100;
154    int cantidadPNHincidenciaiCuenta;
155    int cantidadPNHincidenciaiComponente;
156
157    FormLoadMatrix * formLoadMatrix;
158    FormViewMatrix * formViewMatrix;
159    FormVariablesExogenas * formVariablesExogenas;
160    FormExportMatrix * formExportMatriz;
161    FormEncadenamientos * formEncadenamientos;
162    FormCompararResultados *formCompararResultados;
163    FormCompararMNC *formCompararMNC;
164    FormIncidenciaI *FI;
165    FormPreciosNoHomogeneos * formPreciosNoHomogeneos;
166
167    void initGUI();
168
169    void createCentralWidget();
170    void createMatrixCentralWidget();
171
172    void createMenuBar();
173    void matricesMenuBar();
174    void populateTable(QTableWidget *);
175
176    void CalcularTotales(QTableWidget *, int inicio, bool &);
177    bool comprobarNombreCuenta(QString, int indice);
178    void loadMatrizExogena();
179    void clonarTabla(QTableWidget *,QTableWidget *, int cantidad);
180    void noEditColZero(QTableWidget *);
181    void setAccountTitle(QTableWidget *);
182    void insertremoveRowCol(QTableWidget *, int rowcol, bool opcion);
183    void crearDiccionario(QTableWidget *, bool endogena=true);
184    QStringList obtenerCuentasEndogenas(QTableWidget *,QStringList);
185    QStringList obtenerCuentasExogenas(QTableWidget *,QStringList );
186    void spanEndogenaCell(QTableWidget *, int inicio, int celda, bool endex=true);
187    void spanExogenaCell(QTableWidget *,int celda);
188    void tableItem(QTableWidget *, int inicio, int fin, QString texto);
189
190    QList<QString> llenarLista(QList<QString>, QTableWidget *, int valor, int opcion);
191    void insertRowExogena(QList<QString>, QTableWidget *, int opcion);
192    void setEndogenaExogenaCell(QTableWidget *, int inicioExogena, int elementos,bool condicion);
193    void CalcularAn(QTableWidget *, QTableWidget *, QTableWidget *, int count, bool endogena = false);
194    QString Separador(QTableWidgetItem *,bool quitar);
195    void ItemsNoEditable(QTableWidget *, int inicio, int fin, int col=0);
196    void CellStyle(QTableWidgetItem *);
197    void CellStyleComponente(QTableWidgetItem *);
198    void CellStyleExEn(QTableWidgetItem *);
199    void EndogenaAn();
200
201    void calcularTotalCuentas(QTableWidget *);
202    void estimarVectorPonderacion();
203
204    void obtenerCuentaComponentes();
205    void crearTablaVaciaEncadenamiento(int filas, QTableWidget *, int columnas=4);
206    void crearMatrizEncadenamiento(QTableWidget *, QTableWidget *);
207    void crearMatrizEncadenamientoEndogena(QTableWidget *, QTableWidget *);
208    void calcularTotalesEncadenamientos(QTableWidget *);
209    void encademientosStyle(QTableWidgetItem *);
210    void cuentacomponentesEncadenamiento(QTableWidget *, int count);
211    void obtenerUiUj(QTableWidget *, QVector<double> &, QVector<double> &);
212    void calcularClasificador(QTableWidget *, QVector<double>, QVector<double>, int init = 2);
213    void agregarPrimeraCelda(QTableWidget *);
214
215    void calcularSubtotal(QTableWidget *,int inicio, int fin,int exogena);
216    void llenarEscenario(QTableWidget *, bool clasico=true);
217    void calcularFinEscenario(QTableWidget *);
218    QVector<double> obtenerResultadoEscenario(QVector<double>);
219    QStringList obtenerNombreResultadoEscenario();
220    void crearTablaComparar(QTableWidget *, QTableWidget *);
221    void cuentacomponentesResultado(QTableWidget *, int count, bool clasico = true);
222
223    void obtenerMatrizExgEnd();
224    void crearMatrizExgEnd(QTableWidget *,QTableWidget *,int elementos,int inicioExogena);
225    void calcularMatrizExgEnd(QTableWidget *);
226    void ctvMatrizExgEnd(QTableWidget *, QTableWidget *);
227    void titlespanMatrizExgEnd(QTableWidget *);
228    void estimarMb(QTableWidget *, QTableWidget *);
229    void calcularSubtotalEndExg();
230    QVector<double> obtenerResultadoEscenarioMNC(QVector<double>);
231    void calcularFinEscenarioMNC(QTableWidget *);
232    QStringList obtenerNombreResultadoEscenarioMNC();
233
234    void crearMatrizEndogena(QTableWidget *);
235    void restarIdentidadAn(QTableWidget *);
236    void titleEndogena(QTableWidget *);
237
238    void calcularMaT();
239    void calcularPHCIncidencia100(QTableWidget *);
240    void calcularPHCIncidenciaI(QTableWidget *, QMap<QString, double>);
241    void calcularPHCIncidenciaIComponente(QTableWidget *,QTableWidget *);
242
243    void calcularMbT();
244    void calcularMb();
245    void calcularPHNCIncidencia100(QTableWidget *);
246    void calcularVectorSend(QString componente, QVector<double> &);
247    void multiplicarMatricesPNH(QTableWidget *, QVector<double>);
248    void calcularPNHIncidencia100(QTableWidget *, Eigen::MatrixXd Diagonal);
249    void crearFormularioPNH();
250    QStringList obtenerCuentas();
251
252    void titleSeleccionar(QTableWidget *);
253
254    bool ComprobarCuentas();
255    int ObtenerIndice(QString );
256
257    QStringList ObtenerNombreCuenta(int contador);
258    QList<int> ObtenerLimitesCuenta(int contador,int opccion);
259    QStringList ObtenerComponentes(QTableWidget *);
260    void CrearTablaVacia(int contador,QTableWidget *);
261
262protected:
263    void closeEvent(QCloseEvent *);
264
265private slots:
266    void slotNuevoProyecto();
267    void slotLoadMatrix();
268    void slotExportMatrix();
269    void slotFormLoadMatrixAccepted(const QString &, int, int);
270    void slotFormLoadMatrixClosed();
271
272    void AgregarCuenta();
273    void RestaurarCeldas();
274    void FinalizarCuentas();
275    void ModificarCuenta();
276    void slotCoeficienteHorizontal();
277    void slotCoeficienteVertical();
278    void slotAccChange();
279
280    void slotVariableExogena();
281    void slotCloseExogena();
282    void slotAgregarExogena();
283    void slotFinalizarExogena();
284    void slotDeshacerExogena();
285
286    void slotMa();
287
288    void slotEncadenamientos();
289    void slotCloseEncadenamiento();
290    void slotAgregarEncadenamiento();
291    void slotVerEncadenamiento();
292    void slotClasificarCuentas();
293
294    void slotCloseExport();
295    void slotSaveExport();
296    void slotSearchExport();
297
298    void slotModeloClasico();
299    void calcularEscenario(bool clasico = true);
300    void finalizarEscenario();
301
302    void slotModeloNoClasico();
303    void calcularEscenarioNC();
304    void finalizarEscenarioNC();
305
306    void slotCompararResultadosMNC();
307    void slotVerResultadoMNC();
308
309    void slotPHCIncidencia100();
310    void slotPHCIncidenciaiCuenta();
311    void slotCalcularPHCIncidenciaiCuenta();
312    void slotPHCIncidenciaiComponente();
313    void slotCalcularPHCIncidenciaiComponente();
314
315    void slotCompararResultados();
316    void slotVerResultado();
317
318    void slotPHNCIncidencia100();
319    void slotPHNCIncidenciaiCuenta();
320    void slotCalcularPHNCIncidenciaiCuenta();
321    void slotPHNCIncidenciaiComponente();
322    void slotCalcularPHNCIncidenciaiComponente();
323
324    void slotPNHIncudencia100();
325    void slotCloseformPNH();
326    void slotSelectPNH();
327    void slotPNHIncidenciaiCuenta();
328    void slotPNHIncidenciaiComponente();
329    void slotSelectPNHi();
330    void slotCalcularPNHIncidenciaiCuenta();
331    void slotSelectPNHic();
332    void slotCalcularPNHIncidenciaiComponente();
333
334    void slotSeleccionarTabla();
335
336    void abrirManual();
337    void acercaDe();
338
339public:
340    MainWindow();
341    std::vector<std::string> csv_read_row(std::string , char);
342    std::vector<std::string> csv_read_row(std::istream &, char);
343    QString numberFormat(double &);
344
345    int contarElementosMap(QMap<QString, QStringList> diccionario);
346};
347
348#endif // MAINWINDOW_H
Note: See TracBrowser for help on using the repository browser.