1. Introduction
At present, the world economy is showing signs of various problems, such as economic recession. The causes of an economic recession include epidemics, natural disasters, and wars. These factors have a significant impact on investment. Tourism is a major target for economic recovery, because it can generate great income due to its low investment and high profitability. Many countries that feature tourist attraction landmarks set important targets for economic revitalization and perpetual development that focus on their tourist landmarks. Tourists from several countries create new travel styles and new experiential methods of searching. Hotel businesses rely on successful tourists for growth. Tour planning is necessary when group or family trip styles become popular and increase in size or complexity [
1]. Tourism informational systems are an essential part of making decisions pertaining to visiting attractive tourist locations, which are also referred to as “landmarks”. The ranking, sequencing, routing, and selection of sights to see within a given time window are difficult processes in terms of satisfying the needs of all group members [
2].
Many researchers have studied tourism planning and trip routing design within a determined time window for the software generation of tourism planning systems. The software of tour planning design and trip routing design has focused on the balancing of sequences of visits within a time window to support visiting the greatest number of landmarks with the lowest travel distance and expense. This helps travelers to more easily make decisions regarding trip routing and place selection [
3,
4,
5,
6,
7,
8].
A significant problem in tourism planning design is the satisfaction of all trip members, which is a difficult problem to solve. Therefore, the different tourism styles of family members create a difficult situation in terms of the software creation of a system of tourism planning design. Tourism style is the cause of several factors relating to tour satisfaction. Many factors affect the satisfaction of trip members, such as their different interests, cultures, budgets, time limits, and food and drink preferences [
9,
10,
11]. Visiting the greatest number of landmarks, low costs, interesting activities, convenient transportation, available facilities, and low travel distances and time costs are important factors for tourism planning design [
7,
12].
Recently, a heuristic method was applied to solve many tourism problems, which allowed for the generation of a type of tourism planning software that supports a database system of tourism [
13,
14]. Yu and Chang used a nearest neighbor algorithm to find tour planning solutions for a mobile tourism application. After the solving process, the application could generate an individual trip route, with various suggestions for landmarks and hotels [
15]. In 2015, Gavalas et al. employed a slack route tour planning algorithm to create the eCOMPASS system, which was designed for use on a webpage or mobile application in Athens (Greece) or Berlin (Germany). Their algorithm could perform an attractive place selection in urban areas with both efficiency and diversity [
16]. The Chinese tourism industry found that service quality reduction and stranded tourists were the main problems in 2019, and better tourism management was urgently required. Forecasting methods with a back propagation (BP) neural network model and fruit fly optimization algorithm (FOA) have been employed to solve these problems. Models using this prediction method display tourism demands accurately for sightseeing spots during high seasons [
17].
Tourism has become an important part of the national policy of Thailand due to the continuous growth of the tourism industry there, especially Buriram province in Thailand, which is a popular city. The number of visitors in Buriram increases every year, and most tourists prefer to travel together as a family. The purpose of a family trip is to relax and strengthen family relations; however, family members have various lifestyles, depending on their age and gender. These dissimilarities result in different groups having different family tourism requirements, such as modern technology or a specific tourism style, including the desired spending behavior for products and services. Informational system preparedness is important for allowing family members to search for and select interesting places and accommodation; therefore, travel routes should show information about tourism places and facilities to support decision-making. For this reason, tourism companies in Thailand have created many tourism software applications, with various persuasive purposes and tour styles. Previously, tourism creation has neglected the satisfaction of tourist groups or families regarding tourist sightseeing, which is important for giving tourists a good impression and encouraging them to return. However, many tourism applications cannot meet the requirements for family tours due to the heterogeneity of gender and age in family groups, which brings about different opinions regarding tourism place selection and modes of travel. For the abovementioned reasons, careful tourism routing design for family tours in Buriram is urgently required. Thus, the main contributions of this paper are twofold. Firstly, we study the family tourism routing problem, according to differences in terms of age, gender, and attraction between family members. Although this these aspects were addressed by Zheng and Liao (2019) [
14], the distinctions can be listed as follows: (1) The previous research formulated multi-objective function, the solution provides various alternative routes then user has to select the best route and decision a beneficial trade-off between total utility of the group (TUG) and fairness of individual member (FIN) within a time budget. Current research formulates single objective function and provides the best route in order to make it easy for the user to make decisions. Besides, we include travelling cost in the objective function to economize on budget. (2) We add special constraint to let the tourist indicates the wish list (the place that tourist need to visit) into the route, whereas the literature did not mention. (3) The solution approaches between each research are different. The previous research applied NSACDE which combines ant colony optimization (ACO) and differential evolution algorithm (DEA), whereas we introduce the MALNS as a solution approach. Secondly, we have modified the adaptive large neighborhood search (MALNS) algorithm to solve this problem. Our MALNS algorithm is unique, with modified operators and solution acceptance methods for achieving optimal overall satisfaction regarding tourism places and tourism routing. Finally, the family tourism application base on the MALNS algorithm is flexible in terms of rerouting and re-selecting tourism places in accordance with the changing satisfaction requirements of family members, including in non-family tourism route planning.
This article aims to solve the aforementioned problems by generating a mathematical model and MALNS algorithm for family tours. The MALNS algorithm is carefully route designed and balances the different aspirations of family members and tourism places in routes, depending on differences of age, gender, and time limits. The results from the lingo program using the exact method were compared with the results from MALNS in terms of the performance of the solution-finding method. A mathematical model and modified adaptive large neighborhood search (MALNS) algorithm are applied here to support the creation of software for the processing of a family tourism application. The literature review, mathematical model design, MALNS algorithm, computational consequences and result of the algorithm, conclusions, and recommendations are presented in 
Section 2, 
Section 3, 
Section 4, 
Section 5 and 
Section 6, respectively.
  2. Literature Review
The expansion of the tourism industry is very fast, as it is backed by the government sector. Family tourism is an important policy of tourism organization, as it causes the creation of family bonds, family togetherness, and family memories. The family tourism trend has extended around the world. Recently, Schanzel, and Yeoman [
1,
18] presented a family tourism incentive, including differences between family members in terms of age, immigration, multi-generational travel, social capital and the creation of memories, helicopter parenting, experiential family holidays, children, blended families, new family markets, and gender. These are factors that influenced the creation of family tourism and family tourism reorganization. In particular, the age and gender of a family member are the primary factors in the determination of his/her complex passions and particular needs. Wu et al. [
19] presented a family tourism experience for Chinese children aged between 8–11 years. They found that this group of children had an apparent favorite activity, and several family tourism groups experienced that their tourism experience emphasized physical activities, family togetherness, animal interaction, food testing, and the appreciation of the natural and built environment. These activities influence the generation of destinations that are interesting as family tourist attractions. In addition, Ingkadijaya [
20] studied family tourism requirements in relation to travel motivations, family tourism types and activities, and the travel motivations of families in Bogor city. The main factors were the differences in the age and number of family members. The data for analysis were collected using a survey approach, and statistics are used for the description. It was found that two major family travel motivations are family members’ desire to free themselves from their personal lives and develop family relationships. The tourism types and activities are cultural, natural, and special activities associated with family tourism. The travel motivation of a family is relaxation and the development of family relationships through participation in desirable activities. Additionally, Lima et al. [
21] explain that family tourism in Portugal is focused on the development of family relationships through participation in new activities, relaxation, and exploration of new environments. An influencing factor that affects the creation of experiences and travel choices in family tourism is the economic difference between families. This factor is an important factor and should not be neglected in designing family tourism styles and travel. This reason helps to reduce the differences in family tourism and raise people’s quality of life. From our review of the literature on family tourism, the factors that affect family tourism are differences in terms of gender, age, family activities, spending, destinations that are considered to be attractive, and travel motivations. These factors constitute a determinative factor of member satisfaction in family tourism experience.
However, due to the effect of the generation of experienced complacence in planning family travel experiences on family member expectation, it is difficult to strike a satisfying balance in family tourism. To achieve such a satisfying balance in a family tour, it is necessary to consider the importance of mental factors and relations within the family. Therefore, family tourism design and planning is important and effective in achieving the purpose of adapting to the diverse desires of family tourists. Family tourism design and planning is a tourism problem, which is a very difficult problem to solve due to the diverse desires of family members. In tour design and tour route planning, the difficulty of tourism place selection for sightseeing and family activities must be solved in order to achieve a reasonable level of satisfaction in each family member. Consequently, tourism destination affects tour trip design and tour route planning in family tourism, which is a tourism problem that has not been adequately addressed in the literature.
From the tourism problem literature review conducted here, two primary problems were found for landmark selection. These problems related to the tour trip design problem (TTDP) and the tour route planning problem (TRPP). The TTDP and TRPP are complex problems due to the large amount of data that must be considered for less popular destinations or new landmarks and facilities. In addition, the many factors influencing the problem complexity are differences in terms of time limit, season, traffic, and travel area, which make finding a solution more difficult. For this reason, a local searching method cannot solve these problems, and a heuristic method is therefore the proper solution method. Han et al. [
22] successfully applied a particle swarm optimization (PSO) algorithm to the TRPP to find the maximum tourist satisfaction and the minimum travel distance. The determining factors of this design were the tourism cost, tourism attraction place, and tour time. Moreover, their study found that the congestion levels at the tourist attractions and the numbers of tourists influenced tourist satisfaction for sightseeing. Similarly, Xiao et al. [
23] studied a neural net buffer algorithm for landmark selection in the context of tour route selection for the purpose of tourist support in Zhengzhou, China. The constraints were interesting spot classifications, the number of tourism locations, and the visiting time limits. The results showed good route selection and fast decision-making abilities for tourist support. Sirirak and Pitakaso [
7] presented a study on the optimization of tour distance and the exploration of suitable marketplaces in a determined time window. An ALNS algorithm was used for problem solving in marketplace location selection and route design in Chiang Rai, Thailand. The best solution found by the ALNS algorithm included six approaches for destruction and five approaches for reconstruction. The ALNS algorithm exhibited a 1.12% higher efficiency than the exact method, and the processing time of the ALNS algorithm was about 99% faster than the exact method. Therefore, ALNS algorithms offer high-quality solutions, but the tourism problem solving research on single tourists, as mentioned above, is not applicable to problem solving in family tourism.
Recently, family tourism-related research has focused on solving the TRPP, TTDP, and fashion development continuously in a tour group. Yu et al. [
24] displayed the trip selective problem of tourists in team orienteering using several transportation modes within certain time windows and showed that this problem is an obstacle to tourist trip design. The mixed-integer programming model based on the TOPTW is called the multi-modal team orienteering problem with time windows (MM-TOPTW). The MM-TOPTW was applied in their solution. A two-level particle swarm optimization (2L-PSO) method was used to solve the TTDP with multiple social learning terms, and transportation time and cost were considered as factors. The results showed a higher quality solution when compared to other algorithms. In the same year, a greedy approach was employed for the TRPP, proposing the time and budgets of tourists as the determining factors. Appropriate tourism routes were generated via this approach. Besides, the results showed the influence of the traffic in a tourism route on the tour time [
9]. 
Zhu et al. [
25] and Liao et al. [
26] presented a solution to the TTDP, considering optimized routes and time allocation, with a genetic algorithm (GA) and differential evolution (DE). The problem they encountered was the variation of the time and the environment, including the travel time or waiting time. Time and environmental changes affect the sightseeing choices of tourists. The studies found a suitably interesting point for routing to support travel and tourist confidence; however, conflicting lifestyles were the main problem for tour groups with different desires. Recently, Zheng and Liao [
14] presented a personal tour route design scheme using a mixed method of ant colony optimization (ACO) and a DE algorithm. The solving problem for tour route design was balancing the satisfaction of a heterogeneous tourist group at Kulangsu, an island off the coast of Xiamen in China. Their results show high-quality solutions and more diversified, realistic, and personal routes. Moreover, their research has shown that a primary influencing factor in route design is real-time crowd prediction in popular tourism locations and hotels. This is a factor that affects personalized route design in urban tourism and has not been studied in the context of group tourism problem solving. 
Similarly, Hu et al. [
27] presented a study tour recommendation using a sequential design of attractive destinations for travel based on tourist group guidance. The two methods of sequential generation of attractive destinations are Attention-based Tour Group Recommendation (AGREE) and bi-directional recurrent unit (Bi-GRU). The result shows the performance of generating an attractive destination sequence on the basis of a real-world dataset. Our review of the tour group literature showed several influencing factors in tour group development, including transportation type, cost, tour time, traffic in the tour route, environment, satisfaction, tourism location, and accommodation. These factors are not applicable to family tourism. In addition, the high-performance diversified heuristic method of tour group problem solving can be divided into single and combination methods, such as PSO, GA-DE, ACO-DE, and AGREE-Bi-GRU. Clearly, combination methods are used to improve the process of finding solutions to the TTDP and TRPP. However, the abovementioned method has a limitation associated with the improvement of solutions, which is that it can only use a certain number of heuristic methods. 
Several research suggestions highlight the study of influencing factors and not just the adjustment of problem solving for the TTDP and TRPP alone. The factors include the congestion level of the tourist destination, the conflicting lifestyles of tourists, the traffic on the tour route, real-time crowd prediction, and the hotels in the tour route. Furthermore, differences in satisfaction, age, and gender are worthy of consideration for family tourism, as they are factors that should not be ignored. In addition, the literature review shows that the most effective algorithms for tourism design are heuristic methods. Many studies have shown the high effectiveness of processing in terms of problem solving, showing that it has the best solutions and fastest times. The results of several heuristic methods have been accepted on the basis of their effective solutions. Especially, ALNS algorithms display a prominent point of diversity in terms of destruction and reconstruction methods. Additionally, the ALNS method has a procedure of solution acceptance based on a heuristic approach, which only accepts the best solution. Therefore, the ALNS algorithms generate highly effective solutions, and the required processing time is a distinctive point of problem solving using the ALNS method. However, the ALNS method has a variety of solution improvement approaches and solution acceptance processes to achieve the best solution, but the accepted solution may profit from further solution development in order to achieve an optimal solution. 
Therefore, the performance improvement of the process finding and process of solution acceptance of the ALNS method was considered in this paper. The performance development of process finding based on the ALNS method is called Modified Adaptive Large Neighborhood Search (MALNS) for problem solving in this work. The research focus here is to appropriately determine time windows for family tours in terms of the different demand conditions for different levels of satisfaction, ages, and genders. 
  4. Adaptive Large Neighborhood Search Algorithm
Heuristic algorithms consider several problems while finding optimal solutions. An ALNS algorithm has been used to solve the vehicle routing problem (VRP), location routing problem (LRP), and TRPP [
7,
28,
29,
30]. This work considers the family tour route planning problem, also using an ALNS algorithm to find optimal solutions.
  4.1. ALNS Approach
The ALNS approach here has five steps for finding optimal solutions: Step 1, the first construction is the generation of an initial feasible solution (s); Step 2, the specification of the initial solution (s) is the best solution (s*); Step 3, the operation of destruction and reconstruction is the probability of the selected random initializing weights; and Step 4, the stopping criterion of solution finding is when the new best solution is found. Step 4 includes four sub-steps: Step 4.1, the selection of both destruction (d) and repair (r) is chosen via the weight values for random probabilities; Step 4.2, the new solution is chosen after the destruction (d) and repair (r) of the previous solution (s), where the new solution (s’) passes the conformable acceptance condition; Step 4.3, where the new solution (s’) becomes the initial current solution(s) for solution finding in the next iteration; and Step 4.4, where the new solution (s’) is adjusted with a new weight value when the current solution (s) is better than the former solution (s*). Finally, in Step 5, if the optimal solution is not found, the algorithm returns to the loop in Steps 3 and 4 to find the best new solution until the optimal solution is found. Details of each constituent in the algorithm are shown in Algorithm 1.
        
| Algorithm 1. The adaptive large neighborhood search (ALNS) algorithm for family tourism route planning. | 
|  | 
| 2.Set solution s as the best initial solution s*←s;
 | 
| 3.Assign weights to each operator and perform destruction and reconstruction, with the selective randomization of the initialized weights;
 | 
| 4.Apply the stopping criterion of solution finding, then
 | 
| 4.1Select q, when r  R and d  D, which are related to probabilities p based on the current weights of the applied destruction and reconstruction operators to s;
 | 
| 4.2Destroy and repair the previous solution to find a new solution s′ = r(d(s));
 | 
| 4.3If the new solution is accepted by the acceptance criterion, then s←s′;
 | 
| If solution s is the better than solution s*, then s*←s′; | 
| 4.4Adjust the new weight value of the current solution;
 | 
| 5.Return to loop 1 to find the new best solution s*.
 | 
An initial solution is constructed with a travel route between a selected place to the next attractive destination, considering the ratings for different age ranges and genders. The initial solution considers the best feasible solution for each route. The algorithm construction for finding a feasible solution is shown in Algorithm 2.
        
| Algorithm 2. Feasible solution construction. | 
| 1.Set Lt <− {1, 2, …, n} is comprised of attractive places for travel route construction based on the tourism place ratings.
 | 
| 1.1.The route construction of travel r1 and determination of the initial solution S ={r1}
 | 
| 2.Generate Lt, which is a non-empty set of routes, for repeated operations.
 | 
| 2.1Randomly select travel places, where ct  Lt.
 | 
| 2.2Insert travel place ct into rkS, where rk is the best feasible route for the solution.
 | 
| 2.3If ct features no feasible inserted place, then create new route S.
 | 
| 2.4Delete ct from group set Lt ← Lt − {ct}.
 | 
| 3.Set Lf <− {1,2, …, m}, which is a set of tourism places with good ratings.
 | 
| 4.While group set Lf is not empty for tourism places:
 | 
| 4.1Randomly select the tourism place, where cf  Lf.
 | 
| 4.2Select tourism place cf if it is the best feasible location in route rk  S.
 | 
| 4.3Delete cf from the group set Lf ← Lf − {cf}.
 | 
| 5.Return to loop 1 to achieve the feasible solution S.
 | 
The construction of a feasible solution is performed in four steps. Step 1 is where Lt is defined as the set of all attractive destinations. Route r1 is generated as an empty route, and the determination of r1 is the initial solution S. Step 2 is where set Lt is used for repeated operations. Step 2 consists of four sub-steps: Step 2.1 is where tourism attractions are randomly selected, forming Lt; Step 2.2 is where the destination ct is inserted into rk, where rk is the best feasible route for the solution; Step 2.3 is where a new route is created if destination ct cannot be inserted; and Step 2.4 is where the attractive destination ct is deleted from Lt. Step 3 involves the determination of Lf, which is the set of all tourism locations with good ratings. Step 4 involves the set Lf, which is the set of all selected tourism locations in a current route. Step 4 involves two sub-steps: Step 4.1 is where tourism place cf is randomly selected from Lf; and Step 4.2 is where tourism place cf is selected if it is the best feasible tourism place in route rkS, with the minimum distance. Finally, in Step 5, if the best feasible solution has not been found, then the process begins again from Step 1.
Finding the best solution depends on the internal operation of each destruction and repair method. Several internal operations for the destruction and repair methods are selected randomly via the cumulative probabilistic weights in the current iteration of the improvement of the solution, as detailed below.
  4.2. Destruction Methods
The destruction method featured partial solution removal in order to generate new solutions. Here, four approaches for destruction are used. The four approaches were random removal, worst removal, K-route removal, and relative removal. The differences between these approaches are detailed below.
  4.2.1. Random Removal 
Random removal is an uncomplicated method, where all initial solutions randomly choose a solution for each route, as shown in 
Figure 2. Step 1 of random removal is where a tourism location is randomly selected for destruction. Step 2 is where the number of locations destroyed is randomly selected. Step 3 is when the random set of points are removed from the route. Finally, Step 4 features the repair method, which is used to find the best solution.
  4.2.2. K-Route Removal
The two modes of K-route removal are single-route removal and two-route removal. One of the two modes was randomly selected for the solution destruction, as shown in 
Figure 3. The K-route removal steps are described as follows: Step 1, a route from all routes is randomly selected. One or more than one route from R ⊆ S is selected, where |R| = K. Step 2 represents the determination of the array removal (A) and the array destruction of the randomized route (R). Step 3 is where the removed route is randomized by one of the two modes for solution destruction. Finally, in Step 4, the method proceeds back to Step 1 of route selection to repeat the solution destruction operation and solution finding in set L, which is the solution set for destruction.
The selected route is removed from the set of all routes. After that, the solution repair method generates a new solution. The new random solution is a tourism point in the destroyed route or a point between the destroyed route, where the new solution is inserted into a vacant point in the route.
  4.2.3. Worst Removal
Worst removal is a solution that destroys the worst solution for each group or route. The priority for removal is determined on the basis of high distances or costs. The worst solution is removed from the route, as shown in 
Figure 4. The process is repeated as per the process shown in Algorithm 3.
          
| Algorithm 3. Worst removal algorithm. | 
| 1.Establish vacancy set L←{};
 | 
| 2.Find set< L, while |L| < q:
 | 
| 2.1Generate array A, which is an array containing all attractive destinations from s not in L;
 | 
| 2.2Sort A, such that (i < j)→distance (A) [i] < distance (A[j]);
 | 
| 2.3Randomly select x in the interval (0,1);
 | 
| 2.4Evaluate the addition in L ← L ∪ {A[xp |A|]};
 | 
| 3.Remove points in L from s;
 | 
| 4.Return to loop 1 (set L).
 | 
Through this process, the worst solution is removed from the route, and the tourism points are then reordered. The worst removal steps are the following: Step 1 is where the first vacant set is established. Step 2 is where set L is found via a repeating process, while |L| < q. Step 2 has four sub-steps: Step 2.1 is where array A is generated, which contains all destinations from the solution that are not in set L; Step 2.2 is where array member A is sorted by distance functional removal; Step 2.3 is where the value of x is randomly selected to be between 0 and 1; Step 2.4 is where a tourism point is randomly selected from array A, and the point is evaluated in terms of the set of L, where the value p is a random weight, and low values correspond to increased randomness. Step 3 is where the points in L are removed from the solution. Finally, in Step 4, the value of L is returned to Step 1, where it is used to find further solutions. 
  4.2.4. Relative Removal
Relative removal is the removal of points via relation to the tourism point group. The tourism point in a route is selected by randomization, and the side point is removed as well, as shown in 
Figure 5. The relative removal algorithm steps are shown in Algorithm 4. 
Step 1 is where a single tourism point position is randomly selected from all tourism places. The tourism point position is then removed from the set. Step 2 involves the generation of the group set for removal with the initial member c
t. Step 3 involves finding L, comprising a process that is repeated while |L| < q. This step has five sub-steps, including: Step 3.1, where one tourism point position is chosen randomly from L; Step 3.2, where array A is created from all solutions but is separate from set L; Step 3.3, where the members of array A are sorted from lowest to highest by their functional relation R (c
1,c
2). The definable relation is the route distance between c
1 to c
2 plus the open time of the destination, i.e., c
1 and c
2 from R (c
1,c
2) = α distance (c
1,c
2) + β|t
ac1 − t
ac2|; Step 3.4 is where the value of x is randomly selected to be between 0 and 1; and Step 3.5 is where a tourism point is randomly selected from array A, and the point is increased in set L. The value 
p is a random weight, where low values correspond to increased randomness. Step 4 is where point L is removed from the solution. Finally, in Step 5, the process returns value L to Step 1 in order to find further solutions.
          
| Algorithm 4. Relative removal algorithm. | 
| 1.Establish vacancy set L←{};
 | 
| 2.Randomize the centroids p (lat, lng);
 | 
| 3.While |L| < q:
 | 
| 3.1Find ct as the approximate position of the centroid point with Euclidean distance;
 | 
| 3.2L ← L  {ct};
 | 
| 3.3Centroid update p(lat, lng) = centroids(L) = ;3.4Randomize selection (x) to be between 0 and 1;3.5Randomize the selection of the tourism position in array A, and increase the point in set L
 | 
| 4.Remove points in L from solution;5.Return to loop 1
 | 
  4.3. Reconstructive Operations
The four reconstructive operations were used for the insertion of the repairing solution. The four operations were Greedy insertion, Regret-H insertion, Node swap insertion, and Modified node swap insertion. The differences between the methods are detailed below.
  4.3.1. Greedy Insertion
Greedy insertion is a repair operation that uses the maximum distance or highest travel cost for the purpose of reducing distances or costs to within satisfactory thresholds. Tourism points are reinserted into destroyed routes to repair new routes, as shown in 
Figure 6. 
The steps of greedy insertion are described as follows: Step 1 involves the determination of value S, which is the solution set of members {r
1, r
2, …, r
k}. Step 2 involves iterating over each solution (r
k ∈ S), finding the lowest distances and costs with maximum satisfaction for each solution, which are then inserted (c) into r
k ∆f
c,k. Finally, in Step 3, the tourism position with the lowest cost or lowest distance of all routes is selected for insertion as per Equation (11):
          where c is the lowest travel distance, L is all tourism positions, k is the tourism point number, and f is the distance difference between each route as per the smallest distance evaluation.
  4.3.2. Regret-H insertion
Regret-H insertion was used here as an improvement of greedy insertion, where x
c,h ∈ {1,2, …, H} for solution insertion, as per Equation (12):
          where x
c,h is the insertion point for tourism point c and the sequential insertion to h. The route exhibits the highest distance with greedy insertion.
The route with the greatest travel distance is selected using the regret-H approach. The greatest distances in the route from tourism point i to j are selected for removal. The solution of regret-H is the inserted position of the lowest distance route, as shown in 
Figure 7.
  4.3.3. Node Swap
Node swap is a local search operator and a heuristic method for local problem solving. Here, two modes of node swapping were used for the solution repair, where point swapping for each route was randomly selected. The tourism points of each route were swapped for the shortest distance or lowest cost, along with the highest satisfaction for new route generation, as shown in 
Figure 8. The solution with the lowest distance with the highest satisfaction of all solutions for a new route is the best solution.
  4.3.4. Modified Node Swap
Modified node swap is an applied approach based on three approaches, including node swapping, cluster removal, and worst removal for solution repair. Firstly, a swap point was randomly selected to be swapped with a similar point. Secondly, the cluster around the selective point was determined. Then, the worst point of each cluster was exchanged among the selected points and the worst point to create a new route. Finally, the worst points of each cluster were swapped with each other, as shown in 
Figure 9.
The new route generated on the basis of the lowest distance with the highest satisfaction is the best solution.
  4.4. Acceptance Criterion
An acceptance criterion was used to check if each new solution was the best solution. If a new solution was worse than the previous solution, then the acceptance criterion was considered to make a decision as to whether the new solution should be accepted. In this work, the criterion of solution acceptance used three criteria, including the Simulated Annealing (SA) method, Linear Function (LF), and Exponential Function of Current Number of Interactions (EFCNI). One of the three accepted criteria were selected by randomization in each iteration of the solution finding process. 
  4.4.1. Simulated Annealing Method (SA)
The new solution was checked for acceptance by SA at every iteration [
31]. The acceptance of a new solution means that the new solution is better than the current solution. The simulated annealing method for the acceptance criterion considers the probability of new solution acceptance as per Equation (13): 
          where 
S(V) is the best current solution, and 
S(V′) is the newly created solution. The predetermined parameters are 
T and 
K. The new solution is accepted via the probability of the best solution in each iteration of the solution finding process. The acceptance process stops checking solutions when the algorithm does not find a better solution.
  4.4.2. Linear Function (LF)
The current interaction displays an important matter in accepting or rejection a new solution. The algorithm will search a full area of the search area, and it should have a way to escape from the local optimal when it is trapped in the searching area. Therefore, the data on the interactive current number have been increased by Equation (13). The LF approach shows Equation (14) is as follows:
          where 
MaxIT is the maximum number of iterations, which is the number of current iterations.
  4.4.3. Exponential Function of Current Number of Interactions (EFCNI)
The EFCNI approach involved checking new solutions for acceptance, which will modify the performance of the algorithm. The exponential function of the current number of interactions is shown in Equation (15):
  5. Computational Framework and Results
The mathematical model was tested via an exact method using the Lingo program to verify the model accuracy. The exact method is a method for calculating every alternative in solution finding and selecting the best value from every alternative, which is an optimal solution in problem solving. An effective result found via the exact method was compared with the result of the ALNS algorithm. The mathematical model and the ALNS algorithm show the dataset of three primary parameters for testing in 
Table 1. The determination of the three parameters was carried out via surveying tourists in Thailand. The rating score of interesting tourism place satisfaction was determined as a score between 1–10. The most interesting tourism attractions display high rating scores, and the less interesting tourism attractions show low rating scores. The locations of intermediate interest are represented by a medium score. The second parameter was the number of tourism days, which was between 1–5 days for testing in each experiment, and the number is the precise tourism days fixed by the tourist.
The number of family members used (2–5 persons) was used to determine the age ranges and genders, which were used for testing the mathematical model and the ALNS algorithm. The data for tourism locations and accommodation were selected randomly in the testing of the mathematical model and the ALNS algorithm, as shown in 
Appendix A Table A1. The result of both the Lingo program and ALNS algorithm were analyzed using the Windows operating system and a computer with an Intel
(R) Core i5
-9500 processor CPU operating at 3.00 GHz with 8 GB of RAM. Each problem size featured similar input parameters for comparing the results of Lingo and those of ALNS. The experiment was separated into three case problems, including a small problem size, medium problem size, and large problem size. For this work, the definition of each problem size depended on the number of tourism places, which was divided into three ranges: 1–39, 40–79, and 80, which are the small problem size, medium problem size, and large problem size, respectively. 
  5.1. Comparison Method 
The results for the three problem sizes were evaluated in terms of their effectiveness in finding solutions. The three sets of problem sizes, small, medium, and large, represented 10, 40, and 80 locations, respectively. Each problem size was tested with 5 instances. A comparison of the results found that the MALNS algorithm effectively found solutions for all problem sizes. In particular, both medium and large problem sizes showed a faster processing time with the MALNS algorithm than the Lingo program. The comparison results for all problem sizes are shown in 
Table 2. The comparative results for the MALNS algorithm and Lingo program show the global optimal solutions for both methods for small problems. The solutions display evaluations of routes with the lowest total cost of travel and the maximum total satisfaction rating for travel. In addition, the processing times were similarly fast, displaying no differences between the solutions of both methods because of the low number of tourism places when considering small problem sizes. The results for both the total travel cost and total satisfaction rating for travel exhibit slight differences between the MALNS algorithm and the Lingo program for medium problem sizes, where the Lingo program showed longer processing times than the MALNS algorithm. This is due to the increased number of tourism places considered, representing an extended, complex, and difficult problem for the Lingo program in terms of finding a global solution. The Lingo program showed an average processing time of 31.42 h, while the MALNS algorithm showed an average processing time of 1.08 min. Therefore, the fast effective processing of the MALNS algorithm is the most suitable route planning when the number of tourism places is increased and, with it, the complexity of the travel route. 
For large problem sizes, the Lingo program could not find a global solution in an adequate amount of time, where the expected time for processing was more than 72 h because of the large amount of data to be considered. The Lingo program showed upper bounds for both the total travel cost and total travel satisfaction rating. The MALNS algorithm was very effective and fast for finding solutions, with a processing time of 2.05 min. While the results for the MALNS algorithm did not find a global optimal solution, the response solution was an acceptable solution. The Lingo and MALNS algorithm results are further compared in 
Table 3. The differences between the methods in terms of effectiveness were calculated by Equation (16):
The different percentages of the two methods for all problem sizes show less different percentages. The total average travel cost percentage difference was zero or otherwise insignificant for small problems.
The MALNS algorithm showed a slightly inferior result of 0.18% for medium problems and 0.05% for large problems. The percentage difference for the total average travel satisfaction rating was also zero or insignificant for small problems. A slightly inferior result of 0.24% achieved for medium problems, and a result of 0.21% was obtained for large problems. Therefore, the percentage of the average differential gap of the method is 0.11% in Lingo program and MALNS comparison.
For the MALNS algorithm, the processing time percentage difference was 3% for small problems. Medium and large problems showed dramatic decreases in the processing time percentage differences of 99.94% and 99.95%, respectively. Therefore, the MALNS algorithm exhibits a good solving ability for complex problems, finding effective solutions with a fast processing time. The results in 
Table 2, showing the total travel cost, total satisfaction rating for travel, and processing time for all problem sizes, were analyzed by paired t-tests to evaluate the performance of the two methods.
The paired 
t-test approach considered 0.05 as the level of significance. The statistical results are shown in 
Table 4 and display results with 
p-values with significance levels over 0.05 for the total travel cost and total satisfaction rating for travel for all problem sizes. For the processing time, the 
p-values for small problems were greater than 0.05, and the two methods were not significantly different in terms of their processing times. The processing times for medium and large problems show 
p-values lower than 0.05, meaning that the processing times for the Lingo program and MALNS algorithm were significantly different. Therefore, the MALNS algorithm exhibits a strikingly effective solution finding process, and the result is not different from an exact method based on the Lingo program.
Furthermore, the differential percentage of each instance shows an extremely weak percentage of the gap error of the total travel cost value. The MALNS algorithm shows high performance in tourism planning problem-solving. However, the MALNS algorithm was compared with the LNS algorithm and the ALNS algorithm for the efficacy testing. Destruction and a reconstruction approach mean the Random removal and the Greedy insertion, respectively, were employed in the LNS algorithm of the problem solving-solution for the best solution finding. Each round of the best solution in the LNS algorithm has no acceptant criterion. 
For, the ALNS algorithm randomized one approach from three destructions and three reconstructions for each round the best solution finding. The three destructions are Random removal, Worst removal, and relative removal. The three reconstructions are Greedy insertion, Regret-H insertion, and Node swap. In ALNS process, The SA approach was used as the acceptant criterion for the best solution. 
The result of the MALNS algorithm was compared with the result of LNS algorithm and ALNS algorithm in this problem solving, as shown 
Table 5. From the solution finding, found that the MALNS algorithm display higher performance than LNS and ALNS algorithm for all problem size. The MALNS algorithm give the lowest average total travel cost in all problem size as shown in 
Figure 10a, and the highest average total rating of travel satisfaction as displayed in 
Figure 10b. 
For comparison of the average differential gap percentage, the MALNS algorithm shows higher efficacy than the LNS algorithm in all problem size. In the average differential gap percentage, the MALNS algorithm display lower total travel cost than LNS algorithm around 3.98% for small problem size, 6.48% for medium problem size and 7.14% for large problem size. The total rating of travel satisfaction shows the 5.75% average differential gap percentage of small problem size, 5.00% of medium problem size and 6.36% large problem size. MALNS algorithm gives better valuation than LNS algorithm. In comparison of the average differential gap percentage, MALNS algorithm exhibit higher performance than the ALNS algorithm in all problem size. The average differential gap percentage of MALNS algorithm gives lower total travel cost than ALNS algorithm about 1.10% for small problem size, 1.40% for medium problem size and 1.87% for large problem size. The MALNS algorithm also gives the higher total rating of travel satisfaction than ALNS algorithm about 1.68% for small problem size, 2.73% for medium problem size and 1.10% for large problem size. 
Therefore, the MALNS algorithm applies the new approach of reconstructive operation and increases the acceptance criterion in the solution finding process, which is a highly effective expansion of optimal solution finding. In addition, the MALNS algorithm exhibits a high performance, compared with the other algorithm, as shown in 
Table 6, which shows some sample algorithms used in tour group problem solving.
  5.2. Case Study Area
In the case study, two categories of tested case study, considering family tourism and non-family tourism route planning problems, were solved using the MALNS method for different result considerations. The similar data inputs for the two types of testing included 2 fixed points in a start-to-end trip, 88 tourism places, 29 hotels, 5 members, 1–10 rating scores for tourism place satisfaction identification, and the fixed day of touring was 3 days. The dissimilar tested data inputs are the factors of the genders and ages of family members, and the total number of family members was determined to be five. The factors of gender and ages are not used for non-families, as shown in 
Table 7. 
This is because the number of tourists of non-family tourism is fixed to zero person. The two categories of data were analyzed using the MALNS algorithm, which has the objective of maximum family member satisfaction and the lowest travel cost. The route planning result of two categories of case studies is shown in 
Table 8. The family tourism route design for achieving the highest total satisfaction rating included three travel routes. These routes exhibited the highest total ratings for total travel satisfaction, with scores of 44.57. Each travel route displays four positions for points of interest in each day. The first-day tour begins at point E1, which is an airport. The tourism points for visiting are T17, T21, T51, and T40. The point of the end trip is H7, which is accommodation. The satisfaction per person of the first route shows the highest satisfaction rating at 5.16 score of family member age range at 1–24 years because this route specifies this family member age range as the priority. For other family member age range show no different satisfaction score of the family member in the travel route. The second day of the tour travel starts at point H7, and the tourism places are T34, T2, T4, and T16. The H10 point is the point of the end tour, which is the accommodation on the second day. The satisfaction per person of the second route displays the highest satisfaction rating at 4.24 score of family member age range at >60 years due to this second route set the family member age range at >60 years as the priority of tourism. The final tour day commences at the H10 point of the tour and continues through the T23, T20, T11, and T3 visiting points. The tour ends on the final day at the E2 point, which is a bus station. An individual satisfaction of the final route exhibits high satisfaction rating at 3.87 and 3.69 of family member age range at 36–45 years and 46–59 years respectively due to this route define both family member age range as the priority. The travel routes featured the minimum travel cost and distance, which were 823 baht and 486 km, respectively. The pattern of travel for the three routes is shown in 
Figure 11a. 
Non-family route planning shows three different routes in family tourism. Because the main factor considered in non-family route planning is the lowest travel cost, the algorithm analyzed popular places with the lowest travel cost. The lowest travel cost of a tourism trip is 428 Bath and zero satisfaction, because satisfaction is not necessary for non-family route planning. The non-family tourism route shows three routes by the number of fixed tourism days. The first day of the tour begins at point E1, which is an airport. The places for sightseeing are T21, T17, T18, and T40, and the first day of the trip ends at H19, which is an accommodation point. The second day starts at point H19, and the sightseeing places are T11, T29, T26, and T66, respectively. The H11 lodging point is the end tour point of the second day. The final tour day starts at point H11 and continues through tourism points T25, T24, T15, T22, and T57. 
The tour terminates at point E2 on the final day, which is a bus station. The total travel distance is 285 km, which is the lowest travel distance for non-family tourism route planning. The pattern of the three routes is shown in 
Figure 11b.
Therefore, the MALNS algorithm shows that it can create an effective route design for family tourism and non-family tourism. This is because the MALNS algorithm can adjust the diversity factor value required by tourists and the optimal route planning generation. In family tourism, route design is particularly difficult due to the differences in terms of the gender and age ranges. The MALNS algorithm can be used in routing design and optimal routing to maximize family member satisfaction.
In addition, this program can include the selected initial point, tourism place, and endpoint, with the requirement that tourists are flexible and that a fast processing is achieved in tour route planning based on the MALNS algorithm.
  6. Conclusions and Future Research
This work has considered the family tourism route planning problem. The objective here was to maximize the overall satisfaction rating regarding tourism places with the lowest travel cost. The MALNS algorithm was applied to find optimal solutions for overall satisfaction rating and travel cost, and the tested results were compared with the results for an exact method using the Lingo program. The comparison of the two methods showed similar results for small problem sizes. For medium and large problems, the results of the MALNS algorithm showed a good performance, and a similar performance was found for the Lingo program. The Lingo program showed a greater processing time than the MALNS algorithm. The MALNS algorithm showed a dramatically different processing time. With the MALNS algorithm, the processing time was reduced by 99.94% for medium problem sizes and 99.95% for large problem sizes. The statistical testing of the MALNS algorithm and the Lingo program for all problem sizes showed insignificantly different results in terms of overall satisfaction and travel cost; however, the two methods displayed significantly different processing times for both medium and large problem sizes. Therefore, the MALNS algorithm is an appropriate method for family tourism route design and presents effective solutions with a fast processing time.
The computational result shows that MALNS is effective for finding optimal solutions, meaning that including the four destroy and four repair operators is the best combination. Normally, traditional ALNS includes only one acceptance method to make a decision as to a new solution. However, we design three acceptance criteria. The number of operators and acceptance criteria indicate a high diversification level, which allows the algorithm to escape from the local optima. While it could possibly consume a high processing time, it is well worth the wait. Additionally, we modified the operators for the purpose of intensification, that is, to allow the algorithm to search for the best solution in the local optima. Therefore, the researchers can conclude that the good design of the algorithm plays an important part in the performance and contribution of the MALNS in this research.
In a case study, the MALNS algorithm balanced route planning, while considering the desires of different family members and finding the lowest of traveling cost and distance. The routing proposed in the case study would result in 823 baht for the total traveling cost and a total travel distance of 486 km, which is approximately the minimum traveling cost and distance, with the maximum number of visits to interesting tourist locations, amounting to a travel satisfaction score of 44.57. Therefore, the MALNS method can solve the family tourism route planning problem and provide highly efficient solutions for family members with dissimilar satisfaction rates. The empirical results found for the MALNS algorithm here are very beneficial in terms of software application generation in tourism route planning, which is the problem of finding optimal routes with the maximum overall rating satisfaction of family members and lowest travel cost. Therefore, the MALNS algorithm can be suitable for tour route planning, irrespective of age, gender, and satisfaction differences between family members and the number of tourism places in each route. The balancing of satisfaction and number of tourism places is a target of family tour route planning, and the MALNS algorithm shows high performance in achieving this balance.
However, the MALNS algorithm can be applied to various models of tourism route planning, despite the differences in the characteristics of the problem. When some factors have been added into the model, such as single parents and many family generations and age ranges, we can adjust the model by adding more indices and parameters, then solve using the MALNS in the same way. The aspects of the problem are common to every family. Thus, we believe that the model can be implemented in different parts of the world.
The application of the case study based on the MALNS algorithm allowed for the generation of the software application model and shows an example of travel routing in 
Figure 12. This software application model is easy to use, flexible, and outcomes are produced very quickly. In addition, this software can identify the requirements of tourists to achieve optimal routing, and it uses less time in the routing process. The application of family tourism planning based on the MALNS algorithm will be used to plan tourism routes for a range of families in support of tourism in Burirum Province, Thailand. The application can provide optimal travel routing with the lowest traveling cost and maximum number of tourism places. It therefore allows tourists to see more sightseeing points, which increases their satisfaction. There is a family tourist influx into Burirum Province. Therefore, the local economy is spending more on tourism, thus increasing the income of the local people and progressing toward a circular economy.
In the future, the MALNS algorithm will be used in combination with the full function of and tourism data provided by the software development of an application used on mobile phones and tourism webpages in Thailand. The application will support family or group tours, and tourists will be able to easily and independently plan tourism routes.