Computational Algebra for Commodity Parallel Machines (The ParaGAP Project) Further Particulars
نویسندگان
چکیده
algebra is one of the most powerful unifying paradigms of twentieth century mathematics. A vast field of research in its own right, it is also a key tool in other areas of mathematics, in physics, in chemistry and in computer science. In the last thirty years, computational tools have played an increasing role in the development and application of abstract algebra, until today, computational algebra systems are in widespread use across a range of theoretical and applied disciplines. GAP (Groups, Algorithms and Programming) [34] is a leading computational algebra system, and the leading open source system. It supports computation in many areas of algebra algebra with particular emphasis on group theory. GAP has a well established international user base, and is used for teaching, research and commercial applications including cryptography, crystallography, the study of quantum computing, and applications in many areas of mathematics. Many GAP users need to perform very large computations, whether in theoretical development, such as exploring very large groups, or in applications, such as managing the symmetry in very large searches. This creates a requirement for GAP to support a range of low cost high performance computing solutions, which, today, inevitably means multi-processor systems of one form or another. On the other hand, since most GAP users are not programming specialists, let alone parallel programming specialists, it is essential that details of the parallel implementation: distribution of the computation, messagepassing, synchronization and so on be hidden from the user. The ParaGAP project is a 3-year project to link frontend GAP applications with a high-level, portable and welldeveloped parallel back-end, the GUM implementation [37] of Glasgow Parallel Haskell (GpH) [37]. This will support high-performance computation via the established and popular GAP user interface on economical platforms such as multiprocessor workstations and Beowulf-style PC or workstation clusters. Such hardware is becoming increasingly available to the academic and general research community that forms the primary GAP user base. The two systems will be linked through a flexible general architecture offering the GAP programmer facilities for transferring appropriate types of data to and from GpH and for initiating general parallel computations in GpH. The interface will exploit the OpenMath standard, as appropriate. In order to validate this architecture, and to deliver benefits to end users, the project will develop and implement parallel algorithms for a number of “key sub-problems” which form core time-consuming steps in a very wide range of computations. Efficient algorithms for these will consequently be of very general benefit, even to GAP users who do not wish to do any new programming at all. The problems (see Section 6.1) have been selected to reflect a variety of parallel computations, varying, for example, in the regularity of the computational and/or data structures, in the balance of memory and processor requirements, and in load distribution patterns. In addition to the direct research results obtained through the parallelisation of these key sub-problems, we also anticipate that the project will deliver enhanced insights into the underlying sequential algorithms, that it will provide a valuable source of performance information for this complex and rarely studied class of parallel algorithms, and that the key sub-problems will serve as good motivating applications for researchers in functional programming. The ParaGAP project represents an equal inter-disciplinary collaboration between pure mathematicians, under the leadership of Steve Linton, a main developer of GAP, and computer scientists, under the leadership of Kevin Hammond, a main developer of GpH. 2 Aims and Objectives
منابع مشابه
Massively parallel computing using commodity components
The Computational Plant (Cplant) project at Sandia National Laboratories is developing a large-scale, massively parallel computing resource from a cluster of commodity computing and networking components. We are combining the bene®ts of commodity cluster computing with our expertise in designing, developing, using, and maintaining large-scale, massively parallel processing (MPP) machines. In th...
متن کاملComputational Algebra for Commodity Parallel Machines
algebra is one of the most powerful unifying paradigms of twentieth century mathematics. A vast field of research in its own right, it is also a key tool in other areas of mathematics, in physics, in chemistry and in computer science. In the last thirty years, computational tools have played an increasing role in the development and application of abstract algebra, until today, computational al...
متن کاملA fixed and flexible maintenance operations planning optimization in a parallel batch machines manufacturing system
Scheduling has become an attractive area for artificial intelligence researchers. On other hand, in today's real-world manufacturing systems, the importance of an efficient maintenance schedule program cannot be ignored because it plays an important role in the success of manufacturing facilities. A maintenance program may be considered as the heath care of manufacturing machines and equipments...
متن کاملNavier-Stokes Computations on Commodity Computers
In this paper we discuss and demonstrate the feasibility of solving high-fidelity, nonlinear computational fluid dynamics (CFD) problems of practical interest on commodity machines, namely Pentium Pro PC’s. Such calculations have now become possible due to the progress in computational power and memory of the off-the-shelf commodity computers, along with the growth in bandwidth and communicatio...
متن کاملTwo meta-heuristic algorithms for parallel machines scheduling problem with past-sequence-dependent setup times and effects of deterioration and learning
This paper considers identical parallel machines scheduling problem with past-sequence-dependent setup times, deteriorating jobs and learning effects, in which the actual processing time of a job on each machine is given as a function of the processing times of the jobs already processed and its scheduled position on the corresponding machine. In addition, the setup time of a job on each machin...
متن کامل