APPLICATION OF DIGITAL CELLULAR RADIO FOR MOBILE LOCATION ESTIMATION IIUM Engineering Journal, Vol. 21, No. 1, 2020 Mustafina et al. https://doi.org/10.31436/iiumej.v21i1.1180 NUMERICAL ALGORITHM FOR FINDING OPTIMAL INITIAL CONCENTRATIONS OF CHEMICAL REACTIONS SVETLANA MUSTAFINA1*, ANDREY ANTIPIN1, EVGENIA ANTIPINA1, ELENA ODINOKOVA2, LARISA TUCHKINA2, KONSTANTIN KOLYAZOV2, AND SOFIA MUSTAFINA1 1Dept. Mathematics and Information Technology, Bashkir State University, Ufa, Russia 2Dept. Information Technology and Management Systems, Moscow State University of Technologies and Management, Moscow, Russia. *Corresponding author: Mustafina_SA@mail.ru (Received: 16th June 2019; Accepted: 19th October 2019; Published on-line: 20th January 2020) ABSTRACT: This article is devoted to the problem of developing methods for mathematical modelling in the sphere of optimal planning in a chemical experiment. In the article, the problem of finding the optimal ratio for initial concentrations of substances is formulated in general terms and an algorithm for solving this problem is constructed basing on the method of artificial immune systems. The developed algorithm for finding the optimal initial concentrations of substances allows solving the problem of experiment planning in chemistry at the computational experiment stage. In this case, the solution of the optimization problem found with its help does not depend on the choice of the initial approximation. The algorithm was tested for the industrially meaningful process of benzilidenebenzilamine synthesis for which the optimum values of the initial concentrations were calculated in order to obtain maximum yield of the reaction product. ABSTRAK: Artikel ini ditujukan untuk masalah mengembangkan kaedah pemodelan matematik dalam bidang perancangan optimum dalam percubaan kimia. Dalam artikel itu, masalah mencari nisbah optimum untuk konsentrasi awal bahan digubal secara umum dan algoritma untuk menyelesaikan masalah ini dibina berdasarkan kaedah sistem imun buatan. Algoritma yang dibangunkan untuk mencari kandungan konsentrasi awal yang optimum membolehkan menyelesaikan masalah perancangan percubaan dalam kimia pada peringkat percubaan pengkomputeran. Dalam kes ini, penyelesaian masalah pengoptimuman yang didapati dengan bantuannya tidak bergantung pada pilihan permulaan awal. Algoritma ini telah diuji untuk proses sintesis benzilidenebenzilamin yang bermakna industri yang mana nilai-nilai optimum kepekatan awal dikira untuk mendapatkan hasil maksimum produk reaksin. KEYWORDS: chemical kinetics; artificial immune systems; initial concentration 1. INTRODUCTION The solution to many problems in chemistry and chemical technology is associated with complex and expensive experiments. In the study of the chemical process at the computational experiment stage, it is advisable to identify its main regularities because of the complexity of the initial raw materials’ compositions and the low content of valuable components in them. In this regard, the actual task is to develop methods for optimal planning of the experiment, which allow saving time and material resources for conducting a full-scale experiment. 167 IIUM Engineering Journal, Vol. 21, No. 1, 2020 Mustafina et al. https://doi.org/10.31436/iiumej.v21i1.1180 The development of computer technology and information technology allows the use of mathematical methods in the planning of the chemical experiments. The methods of mathematical modelling allow the determination of optimal concentrations of reagents to obtain the best yield of the final product and significantly reduce the cost of substance synthesis. The calculation of the initial concentrations of the reactants in a chemical reaction is made by searching for an extremum of the function for calculating the dynamics of the substance concentrations during the chemical experiment. The significant drawbacks of most numerical methods for finding the extremum of functions are the difficulties in achieving convergence of the process, which depends on the choice of the initial approximation. Currently, metaheuristic optimization methods are widely used, which make it possible to efficiently find a global optimum in a reasonable time [1-3]. Their important feature is the ability to overcome the local extremum point of the target function in the search process. Therefore, they allow finding better solutions in comparison with classical heuristics [4-7]. Among the metaheuristic algorithms, the method of artificial immune systems is distinguished. Its advantage is the presence of a memory mechanism. The memory mechanism makes it possible to use information about previously found best solutions, thereby increasing the efficiency of global search. An important feature of the method of artificial immune systems is the independence of the optimization problem solution from the initial approximation [8-10]. 2. FORMULATION OF THE PROBLEM Let us formulate in general terms the problem of finding the optimal ratio for initial concentrations of substances. A mathematical model for the dynamics of substance concentrations is a system of ordinary differential equations ( , ( ), ), dx f t x t T dt (1) with initial conditions 0(0) , 1, ,i ix x i n (2) where 1 2( ) ( ( ), ( ), , ( ))nx t x t x t x t is the vector of the concentrations of the reacting substances, f (t, x(t), T) is continuous together with their partial derivatives of the function, ],0[ 2tt is the time of reaction, and T is the reaction temperature [11]. At the initial moment of time, substances are interconnected by some ratio: 1 1(0) : : (0) : : .n nx x (3) It is required to find the ratio for initial concentrations of substances, which ensures the extremum of optimality criterion 2 1 ( ) ( ) . n i i i Q x x t extr (4) The optimality criterion expresses the maximum yield of the target products or the minimum impurity content depending on the coefficients i (positive or negative). You 168 IIUM Engineering Journal, Vol. 21, No. 1, 2020 Mustafina et al. https://doi.org/10.31436/iiumej.v21i1.1180 can also specify some economic criterion, then the coefficients i are the cost coefficients of the reagents. 3. THE ALGORITHM FOR THE METHOD OF ARTIFICIAL IMMUNE SYSTEMS TO CALCULATE OPTIMAL INITIAL CONCENTRATIONS OF SUBSTANCES The method of artificial immune systems simulates the functioning of a living organism immune system, designed to destroy foreign bodies and improve the fight against them. Consider the main concepts of the method. An antigen is an alien substance from which the body tries to protect itself with antibodies. An antibody is a substance that recognizes and destroys an antigen [12]. A memory cell is an immune cell that accumulates data about new antibodies that can recognize an antigen. The target function of the optimization problem is called the fitness function [13,14]. As a function of fitness, we used the maximum yield of the target reaction product at the final moment of the reaction. This required the solution of a direct kinetic problem with a given ratio for the initial concentrations of the initial substances, that is, the solution of a system of differential equations (Eq. (1)) with initial conditions (Eq. (2)). We modified the algorithm to solve the problem of finding the optimal initial concentrations of the components in the reacting mixture. As a population of immune cells, we introduced sets of initial concentrations of substances 1 2 (0) ( (0), (0), , (0)), 1, ,j j j jnx x x x j k where k is the number of immune cells in the population. To calculate the value of the fitness function ( )Q x , it is necessary to know the concentration of reagents at the final point in time. To do this, we introduced a block for solving a direct kinetic problem into the algorithm. The problem of finding the minimum of the target function ( )Q x was reduced to the problem of finding the maximum by replacing the sign in front of the function with the opposite one: *( ) min ( ) max [ ( )].Q x Q x Q x If Q(x) was positive then Q(x*)<0. We formulated this algorithm. Step 1. The creation of an initial population for the starting substance concentrations. Set the number of immune cells in the population k, the number of parental cells for the selection r_sel, the number of cells in the population with the worst value of the fitness function n_bad, the maximum number of iterations i_max, the clone operator parameter n_cl, the mutation parameter m, the iteration counter num = 0. Randomly set the values of k cells of the initial population (0), 1, ,jx j k 0 (0) 1.jx Step 2. Calculation of fitness function values. For sets (0)jx calculate the value of fitness function ( )jQ x , by solving a direct kinetic problem for each immune cell. That is, at this step it is necessary to find a numerical solution to the system of differential equations (Eq. (1)) with the initial 169 IIUM Engineering Journal, Vol. 21, No. 1, 2020 Mustafina et al. https://doi.org/10.31436/iiumej.v21i1.1180 conditions (Eq. (2)) by an explicit or implicit method. The initial conditions of the system (Eq. (2)) are the immune cell. Step 3. Cloning. Select r_sel parent cells from the population (a set of antibodies), which correspond to the best values of fitness function ( )Q x . Generate n_cl clones for each cell. Step 4. Mutation. For each parent cell generate random numbers [0,1],l 1 [0,1 (0)], j ih x 2 [0, (0)], j ih x 1, .i n Perform a mutation of its clones by the rule: if 0, 5,l then 1(0) : (0) , s s i ix x h m else 2(0) : (0) , s s i ix x h m where 1, _ ,s n cl m – mutation parameter. Step 5. Calculation of fitness function values. For each mutant clone calculate the value of the fitness function by Eq. (4). Step 6. Selection and transition to a new population. For each parent cell, find the mutant clone with the lowest value of the fitness function. Compare its value with the value of the fitness function of the parent cell. In the new population, leave the parent cell or replace it with a mutant clone with the best fitness function value. Step 7. Renewal of a population. In the population, find n_bad cells with the lowest value of fitness function ( )Q x . Replace these cells with new ones, randomly generated in the interval [0,1), and calculate the value of the fitness function ( )Q x for them. Increase the iteration counter: num= num + 1. Step 8. Checking the conditions for the end of search. If num> /ColorImageDict << /QFactor 0.76 /HSamples [2 1 1 2] /VSamples [2 1 1 2] >> /JPEG2000ColorACSImageDict << /TileWidth 256 /TileHeight 256 /Quality 15 >> /JPEG2000ColorImageDict << /TileWidth 256 /TileHeight 256 /Quality 15 >> /AntiAliasGrayImages false /CropGrayImages true /GrayImageMinResolution 200 /GrayImageMinResolutionPolicy /OK /DownsampleGrayImages true /GrayImageDownsampleType /Bicubic /GrayImageResolution 300 /GrayImageDepth -1 /GrayImageMinDownsampleDepth 2 /GrayImageDownsampleThreshold 1.50000 /EncodeGrayImages true /GrayImageFilter /DCTEncode /AutoFilterGrayImages false /GrayImageAutoFilterStrategy /JPEG /GrayACSImageDict << /QFactor 0.76 /HSamples [2 1 1 2] /VSamples [2 1 1 2] >> /GrayImageDict << /QFactor 0.76 /HSamples [2 1 1 2] /VSamples [2 1 1 2] >> /JPEG2000GrayACSImageDict << /TileWidth 256 /TileHeight 256 /Quality 15 >> /JPEG2000GrayImageDict << /TileWidth 256 /TileHeight 256 /Quality 15 >> /AntiAliasMonoImages false /CropMonoImages true /MonoImageMinResolution 400 /MonoImageMinResolutionPolicy /OK /DownsampleMonoImages true /MonoImageDownsampleType /Bicubic /MonoImageResolution 600 /MonoImageDepth -1 /MonoImageDownsampleThreshold 1.50000 /EncodeMonoImages true /MonoImageFilter /CCITTFaxEncode /MonoImageDict << /K -1 >> /AllowPSXObjects false /CheckCompliance [ /None ] /PDFX1aCheck false /PDFX3Check false /PDFXCompliantPDFOnly false /PDFXNoTrimBoxError true /PDFXTrimBoxToMediaBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXSetBleedBoxToMediaBox true /PDFXBleedBoxToTrimBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXOutputIntentProfile (None) /PDFXOutputConditionIdentifier () /PDFXOutputCondition () /PDFXRegistryName () /PDFXTrapped /False /CreateJDFFile false /Description << /ARA /BGR /CHS /CHT /CZE /DAN /DEU /ESP /ETI /FRA /GRE /HEB /HRV /HUN /ITA (Utilizzare queste impostazioni per creare documenti Adobe PDF adatti per visualizzare e stampare documenti aziendali in modo affidabile. I documenti PDF creati possono essere aperti con Acrobat e Adobe Reader 6.0 e versioni successive.) /JPN /KOR /LTH /LVI /NLD (Gebruik deze instellingen om Adobe PDF-documenten te maken waarmee zakelijke documenten betrouwbaar kunnen worden weergegeven en afgedrukt. De gemaakte PDF-documenten kunnen worden geopend met Acrobat en Adobe Reader 6.0 en hoger.) /NOR /POL /PTB /RUM /RUS /SKY /SLV /SUO /SVE /TUR /UKR /ENU (Use these settings to create Adobe PDF documents suitable for reliable viewing and printing of business documents. Created PDF documents can be opened with Acrobat and Adobe Reader 6.0 and later.) >> >> setdistillerparams << /HWResolution [600 600] /PageSize [595.440 841.680] >> setpagedevice