Рус Eng Cn Translate this page:
Please select your language to translate the article


You can just close the window to don't translate
Library
Your profile

Back to contents

Software systems and computational methods
Reference:

Development of an Application for Design Automation in KOMPAS-3D: Quality Control Table for Base Metal

Savelieva Yuliya Olegovna

ORCID: 0009-0004-8971-4110

PhD in Technical Science

Associate Professor; Branch of SamSTU in Syzran; Samara State Technical University

446001, Russia, Samara region, Syzran, Sovetskaya str., 45, office 404

Savelieva_yu_ol@mail.ru
Il'in Artem Vladimirovich

Student; Branch of SamSTU in Syzran; Samara State Technical University

446001, Russia, Samara region, Syzran, Sovetskaya str., 45

Savelieva_yu_ol@mail.ru
Luk'yanov Aleksandr Aleksandrovich

Student; Branch of SamSTU in Syzran; Samara State Technical University

446001, Russia, Samara region, Syzran, Sovetskaya str., 45

Savelieva_yu_ol@mail.ru
Milihina Kseniya Mihailovna

Student; Branch of SamSTU in Syzran; Samara State Technical University

446001, Russia, Samara region, Syzran, Sovetskaya str., 45

Savelieva_yu_ol@mail.ru

DOI:

10.7256/2454-0714.2025.1.73073

EDN:

VBHBRP

Received:

18-01-2025


Published:

03-04-2025


Abstract: The complexity of compiling quality control tables for base metal TB1 in order to design nuclear power products arises from the necessity to take into account a plenty of requirements from various sources (which may overlap or complement each other): for example, standards such as industry standards (IS/OST), building codes (BC/SNiP), technical specifications, customer requirements, internal rules for their completion, and other regulatory documents. Incorrectly prepared documents submitted to an authorized quality control organization (an entity authorized to conduct conformity assessment in the form of acceptance testing of products intended for use in components of nuclear energy facilities in the Russian Federation) result in financial and time losses for the developer, as well as difficulties in further product acceptance. This paper discloses the development process of a user application (library) that enables the automatic generation and construction of a quality control table for base metal TB1 on the basis of a drawing document in KOMPAS-3D. The application code (library) for KOMPAS-3D CAD is developed using Delphi, and it implements automated generation of tables TB1 necessary in designing equipment for the nuclear energy sector. One of the key characteristics of a modern engineering simulation system is the ability to integrate automation, for instance, by using subsystems to expand the software package's capabilities, such as user applications (custom programming libraries). This paper formulates the main requirements for the functionality of the user application (library) for KOMPAS-3D. The application code enables reading data from an assembly file opened in KOMPAS-3D, creating a new drawing document, generating a table according to TB1 requirements, and filling it with data from the assembly document.


Keywords:

quality control table, base metal, TB1, KOMPAS-3D, application, custom library, software library, design automation, Delphi, design library creation tools

This article is automatically translated. You can find original text of the article here.

Introduction. The effectiveness of the COMPASS-3D software package for three-dimensional modeling, creating drawings, and specifications is determined by the use of not only basic tools for implementing the target function, but also the ability to expand the functionality of the software package using user-applied applications and user software libraries [1-5]. The COMPASS-3D CAD already provides automation tools such as embedded applications libraries are plug–in software modules, the number of which differs in different versions, allowing to reduce design time due to the simplicity and high speed of creating and using standard elements based on basic functions [6-8].

Despite a significant number of libraries (a design library containing more than two hundred parametric images of typical elements: various fasteners, bearings, profiles, pipeline connection elements, etc.; libraries of gearboxes, electric motors, fasteners, grooves, springs, die parts, molds, materials and grades, and others [6]), there are always enough of them to implement the objective function. For example, a particular library is not freely available, or companies develop products based on their own regulatory documents. Ready-made modules for developing applications in COMPASS contain a description of interfaces in accordance with the syntax of a specific programming language.

At enterprises, when designing and manufacturing nuclear power equipment, base metal quality control tables (TB1) are compiled, on the basis of which quality programs are developed. Quality control tables that establish the need to perform specific control operations are assigned certain codes: "TB1" - tables of quality control of the base metal; "TB2" - tables of quality control of welded joints and surfacing; "TBZ" - tables of quality control of production welded joints on production control welded joints [9].

Projects using TB1 are accepted by an authorized organization for quality control programs [10-11]. The quality control program for nuclear power products, consisting of a text part and quality control tables, defines the principles and requirements for the quality of the designed assembly units, products, equipment and pipelines, installations during the manufacturing process [9].

The compilation of TB1 is a complex process, since the design contractor must rely on various standards, for example, industry standards (OST), state standards, building codes (SNiP), technical specifications and other regulatory documents, acting in accordance with the requirements of the main designer – customer. Incorrectly drafted documents submitted to an authorized quality control organization entail financial and time losses for developers, as well as difficulties in further delivery of the product.

The object of the study: the table of quality control of the base metal (TB1).

The subject of the study: the procedure for developing an application user application.

Setting the task. It is necessary to develop a custom application for Compass-3D that allows you to automatically generate TB1.

Basic requirements for the functionality of a user application:

1. The launch takes place from the assembly in COMPASS-3D via the command panel or via the "Applications" - "TB1" buttons.

2. After launching, the program window displays a table with the parts received from the assembly (as well as the details of all subassemblies), their number, designation, material and the corresponding standard.

3. The program should have functionality that allows the designer to change all the graphs of the table, select those positions that will be built in the table in the drawing, add new positions, delete added ones, cross out the text and the ability to divide the table into several sheets.

4. The application should provide for the selection of control operations for assembly materials, operations with ciphers, as well as the addition of new operations, followed by their storage in the program memory.

5. The ability to select characters for operations by clicking on the corresponding cell.

6. By clicking on the corresponding button, a drawing document should be automatically created, with a constructed table with all the changes made by the designer to the program interface.

7. The ability to add the functionality of reading data from a drawing to make changes through the program interface.

In this work, TB1 is constructed in accordance with OST 108.004.10-86 [9] and the internal standards for their completion from the customer. The application's program code is written in Delphi.

The procedure for developing an application user application. A "blank" is being created for the COMPASS application (library):

1) In Delphi, the File - New - Other command is executed. In the New Items window that appears, with all possible Windows application templates and Delphi files (executable exe file, console application, Delphi form or component, etc.), select Dynamic-Link Library on the Delphi Projects tab.

2) Files are connected that contain descriptions of all API interfaces, version 7. To do this, run the Tools - Options – Library command, and specify the path to the include directory in the COMPASS folder in the Library path column.

3) The Projects - options - Application command is executed. The extension is entered in the Target file extension field.

4) A new module and a 64-bit platform must be added to the project, the project is saved and compiled.

5) In order for the "blank" to interact with COMPASS, it must have the following functions: LibraryEntry (entry point to the library), LibraryId (returns the library ID), GetNewKompasAPI (getting access to a new API; optional, but convenient because you don't have to write an API check every time). These functions must be exportable, i.e. exportable, so that the COMPASS system can see and call them; for this reason, they are placed in the exports section.

It is necessary to read the data from the assembly. All the basic procedures and functions of the application's interaction with COMPASS-3D are located in the UstatementMaterals module.

As in all libraries, the LIBRARYENTRY procedure is used for COMPASS-3D, the code is shown in Fig. 1.

Рис 1.jpg

Fig. 1. LIBRARYENTRY procedure

The procedure of the CreateLineDimension module, which checks the active document (if the assembly is running (Fig. 2), then the data is considered from the assembly (a thermal pistol is given as an example of a test assembly, if a drawing is from a drawing), is shown in Fig. 3. Functions are called that read data from the assembly and from drawing, GetAsemblyComponents, and GetDrawingComponents (Fig. 4), all received data is entered into the ComponentsList (Fig. 5).

Using the FormCreate procedure, a form and its components are created (Fig. 6 and Fig. 7). From ComponentsList, data is entered into the interface of the TreeList component application (Fig. 8).

Fig. 2. Test assembly

Рис 3_.jpg

Fig.3. Procedure of the CreateLineDimension module

Рис 4.jpg

Fig.4. Implementation of GetAsemblyComponents

Fig.5. Data read from the assembly

Рис 6 ч1.jpg

Fig.6. The FormCreate procedure (the beginning of the code)

Рис 6 ч2.jpg

Fig.7. FormCreate procedure (end of code)

Figure 8. Data read from the assembly in the application interface

The application window interface (Fig. 8) contains a panel with the following buttons:

1) "Create a table" is a call to the procedure responsible for forming the table in the drawing. After clicking this button, the CreateDrawingDocument procedure is started, which creates a drawing document and performs several checks (Fig.9, Fig.10). The procedure for creating a new sheet if the data does not fit on one sheet is shown in Fig. 11

создание таблицы ч1.jpg

Fig. 9. CreateDrawingDocument procedure (the beginning of the code)

создание таблицы ч2.jpg

Fig.10. CreateDrawingDocument procedure (end of code)

таблица если не уместилось.jpg

Fig.11. Procedure for creating a new sheet

The procedure for creating the table itself is shown in Fig. 12 - Fig. 14.

таблица ч1.jpg

Fig.12. The procedure for creating a table (the beginning of the code)

таблица ч2.jpg

Fig.13. The procedure for creating a table (continued code)

таблица ч3.jpg

Fig.14. The procedure for creating a table (end of the code)

2) "Add operations" - adding operations and their ciphers. When clicking on this button, a new "Operation Selection" form appears (Fig. 15), where the user selects the necessary operations or adds new ones. Clicking on "Add operation" opens a window with a form to fill out, in which the user enters the name of the operation and its cipher. You can cancel adding an operation using the Cancel button or by closing the active form. Clicking the "Ok" button starts the procedure for adding an operation to the form, the operation is added to the end of the list and displayed sorted by cipher.

Fig.15. The "Operation selection" form

Clicking on the "Apply" button causes the "Select Operations" form to close and operations are added to the main form (Fig. 16).

Fig.16. Added operations in the application interface

Clicking on a cell under an operation results in a drop-down list with symbols to insert into that cell.

All operations are stored in a text file located in the application directory (Fig. 17). At startup, the application reads all operations and enters them into the form. After closing, the operations are saved in a file. OperationList.txt .

Fig.17. The file with operations

The procedures that are triggered after clicking on the "Apply" button are shown in Fig. 18, Fig. 19.

после применить ч1.jpg

Fig.18. Procedures triggered by clicking on the "Apply" button (the beginning of the code)

после применить ч2.jpg

Fig.19. Procedures triggered by clicking on the "Apply" button (end of code)

3) "Compare with assembly" - comparison of the read data with those that are currently in the assembly, the different data is highlighted in blue.

4) "Add row" - adding a new row above the selected one. This button has a drop-down list with additional buttons for editing data ("Add row from bottom", "Start from a new sheet", "Delete row", "Select all items", "Cross out text in row", "Cross out text in cell").

Development results. As a result of sequentially following the steps described in the application development procedure, the user will receive a new drawing document with a generated quality control table for the base metal TB1 (Fig. 20). For the example shown in Fig.2, the table provides the following information and data: the name of the part or assembly unit, the number of parts, the designation of the drawing, the material (material, test group; designation of the standard), the name of the operation (input control of basic and assembly materials, semi-finished products and components; checking the availability and completeness of technological documents; control of metrological support of means of change; certification of managers and specialists; certification of supervisors; control of assembly and welding equipment, equipment and fixtures; testing of deposited metal for resistance against the formation of hot cracks).

Fig. 20. Example of a base metal quality control table

The developed user application application automatically reads data from the assembly file opened in COMPASS-3D, creates a new drawing document, builds TB1, and enters data taken from the assembly document.

Scientific novelty of the obtained results. The developed procedure for constructing the TB1 table in COMPASS-3D (in conditions of limited information about algorithms for compiling quality control tables in the public domain and difficulties encountered by project specialists who make up the design documentation of the TB1 table and, based on them, quality programs), unlike the known ones, allows for automatic construction.

Conclusion. The paper describes the procedure for developing an application-based user application for COMPASS-3D, which allows automated generation of a base metal quality control table (TB1). The implementation uses software code written in the Delphi software environment. This application can be used by enterprises (organizations) specializing in the design and manufacture of equipment for nuclear power plants.

The developed user application meets the criteria of flexibility, as well as speed, in terms of the possibility of making operational changes. The development process was carried out iteratively, which allowed us to expand the functionality. For example, as an extension of the code's capabilities, it may be possible to use a procedure for reading data from a single sheet (the active sheet is the sheet selected in the tree) – the application switches to the "TB1 Active Sheet" mode, in which the "Build table" button is replaced by the "Update data on the active sheet" button. With this mode, the user can easily change the data on just one sheet.

Due to the versatility of the program code, it is possible to use it not only for COMPASS-3D, but also for other CAD systems.

Also, as prospects for further use for projects to create application libraries for COMPASS-3D, the principles of writing program code for development procedures can be used as a basis, which is in the field of interests of both enterprises (for example, for existing designers, specialists improving their skills in the relevant field) and design bureaus, as well as educational institutions.

References
1. Norseev, S. (2013). Developing Applications for KOMPAS in Delphi. https://norseev.ru/books/kompas-delphi-2013/
2. Soshkina, D.E. (2022). Development of a User Library in KOMPAS-3D. Progressive Technologies and Economics in Mechanical Engineering. Proceedings of the XIII All-Russian Scientific and Practical Conference for Students and Youth, 34–36. Tomsk: TPU Publishing House.
3. Gusha, A.O., & Stasenko, T.D. (2023). On the Development of User Libraries of Standard Components for KOMPAS-3D in C#. Research and Development in Mechanical Engineering, Energy, and Management. Materials of the XXIII International Scientific-Technical Conference of Students, Graduate Students, and Young Scientists, 2(2), 268–270. Gomel: GSTU..
4. Terekhin, R.D., Folomkin, A.I. (2017). Development of Programming Libraries for Demonstrating and Constructing Intersection Lines of Various Surfaces. Technical Sciences – From Theory to Practice. Collection of articles from the LXXI International Scientific and Practical Conference, 6(66), 13–18. Novosibirsk: ANS "SibAK".
5. Reshetnikova, E.S., Savelyeva, I.A., & Svistunova, E.A. (2020). Geometric modeling and development of custom libraries in the design of engineering facilities. Software systems and computational methods, 1, 1–7. https://doi.org/10.7256/2454-0714.2020.1.32292
6. Kidruk, M.I. (2006). Constructor Libraries and Tools for their Creation in KOMPAS-3D System. Libraries, calculation modules, and reference books in KOMPAS-3D for constructors. CAD and Graphics. Mechanical Engineering, 1. Retrieved from https://sapr.ru/article/14850
7. Kidruk, M.I. (2006) Constructor Libraries and Tools for their Creation in KOMPAS-3D System. Do It Yourself or How to Create Your Library for KOMPAS-3D. CAD and Graphics. Mechanical Engineering, 2. Retrieved from https://sapr.ru/article/15598
8ASCON software users forum. http://forum.ascon.ru/index.php
9. OST 108.004.10-86. Industry Standard. Quality Control Program for Nuclear Power Products (effective from Jan. 01, 2007). Moscow: Amendment 12.
10. RD EO 1.1.2.01.0713-2019. Conformity Assessment in the Forms of Acceptance and Testing of Products for Nuclear Power Plants. Regulations (effective from Feb. 20, 2020). Replacing RD EO 1.1.2.01.0713-2013 "Regulations on Conformity Assessment in the Form of Acceptance and Testing of Products for Nuclear Power Plants." Moscow: Updated Jan. 01, 2021.
11. DWG.RU forum for discussing design, construction, and engineering issues in construction, architecture, mechanical engineering, and related fields. Retrieved from https://forum.dwg.ru/showthread.php?t=167100

First Peer Review

Peer reviewers' evaluations remain confidential and are not disclosed to the public. Only external reviews, authorized for publication by the article's author(s), are made public. Typically, these final reviews are conducted after the manuscript's revision. Adhering to our double-blind review policy, the reviewer's identity is kept confidential.
The list of publisher reviewers can be found here.

The presented article on the topic "Development of an application for design automation in COMPASS-3D: a base metal quality control table" corresponds to the topic of the journal "Software Systems and Computational Methods" and is devoted to the development of a user application for Compass-3D that allows you to automatically generate base metal quality control tables (TB1). The authors of the article indicate the main requirements for the functionality of a user application, among which: the launch takes place from the assembly in COMPASS-3D via the command panel or via the "Applications" - "TB1" buttons; after that, the program window displays a table with the parts received from the assembly (as well as the details of all subassemblies), their number, designation, the program should also be functional, allowing the designer to change all the graphs of the table, select those positions that will be built in the table in the drawing, add new positions, delete added ones, cross out the text and the ability to divide the table into several sheets; the application should provide a choice of control operations for assembly materials, operations with ciphers, as well as the addition of new operations, followed by their storage in the program's memory; it is possible to select characters for operations by clicking on the appropriate cell; by clicking on the appropriate button, a drawing document should be automatically created, with a constructed table with all the changes made by the designer to the program interface; it should be possible to add data reading functionality from the drawing to make changes through the program interface. In the article, the authors describe the procedure for developing an application user application for COMPASS-3D, which makes it possible to generate a quality control table for base metal (TB1) in an automated mode. To implement this, we used software code written in the Delphi software environment, which is used by enterprises (organizations) specializing in the design and manufacture of equipment for nuclear power plants. The style and language of the presentation of the material is quite accessible to a wide range of readers. The practical significance of the article is clearly justified. The article is quite structured - there is an introduction, conclusion, internal division of the main part. The disadvantages include the following points: there is no scientific novelty in the content of the article. There is no clear identification of the subject, the object of research. The article does not meet the minimum requirements in terms of volume (the volume must be at least 12,000 characters). It is recommended to clearly identify the scientific novelty of the research, formulate the subject and object. Increase the length of the article to 12,000 characters or more. It would also be advisable to add about the prospects for further research. The article "Development of an application for design automation in COMPASS-3D: a base metal quality control table" requires further development based on the above comments. After making amendments, it is recommended for reconsideration by the editorial board of the peer-reviewed scientific journal.

Second Peer Review

Peer reviewers' evaluations remain confidential and are not disclosed to the public. Only external reviews, authorized for publication by the article's author(s), are made public. Typically, these final reviews are conducted after the manuscript's revision. Adhering to our double-blind review policy, the reviewer's identity is kept confidential.
The list of publisher reviewers can be found here.

The article is devoted to the development of an applied user application for automating the compilation of a base metal quality control table (TB1) in KOMPAS-3D CAD. The paper considers the creation of a software product that speeds up and simplifies the process of creating documentation in the field of designing equipment for nuclear energy. The author applies a software development method using the Delphi language. The article describes in detail the sequence of actions for creating and integrating a library for COMPASS-3D, interacting with its API, as well as automating mechanisms for working with assembly data. The software part includes a description of key procedures, such as reading data from an assembly, creating drawings, and editing tables. The process of designing and compiling quality control tables in the nuclear power industry is extremely important, since the quality of manufacture and safety of equipment operation depend on the accuracy and correctness of documentation. The development of such an application meets the current needs of the industry, as well as contributes to the acceleration and automation of complex engineering processes. This solution is relevant in the context of modern design and documentation requirements in the nuclear power industry. The scientific novelty of the work lies in the proposal of an automated approach to the formation of quality control tables in COMPASS-3D, which significantly improves accuracy and reduces documentation preparation time. Unlike existing solutions, this application allows you to dynamically change data during development and easily integrate new functionality into the application. The article is written in a clear and consistent style, accessible to the target audience, which includes both software developers and specialists involved in designing in COMPASS-3D. The work is logically structured: introduction, problem statement, description of development methods, implementation and results. The article is accompanied by detailed illustrations that help visualize the key stages of development. This makes the material not only theoretically significant, but also practically useful. The author has carefully selected the literature, including both fundamental works and modern research related to the development of applications for CAD COMPASS-3D. The bibliography reflects a variety of sources, which increases the scientific value of the work. However, to improve the level of work, it is recommended to add more relevant sources related to new technologies in the field of design automation and software development. The article contains no obvious weaknesses. The applied methodology and development demonstrate the author's high level of knowledge in the field of programming and design in COMPASS-3D. Possible improvements may relate to the details of data processing algorithms and their optimization, as well as the expansion of the application's functionality for use in broader contexts other than nuclear energy. The article is a valuable contribution to the development of software tools for automation of engineering processes in the nuclear power industry. The practical significance of the work is high, as the developed tool makes it possible to increase the efficiency of engineers, as well as reduce the likelihood of errors when compiling quality control tables. The work can be recommended both for specialists in the field of design and for scientists involved in the development of software systems for engineering tasks. The article may be of interest to a wide audience, including both professionals and students studying CAD software. The work deserves publication, given its scientific significance and practical usefulness. It is recommended to accept the article for publication with minor improvements related to improving the analysis of existing solutions in the field of design automation and expanding the functionality of the described application.