Descargar

Derivación por diferencias divididas y por fórmulas de alta precisión en Visual Basic 2005 (página 4)

Enviado por jaimemontoya


Partes: 1, 2, 3, 4, 5, 6, 7, 8, 9

.set_TextMatrix(1, 2, Math.Round(Val(tablas5(1, 2)), 10)) 'Imprime el valor de "f(a)" (con 10 decimales).

.set_TextMatrix(2, 2, Math.Round(Val(tablas5(2, 2)), 10)) 'Imprime el valor de "f(a+h)" (con 10 decimales).

.set_TextMatrix(3, 2, Math.Round(Val(tablas5(3, 2)), 10)) 'Imprime el valor de "f(a+2h)" (con 10 decimales).

.set_TextMatrix(4, 2, Math.Round(Val(tablas5(4, 2)), 10)) 'Imprime el valor de "f(a+3h)" (con 10 decimales).

.set_TextMatrix(5, 2, Math.Round(Val(tablas5(5, 2)), 10)) 'Imprime el valor de "f(a+4h)" (con 10 decimales).

.set_TextMatrix(6, 2, Math.Round(Val(tablas5(6, 2)), 10)) 'Imprime el valor de "f(a+5h)" (con 10 decimales).

.set_TextMatrix(2, 3, Math.Round(Val(tablas5(2, 3)), 10)) 'Imprime el valor de "(f(a+h)-f(a))/h"="f'(a)" (con 10 decimales).

.set_TextMatrix(3, 3, Math.Round(Val(tablas5(3, 3)), 10)) 'Imprime el valor de "(f(a+2h)-f(a+h))/h"="f'(a+h)" (con 10 decimales).

.set_TextMatrix(4, 3, Math.Round(Val(tablas5(4, 3)), 10)) 'Imprime el valor de "(f(a+3h)-f(a+2h))/h"="f'(a+2h)" (con 10 decimales).

.set_TextMatrix(5, 3, Math.Round(Val(tablas5(5, 3)), 10)) 'Imprime el valor de "(f(a+4h)-f(a+3h))/h"="f'(a+3h)" (con 10 decimales).

.set_TextMatrix(6, 3, Math.Round(Val(tablas5(6, 3)), 10)) 'Imprime el valor de "(f(a+5h)-f(a+4h))/h"="f'(a+4h)" (con 10 decimales).

.set_TextMatrix(3, 4, Math.Round(Val(tablas5(3, 4)), 10)) 'Imprime el valor de "(f'(a+h)-f'(a))/h"="f''(a)" (con 10 decimales).

.set_TextMatrix(4, 4, Math.Round(Val(tablas5(4, 4)), 10)) 'Imprime el valor de "(f'(a+2h)-f'(a+h))/h"="f''(a+h)" (con 10 decimales).

.set_TextMatrix(5, 4, Math.Round(Val(tablas5(5, 4)), 10)) 'Imprime el valor de "(f'(a+3h)-f'(a+2h))/h"="f''(a+2h)" (con 10 decimales).

.set_TextMatrix(6, 4, Math.Round(Val(tablas5(6, 4)), 10)) 'Imprime el valor de "(f'(a+4h)-f'(a+3h))/h"="f''(a+3h)" (con 10 decimales).

.set_TextMatrix(4, 5, Math.Round(Val(tablas5(4, 5)), 10)) 'Imprime el valor de "(f''(a+h)-f''(a))/h"="f'''(a)" (con 10 decimales).

.set_TextMatrix(5, 5, Math.Round(Val(tablas5(5, 5)), 10)) 'Imprime el valor de "(f''(a+2h)-f''(a+h))/h"="f'''(a+h)" (con 10 decimales).

.set_TextMatrix(6, 5, Math.Round(Val(tablas5(6, 5)), 10)) 'Imprime el valor de "(f''(a+3h)-f''(a+2h))/h"="f'''(a+2h)" (con 10 decimales).

.set_TextMatrix(5, 6, Math.Round(Val(tablas5(5, 6)), 10)) 'Imprime el valor de "(f'''(a+h)-f'''(a))/h"="f''''(a)" (con 10 decimales).

.set_TextMatrix(6, 6, Math.Round(Val(tablas5(6, 6)), 10)) 'Imprime el valor de "(f'''(a+2h)-f'''(a+h))/h"="'f''''(a+h)" (con 10 decimales).

.set_TextMatrix(6, 7, Math.Round(Val(tablas5(6, 7)), 10)) 'Imprime el valor de "(f''''(a+h)-f''''(a))/h"="f'''''(a)" (con 10 decimales).

End With

TextBox5.Text = "quinta" 'Imprime el orden de la derivada.

TextBox6.Text = tablas5(6, 7) 'Muestra la respuesta en el TextBox6.

TextBox7.Text = TextBox3.Text 'Imprime el error utilizado.

End If

End If

'CASO 6. PRIMERA DERIVADA POR TABLAS DE DIFERENCIAS DIVIDIDAS HACIA ATRÁS.

If (ComboBox1.SelectedItem = "Tablas de Diferencias Divididas Hacia Atrás") And (ComboBox2.SelectedItem = "1ra. derivada") Then

Dim i, j As Integer '"i" significará "fila" y "j" significará columna, de modo que se trabajará con (i,j)=(fila,columna)

'Establece cuántas filas y columnas tendrá el Grid.

AxMSFlexGrid1.Rows = 3 'Establece 3 filas.

AxMSFlexGrid1.Cols = 4 'Establece 4 columnas.

'Se crea una nueva instancia de la clase Evaluador.

Dim mEval As New Evaluador()

'Se crea una variable tipo string y se le asigna la expresión que se quiere evaluar.

Dim mExpresion As String = TextBox1.Text ' = "X".

'Se crea un objeto StringCollection y se le agregan los parámetros de entrada que usará el método eval.

Dim mParameters As New StringCollection()

mParameters.Add("ByVal X as Double")

'Las funciones a utilizar pertenece al espacio de nombres System.Math.

'se hace necesario entonces, crear un objeto StringCollection y agregar

'el namespace System.Math.

Dim mNameSpaces As New StringCollection()

mNameSpaces.Add("System.Math")

'Se invoca el método PrecompilarFunción y se verifica si se generó correctamente el assembly.

If mEval.PrecompilarAssembly(mExpresion, mParameters, mNameSpaces) Then

'Si el assembly se generó correctamente, se crea un array con los valores de los parametros a evaluar.

'Se invoca el método Evaluar y se asignan los resultados correspondientes.

'Se limpian todas las celdas para que no queden impresos resultados de procesos anteriores.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

For fila As Integer = 0 To .Rows – 1

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 0 To .Cols – 1

.set_TextMatrix(fila, columna, "") 'Por estar dentro de los For anidados, con esto se ponen valores String Empty en todas las celdas, de modo que no aparezca nada y queden todas las celdas limpias y sin resultados de cálculos hechos anteriormente.

Next

End With

Next

End With

'Se comienzan a hacer los cálculos.

tablas6(1, 1) = Val(TextBox2.Text) – Val(TextBox3.Text) 'Almacena "a-h".

tablas6(2, 1) = Val(TextBox2.Text) 'Almacena "a".

tablas6(1, 2) = mEval.Evaluar(Val(tablas6(1, 1))) 'Almacena "f(a-h)".

tablas6(2, 2) = mEval.Evaluar(Val(tablas6(2, 1))) 'Almacena "f(a)".

tablas6(1, 3) = (Val(tablas6(2, 2)) – Val(tablas6(1, 2))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-h))/h"="f'(a)".

'Para indicar que se realizarán operaciones con el objeto AxMSFlexGrid1

'sin necesidad de escribir su nombre.

'De aquí en adelante vienen las impresiones de los valores en las celdas correspondientes.

AxMSFlexGrid1.ForeColor = Color.Blue 'Cambia el color de letra de todas las celdas a azul.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

.AllowUserResizing = MSFlexGridLib.AllowUserResizeSettings.flexResizeBoth 'Determina que el usuario puede modificar el ancho de columna en tiempo de ejecución.

'Para ponerle color amarillo suave de fondo a todas las celdas.

Dim Color1 As Color = Color.LightGoldenrodYellow 'Amarillo suave.

For fila As Integer = 1 To .Rows – 1 'Para no involucrar la primera fila, se comienza de 1 y no de 0.

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 1 To .Cols – 1 'Para no involucrar la primera columna, se comienza de 1 y no de 0.

.Col = columna

.CellBackColor = Color1 'Por estar dentro del For, cambia el color de fondo de todas las celdas a LighYellow (amarillo suave), pues la variable Color1 fue inicializada anteriormente con el valor de "Color.LightGoldenrodYellow".

.CellForeColor = Color.Blue 'Por estar dentro del For, cambia el color de letra de todas las celdas a azul.

.set_ColWidth(columna, 1300) 'Por estar deltro del For, le da un ancho de 1300 a cada columna.

Next

End With

Next

'Establece la alineación del contenido de la columna 0

.set_ColAlignment(0, MSFlexGridLib.AlignmentSettings.flexAlignCenterCenter)

'Se le ponen los respectivos títulos a cada fila.

'La sintaxis dentro del paréntesis es: (fila, columna, valor).

.set_TextMatrix(1, 0, "a-h")

.set_TextMatrix(2, 0, "a")

'Se le ponen los respectivos títulos a cada columna.

.set_TextMatrix(0, 1, "x")

.set_TextMatrix(0, 2, "f(x)")

.set_TextMatrix(0, 3, "f'(x)")

'Impresiones de resultados.

.set_TextMatrix(1, 1, Math.Round(Val(tablas6(1, 1)), 10)) 'Imprime el valor de "a-h" (con 10 decimales).

.set_TextMatrix(2, 1, Math.Round(Val(tablas6(2, 1)), 10)) 'Imprime el valor de "a" (con 10 decimales).

.set_TextMatrix(1, 2, Math.Round(Val(tablas6(1, 2)), 10)) 'Imprime el valor de "f(a-h)" (con 10 decimales).

.set_TextMatrix(2, 2, Math.Round(Val(tablas6(2, 2)), 10)) 'Imprime el valor de "f(a)" (con 10 decimales).

.set_TextMatrix(1, 3, Math.Round(Val(tablas6(1, 3)), 10)) 'Imprime el valor de "(f(a)-f(a-h))/h"="f'(a)" (con 10 decimales).

End With

TextBox5.Text = "primera" 'Imprime el orden de la derivada.

TextBox6.Text = tablas6(1, 3) 'Muestra la respuesta en el TextBox6.

TextBox7.Text = TextBox3.Text 'Imprime el error utilizado.

End If

End If

'CASO 7. SEGUNDA DERIVADA POR TABLAS DE DIFERENCIAS DIVIDIDAS HACIA ATRÁS.

If (ComboBox1.SelectedItem = "Tablas de Diferencias Divididas Hacia Atrás") And (ComboBox2.SelectedItem = "2da. derivada") Then

Dim i, j As Integer '"i" significará "fila" y "j" significará columna, de modo que se trabajará con (i,j)=(fila,columna)

'Establece cuántas filas y columnas tendrá el Grid.

AxMSFlexGrid1.Rows = 4 'Establece 4 filas.

AxMSFlexGrid1.Cols = 5 'Establece 5 columnas.

'Se crea una nueva instancia de la clase Evaluador.

Dim mEval As New Evaluador()

'Se crea una variable tipo string y se le asigna la expresión que se quiere evaluar.

Dim mExpresion As String = TextBox1.Text ' = "X".

'Se crea un objeto StringCollection y se le agregan los parámetros de entrada que usará el método eval.

Dim mParameters As New StringCollection()

mParameters.Add("ByVal X as Double")

'Las funciones a utilizar pertenece al espacio de nombres System.Math.

'se hace necesario entonces, crear un objeto StringCollection y agregar

'el namespace System.Math.

Dim mNameSpaces As New StringCollection()

mNameSpaces.Add("System.Math")

'Se invoca el método PrecompilarFunción y se verifica si se generó correctamente el assembly.

If mEval.PrecompilarAssembly(mExpresion, mParameters, mNameSpaces) Then

'Si el assembly se generó correctamente, se crea un array con los valores de los parametros a evaluar.

'Se invoca el método Evaluar y se asignan los resultados correspondientes.

'Se limpian todas las celdas para que no queden impresos resultados de procesos anteriores.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

For fila As Integer = 0 To .Rows – 1

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 0 To .Cols – 1

.set_TextMatrix(fila, columna, "") 'Por estar dentro de los For anidados, con esto se ponen valores String Empty en todas las celdas, de modo que no aparezca nada y queden todas las celdas limpias y sin resultados de cálculos hechos anteriormente.

Next

End With

Next

End With

'Se comienzan a hacer los cálculos.

tablas7(1, 1) = Val(TextBox2.Text) – (2 * (Val(TextBox3.Text))) 'Almacena "a-2h".

tablas7(2, 1) = Val(TextBox2.Text) – Val(TextBox3.Text) 'Almacena "a-h".

tablas7(3, 1) = Val(TextBox2.Text) 'Almacena "a".

tablas7(1, 2) = mEval.Evaluar(Val(tablas7(1, 1))) 'Almacena "f(a-2h)".

tablas7(2, 2) = mEval.Evaluar(Val(tablas7(2, 1))) 'Almacena "f(a-h)".

tablas7(3, 2) = mEval.Evaluar(Val(tablas7(3, 1))) 'Almacena "f(a)".

tablas7(1, 3) = (Val(tablas7(2, 2)) – Val(tablas7(1, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-h)-f(a-2h))/h"="f'(a-2h)".

tablas7(2, 3) = (Val(tablas7(3, 2)) – Val(tablas7(2, 2))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-h))/h"=f'(a)".

tablas7(1, 4) = (Val(tablas7(2, 3)) – Val(tablas7(1, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a)-f'(a-h))/h"=f''(a)".

'Para indicar que se realizarán operaciones con el objeto AxMSFlexGrid1

'sin necesidad de escribir su nombre.

'De aquí en adelante vienen las impresiones de los valores en las celdas correspondientes.

AxMSFlexGrid1.ForeColor = Color.Blue 'Cambia el color de letra de todas las celdas a azul.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

.AllowUserResizing = MSFlexGridLib.AllowUserResizeSettings.flexResizeBoth 'Determina que el usuario puede modificar el ancho de columna en tiempo de ejecución.

'Para ponerle color amarillo suave de fondo a todas las celdas.

Dim Color1 As Color = Color.LightGoldenrodYellow 'Amarillo suave.

For fila As Integer = 1 To .Rows – 1 'Para no involucrar la primera fila, se comienza de 1 y no de 0.

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 1 To .Cols – 1 'Para no involucrar la primera columna, se comienza de 1 y no de 0.

.Col = columna

.CellBackColor = Color1 'Por estar dentro del For, cambia el color de fondo de todas las celdas a LighYellow (amarillo suave), pues la variable Color1 fue inicializada anteriormente con el valor de "Color.LightGoldenrodYellow".

.CellForeColor = Color.Blue 'Por estar dentro del For, cambia el color de letra de todas las celdas a azul.

.set_ColWidth(columna, 1300) 'Por estar deltro del For, le da un ancho de 1300 a cada columna.

Next

End With

Next

'Establece la alineación del contenido de la columna 0

.set_ColAlignment(0, MSFlexGridLib.AlignmentSettings.flexAlignCenterCenter)

'Se le ponen los respectivos títulos a cada fila.

'La sintaxis dentro del paréntesis es: (fila, columna, valor).

.set_TextMatrix(1, 0, "a-2h")

.set_TextMatrix(2, 0, "a-h")

.set_TextMatrix(3, 0, "a")

'Se le ponen los respectivos títulos a cada columna.

.set_TextMatrix(0, 1, "x")

.set_TextMatrix(0, 2, "f(x)")

.set_TextMatrix(0, 3, "f'(x)")

.set_TextMatrix(0, 4, "f''(x)")

'Impresiones de resultados.

.set_TextMatrix(1, 1, Math.Round(Val(tablas7(1, 1)), 10)) 'Imprime el valor de "a-2h" (con 10 decimales).

.set_TextMatrix(2, 1, Math.Round(Val(tablas7(2, 1)), 10)) 'Imprime el valor de "a-h" (con 10 decimales).

.set_TextMatrix(3, 1, Math.Round(Val(tablas7(3, 1)), 10)) 'Imprime el valor de "a" (con 10 decimales).

.set_TextMatrix(1, 2, Math.Round(Val(tablas7(1, 2)), 10)) 'Imprime el valor de "f(a-2h)" (con 10 decimales).

.set_TextMatrix(2, 2, Math.Round(Val(tablas7(2, 2)), 10)) 'Imprime el valor de "f(a-h)" (con 10 decimales).

.set_TextMatrix(3, 2, Math.Round(Val(tablas7(3, 2)), 10)) 'Imprime el valor de "f(a)" (con 10 decimales).

.set_TextMatrix(1, 3, Math.Round(Val(tablas7(1, 3)), 10)) 'Imprime el valor de "(f(a-h)-f(a-2h))/h"="f'(a-2h)" (con 10 decimales).

.set_TextMatrix(2, 3, Math.Round(Val(tablas7(2, 3)), 10)) 'Imprime el valor de "(f(a)-f(a-h))/h"=f'(a)" (con 10 decimales).

.set_TextMatrix(1, 4, Math.Round(Val(tablas7(1, 4)), 10)) 'Imprime el valor de "(f'(a)-f'(a-h))/h"=f''(a)" (con 10 decimales).

End With

TextBox5.Text = "segunda" 'Imprime el orden de la derivada.

TextBox6.Text = tablas7(1, 4) 'Muestra la respuesta en el TextBox6.

TextBox7.Text = TextBox3.Text 'Imprime el error utilizado.

End If

End If

'CASO 8. TERCERA DERIVADA POR TABLAS DE DIFERENCIAS DIVIDIDAS HACIA ATRÁS.

If (ComboBox1.SelectedItem = "Tablas de Diferencias Divididas Hacia Atrás") And (ComboBox2.SelectedItem = "3ra. derivada") Then

Dim i, j As Integer '"i" significará "fila" y "j" significará columna, de modo que se trabajará con (i,j)=(fila,columna)

'Establece cuántas filas y columnas tendrá el Grid.

AxMSFlexGrid1.Rows = 5 'Establece 5 filas.

AxMSFlexGrid1.Cols = 6 'Establece 6 columnas.

'Se crea una nueva instancia de la clase Evaluador.

Dim mEval As New Evaluador()

'Se crea una variable tipo string y se le asigna la expresión que se quiere evaluar.

Dim mExpresion As String = TextBox1.Text ' = "X".

'Se crea un objeto StringCollection y se le agregan los parámetros de entrada que usará el método eval.

Dim mParameters As New StringCollection()

mParameters.Add("ByVal X as Double")

'Las funciones a utilizar pertenece al espacio de nombres System.Math.

'se hace necesario entonces, crear un objeto StringCollection y agregar

'el namespace System.Math.

Dim mNameSpaces As New StringCollection()

mNameSpaces.Add("System.Math")

'Se invoca el método PrecompilarFunción y se verifica si se generó correctamente el assembly.

If mEval.PrecompilarAssembly(mExpresion, mParameters, mNameSpaces) Then

'Si el assembly se generó correctamente, se crea un array con los valores de los parametros a evaluar.

'Se invoca el método Evaluar y se asignan los resultados correspondientes.

'Se limpian todas las celdas para que no queden impresos resultados de procesos anteriores.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

For fila As Integer = 0 To .Rows – 1

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 0 To .Cols – 1

.set_TextMatrix(fila, columna, "") 'Por estar dentro de los For anidados, con esto se ponen valores String Empty en todas las celdas, de modo que no aparezca nada y queden todas las celdas limpias y sin resultados de cálculos hechos anteriormente.

Next

End With

Next

End With

'Se comienzan a hacer los cálculos.

tablas8(1, 1) = Val(TextBox2.Text) – (3 * (Val(TextBox3.Text))) 'Almacena "a-3h".

tablas8(2, 1) = Val(TextBox2.Text) – (2 * (Val(TextBox3.Text))) 'Almacena "a-2h".

tablas8(3, 1) = Val(TextBox2.Text) – Val(TextBox3.Text) 'Almacena "a-h".

tablas8(4, 1) = Val(TextBox2.Text) 'Almacena "a".

tablas8(1, 2) = mEval.Evaluar(Val(tablas8(1, 1))) 'Almacena "f(a-3h)".

tablas8(2, 2) = mEval.Evaluar(Val(tablas8(2, 1))) 'Almacena "f(a-2h)".

tablas8(3, 2) = mEval.Evaluar(Val(tablas8(3, 1))) 'Almacena "f(a-h)".

tablas8(4, 2) = mEval.Evaluar(Val(tablas8(4, 1))) 'Almacena "f(a)".

tablas8(1, 3) = (Val(tablas8(2, 2)) – Val(tablas8(1, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-2h)-f(a-3h)/h"="f'(a-2h)".

tablas8(2, 3) = (Val(tablas8(3, 2)) – Val(tablas8(2, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-h)-f(a-2h)/h"="f'(a-h)".

tablas8(3, 3) = (Val(tablas8(4, 2)) – Val(tablas8(3, 2))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-h)/h"="f'(a)".

tablas8(1, 4) = (Val(tablas8(2, 3)) – Val(tablas8(1, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-h)-f'(a-2h)/h"="f''(a-h)".

tablas8(2, 4) = (Val(tablas8(3, 3)) – Val(tablas8(2, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a)-f'(a-h)/h"="f''(a)".

tablas8(1, 5) = (Val(tablas8(2, 4)) – Val(tablas8(1, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a)-f''(a-h)/h"="f'''(a)".

'Para indicar que se realizarán operaciones con el objeto AxMSFlexGrid1

'sin necesidad de escribir su nombre.

'De aquí en adelante vienen las impresiones de los valores en las celdas correspondientes.

AxMSFlexGrid1.ForeColor = Color.Blue 'Cambia el color de letra de todas las celdas a azul.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(1, 500) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

.AllowUserResizing = MSFlexGridLib.AllowUserResizeSettings.flexResizeBoth 'Determina que el usuario puede modificar el ancho de columna en tiempo de ejecución.

'Para ponerle color amarillo suave de fondo a todas las celdas.

Dim Color1 As Color = Color.LightGoldenrodYellow 'Amarillo suave.

For fila As Integer = 1 To .Rows – 1 'Para no involucrar la primera fila, se comienza de 1 y no de 0.

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 1 To .Cols – 1 'Para no involucrar la primera columna, se comienza de 1 y no de 0.

.Col = columna

.CellBackColor = Color1 'Por estar dentro del For, cambia el color de fondo de todas las celdas a LighYellow (amarillo suave), pues la variable Color1 fue inicializada anteriormente con el valor de "Color.LightGoldenrodYellow".

.CellForeColor = Color.Blue 'Por estar dentro del For, cambia el color de letra de todas las celdas a azul.

.set_ColWidth(columna, 1300) 'Por estar deltro del For, le da un ancho de 1300 a cada columna.

Next

End With

Next

'Establece la alineación del contenido de la columna 0

.set_ColAlignment(0, MSFlexGridLib.AlignmentSettings.flexAlignCenterCenter)

'Se le ponen los respectivos títulos a cada fila.

'La sintaxis dentro del paréntesis es: (fila, columna, valor).

.set_TextMatrix(1, 0, "a-3")

.set_TextMatrix(2, 0, "a-2h")

.set_TextMatrix(3, 0, "a-h")

.set_TextMatrix(4, 0, "a")

'Se le ponen los respectivos títulos a cada columna.

.set_TextMatrix(0, 1, "x")

.set_TextMatrix(0, 2, "f(x)")

.set_TextMatrix(0, 3, "f'(x)")

.set_TextMatrix(0, 4, "f''(x)")

.set_TextMatrix(0, 5, "f'''(x)")

'Impresiones de resultados.

.set_TextMatrix(1, 1, Math.Round(Val(tablas8(1, 1)), 10)) 'Imprime el valor de "a-3h" (con 10 decimales).

.set_TextMatrix(2, 1, Math.Round(Val(tablas8(2, 1)), 10)) 'Imprime el valor de "a-2h" (con 10 decimales).

.set_TextMatrix(3, 1, Math.Round(Val(tablas8(3, 1)), 10)) 'Imprime el valor de "a-h" (con 10 decimales).

.set_TextMatrix(4, 1, Math.Round(Val(tablas8(4, 1)), 10)) 'Imprime el valor de "a" (con 10 decimales).

.set_TextMatrix(1, 2, Math.Round(Val(tablas8(1, 2)), 10)) 'Imprime el valor de "f(a-3h)" (con 10 decimales).

.set_TextMatrix(2, 2, Math.Round(Val(tablas8(2, 2)), 10)) 'Imprime el valor de "f(a-2h)" (con 10 decimales).

.set_TextMatrix(3, 2, Math.Round(Val(tablas8(3, 2)), 10)) 'Imprime el valor de "f(a-h)" (con 10 decimales).

.set_TextMatrix(4, 2, Math.Round(Val(tablas8(4, 2)), 10)) 'Imprime el valor de "f(a)" (con 10 decimales).

.set_TextMatrix(1, 3, Math.Round(Val(tablas8(1, 3)), 10)) 'Imprime el valor de "(f(a-2h)-f(a-3h)/h"="f'(a-2h)" (con 10 decimales).

.set_TextMatrix(2, 3, Math.Round(Val(tablas8(2, 3)), 10)) 'Imprime el valor de "(f(a-h)-f(a-2h)/h"="f'(a-h)" (con 10 decimales).

.set_TextMatrix(3, 3, Math.Round(Val(tablas8(3, 3)), 10)) 'Imprime el valor de "(f(a)-f(a-h)/h"="f'(a)" (con 10 decimales).

.set_TextMatrix(1, 4, Math.Round(Val(tablas8(1, 4)), 10)) 'Imprime el valor de "(f'(a-h)-f'(a-2h)/h"="f''(a-h)" (con 10 decimales).

.set_TextMatrix(2, 4, Math.Round(Val(tablas8(2, 4)), 10)) 'Imprime el valor de "(f'(a)-f'(a-h)/h"="f''(a)" (con 10 decimales).

.set_TextMatrix(1, 5, Math.Round(Val(tablas8(1, 5)), 10)) 'Imprime el valor de "(f''(a)-f''(a-h)/h"="f'''(a)" (con 10 decimales).

End With

TextBox5.Text = "tercera" 'Imprime el orden de la derivada.

TextBox6.Text = tablas8(1, 5) 'Muestra la respuesta en el TextBox6.

TextBox7.Text = TextBox3.Text 'Imprime el error utilizado.

End If

End If

'CASO 9. CUARTA DERIVADA POR TABLAS DE DIFERENCIAS DIVIDIDAS HACIA ATRÁS.

If (ComboBox1.SelectedItem = "Tablas de Diferencias Divididas Hacia Atrás") And (ComboBox2.SelectedItem = "4ta. derivada") Then

Dim i, j As Integer '"i" significará "fila" y "j" significará columna, de modo que se trabajará con (i,j)=(fila,columna)

'Establece cuántas filas y columnas tendrá el Grid.

AxMSFlexGrid1.Rows = 6 'Establece 6 filas.

AxMSFlexGrid1.Cols = 7 'Establece 7 columnas.

'Se crea una nueva instancia de la clase Evaluador.

Dim mEval As New Evaluador()

'Se crea una variable tipo string y se le asigna la expresión que se quiere evaluar.

Dim mExpresion As String = TextBox1.Text ' = "X".

'Se crea un objeto StringCollection y se le agregan los parámetros de entrada que usará el método eval.

Dim mParameters As New StringCollection()

mParameters.Add("ByVal X as Double")

'Las funciones a utilizar pertenece al espacio de nombres System.Math.

'se hace necesario entonces, crear un objeto StringCollection y agregar

'el namespace System.Math.

Dim mNameSpaces As New StringCollection()

mNameSpaces.Add("System.Math")

'Se invoca el método PrecompilarFunción y se verifica si se generó correctamente el assembly.

If mEval.PrecompilarAssembly(mExpresion, mParameters, mNameSpaces) Then

'Si el assembly se generó correctamente, se crea un array con los valores de los parametros a evaluar.

'Se invoca el método Evaluar y se asignan los resultados correspondientes.

'Se limpian todas las celdas para que no queden impresos resultados de procesos anteriores.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

For fila As Integer = 0 To .Rows – 1

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 0 To .Cols – 1

.set_TextMatrix(fila, columna, "") 'Por estar dentro de los For anidados, con esto se ponen valores String Empty en todas las celdas, de modo que no aparezca nada y queden todas las celdas limpias y sin resultados de cálculos hechos anteriormente.

Next

End With

Next

End With

'Se comienzan a hacer los cálculos.

tablas9(1, 1) = Val(TextBox2.Text) – (4 * (Val(TextBox3.Text))) 'Almacena "a-4h".

tablas9(2, 1) = Val(TextBox2.Text) – (3 * (Val(TextBox3.Text))) 'Almacena "a-3h".

tablas9(3, 1) = Val(TextBox2.Text) – (2 * (Val(TextBox3.Text))) 'Almacena "a-2h".

tablas9(4, 1) = Val(TextBox2.Text) – Val(TextBox3.Text) 'Almacena "a-h".

tablas9(5, 1) = Val(TextBox2.Text) 'Almacena "a".

tablas9(1, 2) = mEval.Evaluar(Val(tablas9(1, 1))) 'Almacena "f(a-4h)".

tablas9(2, 2) = mEval.Evaluar(Val(tablas9(2, 1))) 'Almacena "f(a-3h)".

tablas9(3, 2) = mEval.Evaluar(Val(tablas9(3, 1))) 'Almacena "f(a-2h)".

tablas9(4, 2) = mEval.Evaluar(Val(tablas9(4, 1))) 'Almacena "f(a-h)".

tablas9(5, 2) = mEval.Evaluar(Val(tablas9(5, 1))) 'Almacena "f(a)".

tablas9(1, 3) = (Val(tablas9(2, 2)) – Val(tablas9(1, 2))) / Val(TextBox3.Text) 'Almacena "(f(a+3h)-f(a-4h))/h"="f'(a-3h)".

tablas9(2, 3) = (Val(tablas9(3, 2)) – Val(tablas9(2, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-2h)-f(a-3h))/h"="f'(a-2h)".

tablas9(3, 3) = (Val(tablas9(4, 2)) – Val(tablas9(3, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-h)-f(a-2h))/h"="f'(a-h)".

tablas9(4, 3) = (Val(tablas9(5, 2)) – Val(tablas9(4, 2))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-2h))/h"="f'(a)".

tablas9(1, 4) = (Val(tablas9(2, 3)) – Val(tablas9(1, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-2h)-f'(a-3h))/h"="f''(a-2h)".

tablas9(2, 4) = (Val(tablas9(3, 3)) – Val(tablas9(2, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-h)-f'(a-2h))/h"="f''(a-h)".

tablas9(3, 4) = (Val(tablas9(4, 3)) – Val(tablas9(3, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a)-f'(a-h))/h"="f''(a)".

tablas9(1, 5) = (Val(tablas9(2, 4)) – Val(tablas9(1, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a-h)-f''(a-2h))/h"="f'''(a-h)".

tablas9(2, 5) = (Val(tablas9(3, 4)) – Val(tablas9(2, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a)-f''(a-h))/h"="f'''(a)".

tablas9(1, 6) = (Val(tablas9(2, 5)) – Val(tablas9(1, 5))) / Val(TextBox3.Text) 'Almacena "(f'''(a)-f'''(a-h))/h"="f''''(a)".

'Para indicar que se realizarán operaciones con el objeto AxMSFlexGrid1

'sin necesidad de escribir su nombre.

'De aquí en adelante vienen las impresiones de los valores en las celdas correspondientes.

AxMSFlexGrid1.ForeColor = Color.Blue 'Cambia el color de letra de todas las celdas a azul.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(1, 500) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

.AllowUserResizing = MSFlexGridLib.AllowUserResizeSettings.flexResizeBoth 'Determina que el usuario puede modificar el ancho de columna en tiempo de ejecución.

'Para ponerle color amarillo suave de fondo a todas las celdas.

Dim Color1 As Color = Color.LightGoldenrodYellow 'Amarillo suave.

For fila As Integer = 1 To .Rows – 1 'Para no involucrar la primera fila, se comienza de 1 y no de 0.

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 1 To .Cols – 1 'Para no involucrar la primera columna, se comienza de 1 y no de 0.

.Col = columna

.CellBackColor = Color1 'Por estar dentro del For, cambia el color de fondo de todas las celdas a LighYellow (amarillo suave), pues la variable Color1 fue inicializada anteriormente con el valor de "Color.LightGoldenrodYellow".

.CellForeColor = Color.Blue 'Por estar dentro del For, cambia el color de letra de todas las celdas a azul.

.set_ColWidth(columna, 1300) 'Por estar deltro del For, le da un ancho de 1300 a cada columna.

Next

End With

Next

'Establece la alineación del contenido de la columna 0

.set_ColAlignment(0, MSFlexGridLib.AlignmentSettings.flexAlignCenterCenter)

'Se le ponen los respectivos títulos a cada fila.

'La sintaxis dentro del paréntesis es: (fila, columna, valor).

.set_TextMatrix(1, 0, "a-4")

.set_TextMatrix(2, 0, "a-3h")

.set_TextMatrix(3, 0, "a-2h")

.set_TextMatrix(4, 0, "a-h")

.set_TextMatrix(5, 0, "a")

'Se le ponen los respectivos títulos a cada columna.

.set_TextMatrix(0, 1, "x")

.set_TextMatrix(0, 2, "f(x)")

.set_TextMatrix(0, 3, "f'(x)")

.set_TextMatrix(0, 4, "f''(x)")

.set_TextMatrix(0, 5, "f'''(x)")

.set_TextMatrix(0, 6, "f''''(x)")

'Impresiones de resultados.

.set_TextMatrix(1, 1, Math.Round(Val(tablas9(1, 1)), 10)) 'Imprime el valor de "a-4h" (con 10 decimales).

.set_TextMatrix(2, 1, Math.Round(Val(tablas9(2, 1)), 10)) 'Imprime el valor de "a-3h" (con 10 decimales).

.set_TextMatrix(3, 1, Math.Round(Val(tablas9(3, 1)), 10)) 'Imprime el valor de "a-2h" (con 10 decimales).

.set_TextMatrix(4, 1, Math.Round(Val(tablas9(4, 1)), 10)) 'Imprime el valor de "a-h" (con 10 decimales).

.set_TextMatrix(5, 1, Math.Round(Val(tablas9(5, 1)), 10)) 'Imprime el valor de "a" (con 10 decimales).

.set_TextMatrix(1, 2, Math.Round(Val(tablas9(1, 2)), 10)) 'Imprime el valor de "f(a-4h)" (con 10 decimales).

.set_TextMatrix(2, 2, Math.Round(Val(tablas9(2, 2)), 10)) 'Imprime el valor de "f(a-3h)" (con 10 decimales).

.set_TextMatrix(3, 2, Math.Round(Val(tablas9(3, 2)), 10)) 'Imprime el valor de "f(a-2h)" (con 10 decimales).

.set_TextMatrix(4, 2, Math.Round(Val(tablas9(4, 2)), 10)) 'Imprime el valor de "f(a-h)" (con 10 decimales).

.set_TextMatrix(5, 2, Math.Round(Val(tablas9(5, 2)), 10)) 'Imprime el valor de "f(a)" (con 10 decimales).

.set_TextMatrix(1, 3, Math.Round(Val(tablas9(1, 3)), 10)) 'Imprime el valor de "(f(a+3h)-f(a-4h))/h"="f'(a-3h)" (con 10 decimales).

.set_TextMatrix(2, 3, Math.Round(Val(tablas9(2, 3)), 10)) 'Imprime el valor de "(f(a-2h)-f(a-3h))/h"="f'(a-2h)" (con 10 decimales).

.set_TextMatrix(3, 3, Math.Round(Val(tablas9(3, 3)), 10)) 'Imprime el valor de "(f(a-h)-f(a-2h))/h"="f'(a-h)" (con 10 decimales).

.set_TextMatrix(4, 3, Math.Round(Val(tablas9(4, 3)), 10)) 'Imprime el valor de "(f(a)-f(a-2h))/h"="f'(a)" (con 10 decimales).

.set_TextMatrix(1, 4, Math.Round(Val(tablas9(1, 4)), 10)) 'Imprime el valor de "(f'(a-2h)-f'(a-3h))/h"="f''(a-2h)" (con 10 decimales).

.set_TextMatrix(2, 4, Math.Round(Val(tablas9(2, 4)), 10)) 'Imprime el valor de "(f'(a-h)-f'(a-2h))/h"="f''(a-h)" (con 10 decimales).

.set_TextMatrix(3, 4, Math.Round(Val(tablas9(3, 4)), 10)) 'Imprime el valor de "(f'(a)-f'(a-h))/h"="f''(a)" (con 10 decimales).

.set_TextMatrix(1, 5, Math.Round(Val(tablas9(1, 5)), 10)) 'Imprime el valor de "(f''(a-h)-f''(a-2h))/h"="f'''(a-h)" (con 10 decimales).

.set_TextMatrix(2, 5, Math.Round(Val(tablas9(2, 5)), 10)) 'Imprime el valor de "(f''(a)-f''(a-h))/h"="f'''(a)" (con 10 decimales).

.set_TextMatrix(1, 6, Math.Round(Val(tablas9(1, 6)), 10)) 'Imprime el valor de "(f'''(a)-f'''(a-h))/h"="f''''(a)" (con 10 decimales).

End With

TextBox5.Text = "cuarta" 'Imprime el orden de la derivada.

TextBox6.Text = tablas9(1, 6) 'Muestra la respuesta en el TextBox6.

TextBox7.Text = TextBox3.Text 'Imprime el error utilizado.

End If

End If

'CASO 10. QUINTA DERIVADA POR TABLAS DE DIFERENCIAS DIVIDIDAS HACIA ATRÁS.

If (ComboBox1.SelectedItem = "Tablas de Diferencias Divididas Hacia Atrás") And (ComboBox2.SelectedItem = "5ta. derivada") Then

Dim i, j As Integer '"i" significará "fila" y "j" significará columna, de modo que se trabajará con (i,j)=(fila,columna)

'Establece cuántas filas y columnas tendrá el Grid.

AxMSFlexGrid1.Rows = 7 'Establece 7 filas.

AxMSFlexGrid1.Cols = 8 'Establece 8 columnas.

'Se crea una nueva instancia de la clase Evaluador.

Dim mEval As New Evaluador()

'Se crea una variable tipo string y se le asigna la expresión que se quiere evaluar.

Dim mExpresion As String = TextBox1.Text ' = "X".

'Se crea un objeto StringCollection y se le agregan los parámetros de entrada que usará el método eval.

Dim mParameters As New StringCollection()

mParameters.Add("ByVal X as Double")

'Las funciones a utilizar pertenece al espacio de nombres System.Math.

'se hace necesario entonces, crear un objeto StringCollection y agregar

'el namespace System.Math.

Dim mNameSpaces As New StringCollection()

mNameSpaces.Add("System.Math")

'Se invoca el método PrecompilarFunción y se verifica si se generó correctamente el assembly.

If mEval.PrecompilarAssembly(mExpresion, mParameters, mNameSpaces) Then

'Si el assembly se generó correctamente, se crea un array con los valores de los parametros a evaluar.

'Se invoca el método Evaluar y se asignan los resultados correspondientes.

'Se limpian todas las celdas para que no queden impresos resultados de procesos anteriores.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(0, 0) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

For fila As Integer = 0 To .Rows – 1

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 0 To .Cols – 1

.set_TextMatrix(fila, columna, "") 'Por estar dentro de los For anidados, con esto se ponen valores String Empty en todas las celdas, de modo que no aparezca nada y queden todas las celdas limpias y sin resultados de cálculos hechos anteriormente.

Next

End With

Next

End With

'Se comienzan a hacer los cálculos.

tablas10(1, 1) = Val(TextBox2.Text) – (5 * (Val(TextBox3.Text))) 'Almacena "a-5h".

tablas10(2, 1) = Val(TextBox2.Text) – (4 * (Val(TextBox3.Text))) 'Almacena "a-4h".

tablas10(3, 1) = Val(TextBox2.Text) – (3 * (Val(TextBox3.Text))) 'Almacena "a-3h".

tablas10(4, 1) = Val(TextBox2.Text) – (2 * (Val(TextBox3.Text))) 'Almacena "a-2h".

tablas10(5, 1) = Val(TextBox2.Text) – Val(TextBox3.Text) 'Almacena "a-h".

tablas10(6, 1) = Val(TextBox2.Text) 'Almacena "a".

tablas10(1, 2) = mEval.Evaluar(Val(tablas10(1, 1))) 'Almacena "f(a-5h)".

tablas10(2, 2) = mEval.Evaluar(Val(tablas10(2, 1))) 'Almacena "f(a-4h)".

tablas10(3, 2) = mEval.Evaluar(Val(tablas10(3, 1))) 'Almacena "f(a-3h)".

tablas10(4, 2) = mEval.Evaluar(Val(tablas10(4, 1))) 'Almacena "f(a-2h)".

tablas10(5, 2) = mEval.Evaluar(Val(tablas10(5, 1))) 'Almacena "f(a-h)".

tablas10(6, 2) = mEval.Evaluar(Val(tablas10(6, 1))) 'Almacena "f(a)".

tablas10(1, 3) = (Val(tablas10(2, 2)) – Val(tablas10(1, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-4h)-f(a-5h))/h"="f'(a-4h)".

tablas10(2, 3) = (Val(tablas10(3, 2)) – Val(tablas10(2, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-3h)-f(a-4h))/h"="f'(a-3h)".

tablas10(3, 3) = (Val(tablas10(4, 2)) – Val(tablas10(3, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-2h)-f(a-3h))/h"="f'(a-2h)".

tablas10(4, 3) = (Val(tablas10(5, 2)) – Val(tablas10(4, 2))) / Val(TextBox3.Text) 'Almacena "(f(a-h)-f(a-2h))/h"="f'(a-h)".

tablas10(5, 3) = (Val(tablas10(6, 2)) – Val(tablas10(5, 2))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-h))/h"="f'(a)".

tablas10(1, 4) = (Val(tablas10(2, 3)) – Val(tablas10(1, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-3h)-f'(a-4h))/h"="f''(a-3h)".

tablas10(2, 4) = (Val(tablas10(3, 3)) – Val(tablas10(2, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-2h)-f'(a-3h))/h"="f''(a-2h)".

tablas10(3, 4) = (Val(tablas10(4, 3)) – Val(tablas10(3, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a-h)-f(a-2h))/h"="f''(a-h)".

tablas10(4, 4) = (Val(tablas10(5, 3)) – Val(tablas10(4, 3))) / Val(TextBox3.Text) 'Almacena "(f'(a)-f'(a-h))/h"="f''(a)".

tablas10(1, 5) = (Val(tablas10(2, 4)) – Val(tablas10(1, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a-2h)-f''(a-3h))/h"="f'''(a-2h)".

tablas10(2, 5) = (Val(tablas10(3, 4)) – Val(tablas10(2, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a-h)-f''(a-2h))/h"="f'''(a-h)".

tablas10(3, 5) = (Val(tablas10(4, 4)) – Val(tablas10(3, 4))) / Val(TextBox3.Text) 'Almacena "(f''(a)-f''(a-h))/h"="f'''(a)".

tablas10(1, 6) = (Val(tablas10(2, 5)) – Val(tablas10(1, 5))) / Val(TextBox3.Text) 'Almacena "(f'''(a-h)-f'''(a-2h))/h"="f''''(a-h)".

tablas10(2, 6) = (Val(tablas10(3, 5)) – Val(tablas10(2, 5))) / Val(TextBox3.Text) 'Almacena "(f(a)-f(a-h))/h"="f''''(a)".

tablas10(1, 7) = (Val(tablas10(2, 6)) – Val(tablas10(1, 6))) / Val(TextBox3.Text) 'Almacena "(f''''(a)-f''''(a-h))/h"="f'''''(a)".

'Para indicar que se realizarán operaciones con el objeto AxMSFlexGrid1

'sin necesidad de escribir su nombre.

'De aquí en adelante vienen las impresiones de los valores en las celdas correspondientes.

AxMSFlexGrid1.ForeColor = Color.Blue 'Cambia el color de letra de todas las celdas a azul.

With AxMSFlexGrid1 'Para no estar poniendo por ejemplo AxMSFlexGrid1.set_ColWidth(1, 500) y así sucesivamente, no estar repitiendo a cada rato "AxMSFlexGrid1." NOTA: Desde el "With" hasta el "End With" solamente deben estarse mandando a imprimir valores a cada una de las celdas, y no estar haciendo cálculos con condiciones If ni nada de eso dentro del "With", pues todos los cálculos y condiciones deben hacerse afuera y venir a esta sección del "With" única y exclusivamente a hacer impresiones.

.AllowUserResizing = MSFlexGridLib.AllowUserResizeSettings.flexResizeBoth 'Determina que el usuario puede modificar el ancho de columna en tiempo de ejecución.

'Para ponerle color amarillo suave de fondo a todas las celdas.

Dim Color1 As Color = Color.LightGoldenrodYellow 'Amarillo suave.

For fila As Integer = 1 To .Rows – 1 'Para no involucrar la primera fila, se comienza de 1 y no de 0.

With AxMSFlexGrid1

.Row = fila

For columna As Integer = 1 To .Cols – 1 'Para no involucrar la primera columna, se comienza de 1 y no de 0.

.Col = columna

.CellBackColor = Color1 'Por estar dentro del For, cambia el color de fondo de todas las celdas a LighYellow (amarillo suave), pues la variable Color1 fue inicializada anteriormente con el valor de "Color.LightGoldenrodYellow".

.CellForeColor = Color.Blue 'Por estar dentro del For, cambia el color de letra de todas las celdas a azul.

.set_ColWidth(columna, 1300) 'Por estar deltro del For, le da un ancho de 1300 a cada columna.

Next

End With

Next

'Establece la alineación del contenido de la columna 0

.set_ColAlignment(0, MSFlexGridLib.AlignmentSettings.flexAlignCenterCenter)

'Se le ponen los respectivos títulos a cada fila.

'La sintaxis dentro del paréntesis es: (fila, columna, valor).

.set_TextMatrix(1, 0, "a-5h")

Partes: 1, 2, 3, 4, 5, 6, 7, 8, 9
 Página anterior Volver al principio del trabajoPágina siguiente