Blog
All Blog Posts | Next Post | Previous PostFNC Math Components in TMS Analytics & Physics 3.2
Monday, December 13, 2021
TMS Analytics & Physics library is a set of classes that provide functionality
for building powerful math applications with Delphi. In the new version 3.2 of
the library, we introduced special FNC math components. The components bring new
possibilities to develop and tune your math application in design-time with
standard IDE tools.
In this article, well consider the base concepts of the FNC math
components and provide information on how to work with functions, derivatives,
and integrals.
All FNC math components are nonvisual. Each component implements some math concept and provides properties to manipulate and tune it in design- and run-time. Lets consider the following components:
- TFNCProvider creates math environment; allows introducing variables and parameters for function evaluations, symbolic derivatives, and integrals.
- TFNCFunction1D introduces a symbolic function of one variable; allows evaluating the function for the specified variable value.
- TFNCDerivative1D introduces a symbolic derivative of a math expression; allows evaluating the derivative for the specified variable value.
- TFNCIntegral1D introduces a symbolic integral of a math expression; allows evaluating the integral for the specified variable value.
To begin any FNC math application we first need to put a TFNCProvider component on the form. The component has two published properties:
- Variables (TVariableCollection) a collection of variables that can be used as arguments of functions.
- Parameters (TParameterCollection) a collection of parameters that can be used in the math environment to build functions, derivatives, integrals, and other math expressions.
When you put a TFNCProvider
on the form in design-time, it automatically creates a default variable x for your math application. You can
change the name of the variable or add/delete variables at design- and
run-time.
For the simplest math application, the default environment with one variable x is enough. So, lets go forward and consider the next FNC component TFNCFunction1D and its properties:
- Provider (TFNCProvider) a math environment for the function.
- Variable (TVariableProperty) a variable specifying the argument of the function.
- Formula (TFormulaProperty) a formula specifying the math expression of the function.
Placing a TFNCFunction1D on the form, it assigns the default value x to the Variable property. We need to set up the Provider property and the expression for the Formula property, say 5*sin(6*x) in the Object Inspector. The resulting properties are shown in the picture below:
The function is ready to use. What can we
do with it? The first idea is to draw the function and see what it looks like.
We have the TFNCFunction1DPlotter
component especially developed for this purpose:
- TFNCFunction1DPlotter a binding for an FNC function component and an FNC Chart; allows drawing any FNC function on the chart.
The component has several published properties that we can use to tune it and show a function on the FNC Chart:
- Provider (TFNCProvider) a math environment for the component.
- Min (TValueProperty) the minimal value of the variable range to plot the function.
- Max (TValueProperty) the maximal value of the variable range to plot the function.
- PointCount (Integer) number of points to plot the function.
- AFunction (TFNCBaseFunction1D) a FNC function to plot.
- AssignLegend (Boolean) if true, assigns the functions expression to the series legend.
- Chart (TTMSFNCChart) an FNC chart to draw the function.
First, we need to assign the appropriate Provider property. The Min and Max properties have default values 0 and 10 accordingly, and the PointCount is 50.
When you assign the Chart property in design-time, the component automatically creates a new serie for the chart. The function will be drawn with this serie and you can set the appropriate properties of the serie to get the suitable representation of the function.
For now, we have a simple math application, designed with the four components: a provider; an FNC function; an FNC plotter; and an FNC chart. The form in design-time is shown in the picture below:
In run-time, the
application works like in design-time: it shows the only function 5*sin(6*x).
Lets move on and get the application drawing any function, the user can input
as a math expression.
First, lets look at the Parameters property on the FNC provider
component. This is a collection of parameters. A parameter is a named value
that can be used in math expressions together with variables. The TParameterProperty class has the
following published properties:
- Name (String) name of the parameter.
- Value (String) constant math expression of the parameters value.
- RealValue (Real) read-only float number for the math expression.
Via common IDEs interface, we can add or remove items of the Parameters collection to get desired math environment. For our application, we created three new parameters and assigned them some values, as shown in the following picture:
Now we can create a
simple user interface to input a math expression in a text box and a button
with the following event handler:
procedure TForm1.Button1Click(Sender: TObject);
var
f: string;
begin
f:= Edit1.Text;
FNCFunction1D1.Formula.Formula:= f;
end;
Thus, in run-time, the user can draw on the chart any function that depends on the variable x and three parameters A, B, and L. Here is an example of one such function draw:
The values of the
parameters can be changed as in design-time as in run-time. If a function
depends on the parameter, changing the value immediately leads to the function
and the chart update.
The TFNCDerivative1D component is intended to work with derivatives and has the following properties:
- Provider (TFNCProvider) a math environment for the component.
- Variable (TVariableProperty) a variable specifying the argument of the function.
- D (TVariableProperty) a variable specifying the differential.
- Functional a differentiable math expression.
- Formula (TFormulaProperty) read-only formula denoting the resulting math expression of the derivative.
In general, this component works like an FNC function, but it evaluates the derivative of the functional expression. Putting the component on the form we can create another button with a simple event handler to draw derivative of any function:
procedure TForm1.Button2Click(Sender: TObject);
var
f: string;
begin
f:= Edit1.Text;
FNCDerivative1D1.Functional:= f;
FNCFunction1DPlotter1.AFunction:= FNCDerivative1D1;
end;
Here we showed the resulting application in run-time for the derivative of a simple math expression:
The TFNCIntegral1D component has the same properties as the described TFNCDerivative1D component, but it evaluates the indefinite integral of a math expression. An example of an integral is shown in the picture below:
The source code of the demo project for the article can be downloaded from here. To start developing your FNC math application you need the latest versions of TMS Analytics & Physics and TMC FNC Chart products.
Masiha Zemarai
This blog post has not received any comments yet.
All Blog Posts | Next Post | Previous Post