RESEARCH ARTICLE

## Hardware/Software Co-Design Advances for Optimizing Resource Allocation in Reconfigurable Systems

G. Frincke<sup>1</sup>, Xe Wang<sup>2\*</sup>

<sup>1,2</sup>Department of Electrical and Computer Engineering, University of Denver, Denver

| Keywords:<br>Co-Design Techniques;<br>Hardware Optimization;<br>Resource Allocation;<br>Reconfigurable Systems;<br>Software Optimization;<br>System Efficiency | <b>Abstract</b><br>In the phenomenal evolution of computing systems, being able to adapt and work efficiently has become a most important attribute. However, at the cutting edge of this technological revolution is hardware/software co-design for reconfigurable systems. By merging the processing power of customizable hardware with the flexibility of software, this breaks new ground in system optimization and resource allocation, without the loss of real hardware. We will dive into this interesting horizon and uncover how co-design methodologies change the landscape of modern computing to unimaginable levels of                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Corresponding Author Email:<br>wan.gxe@du.edu<br>DOI: 10.31838/RCC/02.02.03                                                                                    | performance and versatility. With its ever increasing computational demand,<br>the ability to dynamically allocate resources and reconfigure system archi-<br>tectures on the fly is turning out to be a game changer. The principles of<br>hardware/software co-design have been applied to real world problems in<br>a range of different domains from embedded systems to high performance<br>clusters. This paper is intended to serve as a comprehensive overview of<br>the latest developments, methodologies, and real world applications of this<br>ground breaking approach to system design. Leaving behind the traditional<br>hardware and software partitioning, coopting the concept of cutting edge<br>algorithms for task partitioning and scheduling from machine learning to |
| <b>Received :</b> 01.01.25                                                                                                                                     | those devising scheduling policies for hardware, studying the synergies be-<br>tween hardware and software components, we present the synergies of re-<br>configurable computing platforms and hardware implementation. Together,<br>let's walk you through this exciting journey of optimized resource allocation<br>where hardware and software begin to intermingle, leading to systems that<br>are more powerful, efficient and adaptable than ever before.                                                                                                                                                                                                                                                                                                                               |
| <b>Revised</b> : 28.03.25                                                                                                                                      | How to cite this article: Frincke G, Wang X (2025). Hardware/ Software                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Accepted : 17.05.25                                                                                                                                            | Co-Design Advances for Optimizing Resource Allocation in Reconfigurable Systems. SCCTS Transactions on Reconfigurable Computing, Vol. 2, No. 2, 2025, 15-24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## HARDWARE/SOFTWARE CO DESIGN

Hardware software co design is a paradigm shift from the normal segregated way of system development to an integrated and holistic method. The design of hardware and software components at the same time offers high interaction optimization and helps improve overall system performance, forming this innovative strategy. Co-design is based at its core on using the strengths of hardware and software to create systems that are greater than their parts. Designers are able to consider the full system architecture from the outset so that decisions on which system functionalities should be implemented in hardware for maximum efficiency and which should be implemented in software to maintain flexibility can be made.<sup>[1-5]</sup>

An important advantage of this method is it can cover a wider design space. Rather than being limited by fixed hardware specifications, the co-design is able to allocate resources dynamically according to the unique needs of the dependent application. The flexibility of having fully flexible software becomes critically important when the underlying hardware is reconfigurable to meet changing computational demands. Typically the co-design process can be broken down into several iterations of system specification, partitioning, integration, and verification. During the course of these phases, designers must carefully balance a number of competing requirements, e.g., performance, power consumption, cost, and timeto-market. Together, these factors are considered using co-design methodologies, which allow us to create more efficient and cost effective solutions than conventional design approaches.<sup>[6-9]</sup>

# RECONFIGURABLE COMPUTING IN THE ROLE OF

As a powerful paradigm which bridges the gap of the flexibility of the general purpose processors and the high performance of ASIC(Asspic), reconfigurable computing has been on the rise. The crux of this approach is the reprogrammable field programmable gate array (FPGA), a hardware platform which can be programmed to realize customized digital reconfiguration circuits. Hardware on-the-flv becomes possible, which then allows for a wealth of possibilities for system optimization. Unlike fixed hardware implementations, reconfigurable systems can be reconfigured to adapt the system architecture to the needs of specific computational tasks. Because of such adaptability, more effective use of resources can be achieved, resulting in significant performance and energy efficiency gains (Table 1).

Table 1: Advances in Hardware/Software Co-Design for Resource Optimization

| Advance                                       | Role in Optimization                                                                                                                                                                            |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Unified Design<br>Frameworks                  | Unified design frameworks combine<br>hardware and software design in a single<br>environment, allowing seamless coordi-<br>nation and efficient resource utilization.                           |
| Hardware-<br>Aware<br>Software<br>Development | Hardware-aware software development<br>ensures that the software is designed<br>with knowledge of the underlying hard-<br>ware, enabling more efficient execution<br>on reconfigurable systems. |
| Cross-Layer<br>Optimization                   | Cross-layer optimization targets multiple<br>layers (hardware, software, communica-<br>tion) simultaneously, achieving higher<br>performance by reducing inefficiencies<br>across all levels.   |
| Dynamic<br>Resource<br>Allocation             | Dynamic resource allocation involves<br>adjusting resources in real-time based<br>on workload, ensuring that the system<br>adapts to changes in processing demand<br>and usage.                 |

| Advance                           | Role in Optimization                                                                                                                                                                |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Task<br>Parallelization           | Task parallelization distributes tasks<br>across multiple processing units,<br>improving execution speed and<br>optimizing the use of available computa-<br>tional resources.       |
| Integrated<br>Simulation<br>Tools | Integrated simulation tools provide a<br>platform for testing and refining both<br>hardware and software components<br>together, improving system performance<br>before deployment. |

We believe one of the key advantages of reconfigurable computing is that it can exploit spatial and temporal parallelism. Designers can create highly optimized architectures focused on a particular algorithm or application by customizing datapath and processing element. Such levels of customization can lead to orders of magnitude improvements in performance when applied to computations of specific kinds. Furthermore, reconfigurable systems provide a unique combination of hardware acceleration spearheaded with software programmability. By using this hybrid approach, developers can use the power of the computationally intensive task in hardware while still being able to update and change algorithms through software updates. One thing I've found particularly useful in fast growing domains like machine learning and data analytics, where algorithms and models are constantly being improved and refined, is the synergy between hardware and software.<sup>[10-14]</sup>

## **RESOURCE ALLOCATION OPTIMIZATION**

Under the context of reconfigurable systems, resource allocation is of critical imOportance in hardware/software co-design. We want to distribute computational tasks and data to available hardware and software resources so as to maximize performance while minimizing power and other limits. A fundamental challenge in resource allocation is the inherent heterogeneity of modern computing systems. Typically these systems have an admixture of general purpose processors, specialized accelerators and the reconfigurable logic offerings with their merits and shortcomings. To determine what tasks to place where and when, and thus determine effective allocation strategies, we need to consider the unique characteristics of each resource type. More recently, dynamic resource allocation techniques have been adopted that enable systems to change their

#### G. Frincke and Xe Wang : Hardware/ Software Co-Design Advances for Optimizing Resource Allocation in Reconfigurable Systems



Fig. 1: Resource Allocation Optimization

resource allocation in real time as workloads and the surrounding environment change. Runtime monitoring and prediction algorithms are used in these approaches to optimize resource utilization continuously as a function of the current system state along with future expectations of system demand (Figure 1).

Another dimensions that deserves attention in resource allocation is data movement and communication between different system components. Placing tasks and their data to minimize communication overhead is important because data transfer is often a bottleneck to system performance. This challenge is addressed by techniques including data locality aware scheduling and intelligent caching strategies. In addition, energy aware resource allocation has attained huge importance - especially in mobile and embedded systems. Thus, designer can consider power consumption as well as performance metric to make the system seeking an optimum between computation capability and energy efficiency. It often uses techniques like dynamic voltage and frequency scaling (DVFS), or selective power gating of components which are not being used.[15-18]

### **PARTITIONING ALGORITHMS**

It is known that mechanisms for partitioning the tasks and functionalities between hardware and software components are of paramount importance in hardware/software co-design. The goal of these algorithms is to provide the best combination that among system performance ensures different constraints, for example, power consumption and

area utilization and cost. Graph based algorithms are one popular way to partition. This method treats the system as a directed acyclic graph (DAG), consisting of nodes which represent tasks or computational units and edges which represent data dependencies or communication between nodes. Then, the partitioning problem is reshaped as a graph cutting problem, balancing computational load while minimizing cost incurred by the edges across hardware and software domains (Table 2).

Recently, heuristic algorithms have been growing popular because they provide near optimal solutions within reasonable times for complex partitioning problems. Hardware/software partitioning has been applied to a variety of techniques including simulated annealing, genetic algorithms and tabu search that provide a good trade off between solution guality and computational complexity. Having seen this, research has emerged in machine learning based approaches to partitioning. The use of these algorithms leverages historical data and runtime feedback to learn how to make intelligent partitioning decisions that change over time to cater to changes in system behavior and workload characteristics. Specifically reinforcem ent learning has been showing promise in this domain, which is the capability of systems to learn to continually improve their partition interpreting strategies over time. With the increased need to optimize multiple conflicting criteria simultaneously, multi objective partitioning algorithms have become an important element of the designer's repertoire. These algorithms take into account performance, power consumption,

|                                        | Table 2: Optimizing Resource Allocation in Reconfigurable Systems                                                                                                                |  |  |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Technique                              | Optimization Benefit                                                                                                                                                             |  |  |
| Resource Over-<br>Provisioning         | Resource over-provisioning ensures that sufficient resources are available to meet peak demands, avoiding bottlenecks and improving system reliability.                          |  |  |
| Demand-Based<br>Resource Scaling       | Demand-based resource scaling dynamically adjusts the amount of resources allocated based on real-time system demand, ensuring optimal resource usage.                           |  |  |
| Predictive<br>Resource<br>Management   | Predictive resource management uses forecasting techniques to anticipate resource needs and allo-<br>cate resources accordingly, improving system responsiveness and efficiency. |  |  |
| Resource<br>Contention<br>Management   | Resource contention management reduces conflicts and ensures that multiple processes can access shared resources without causing delays or system failures.                      |  |  |
| Energy-Aware<br>Resource<br>Allocation | Energy-aware resource allocation ensures that resources are allocated efficiently to minimize power consumption, balancing performance with energy savings.                      |  |  |
| Load Balancing<br>Strategies           | Load balancing strategies distribute workloads evenly across available resources, preventing any single resource from being overwhelmed and ensuring efficient system operation. |  |  |

reliability and cost, and produce sets of Pareto optimal solutions, representing different trade offs between these objectives. Such partitioning strategy allows designers to achieve more flexibility in selecting a strategy that matches their own requirements and constraints.<sup>[19-25]</sup>

## METHODS OF INNOVATIVE SCHEDULING

Scheduling is an important hardware/software codesign problem since it must effectively schedule tasks that may be executed on resources to meet timing and dependency constraints while also maximizing efficient use of available resources. With the advances in systems being more complex and heterogenous, we see the need for advanced scheduling techniques to the challenges of modern computing environments. Because of its simplicity and effectiveness, list scheduling algorithms are still a popular choice for the many co-design applications. This algorithms arrange the tasks according to different metrics, for example critical path length, communication costs, etc., based on resource requirements. List schedulers have this capability through maintaining a dynamic priority list that allows them to make quick decisions about task allocation and execution order as system conditions change in real time.<sup>[26-28]</sup>

Recent years have witnessed a growing interest in hierarchical scheduling for large scale systems with many levels of parallelism. Importantly, these techniques break the scheduling problem into a hierarchy of sub problems that facilitate better management of complex task graphs and heterogeneous resources. Hierarchical scheduling strategies combine global and local scheduling strategies, balancing system optimization and fine grained resource management. The probabilistic scheduling methods provide a powerful tool for dealing with uncertainty in the execution times of tasks and the availability of resources. These techniques formulate statistical models of the variability in the scheduling outcomes, thus providing a more robust basis for decision making when the variability is present. For example, stochastic scheduling algorithms can produce schedules resistant to unexpected delays or failures of resources, thereby enhancing system reliability in general. As battery powered devices and green computing initiatives have become even more important, energy aware scheduling has grown in importance. Energy usage and more traditional performance metrics are taken into account, and these algorithms seek to minimize energy use without violating timing constraints. Energy aware schedulers often incorporate such techniques as dynamic voltage and frequency scaling (DVFS) to find a good compromise between performance and power efficiency.

## INTEGRATING HARDWARE AND SOFTWARE FEATURE

Hardware and software components are successfully integrated through hardware/software co-design. In this process interfaces and communication protocols are created in order to have efficient interaction

#### G. Frincke and Xe Wang : Hardware/ Software Co-Design Advances for Optimizing Resource Allocation in Reconfigurable Systems

between the different system elements to be done without too much overhead and with maximum overall performance. Managing different abstraction levels and design paradigms used in hardware and software development is one key problem in Hardware/Software integration. Usually designer do bridge this gap through the use of hardware abstraction layers (HALs) and device drivers to provide software with a standardized interface by which to interact with underlying hardware components. These abstraction layers enable to isolate software from hardware details, making the software more portable and maintainable. Effective data exchange between hardware and software components makes use of communication protocols. As with most cool things nowadays, high speed interfaces like PCIe and AXI have emerged as popular ways of connecting reconfigurable hardware accelerators to host CPUs; providing very low latency and very high bandwidth. In the case of embedded systems, protocols such as SPI and I2C offer of lightweight means of interfacing to other peripherals and sensors.

Memory management is a critical aspect of hardware software integration where system has a shared memory architecture. Cache coherence protocols or memory consistency models must be used to ensure data integrity as well as to synchronize hardware and software components. Since advanced memory management units (MMUs) and memory protection schemes may be used, conflicts are prevented and system reliability is increased. With the rapid rise of co-simulation and emulation tools, having them for the task of verifying that the integrated hardware and software components are working correctly is a must. By using these tools, designers can test the whole system in a virtual environment and find, and thus solve, problems before the system produces working prototypes. The process is further enhanced by hardware in the loop (HIL) testing techniques, whereby real hardware components are included in the simulation environment to generate more accurate results and faster iteration cycles (Figure 2).



Fig. 2: Integrating Hardware and Software Featur

### **DESIGN SPACE EXPLORATION**

Hardware Software co design is a process of combining hardware and software to produce machines with specified performance, power, and cost requirements. It is a design space exploration where different design alternatives must be systematically evaluated to identify the optimal solution. As discussed above, this of course is especially relevant in situations that arise when the reconfigurability of the hardware underlying the system leaves open the possibility for virtually any number of possible configurations. Multi objective optimization techniques, have been one of the common approaches to design space exploration. These techniques seek to find Pareto-optimal solutions marking the best compromise between the competing design objectives. While genetic algorithms and evolutionary strategies have proven effective at navigating large design spaces to generate diverse sets of solutions for designers to evaluate against their own priorities and constraints, we question whether this objective exposes a flaw in the genetic algorithms approach to design.

Design space exploration relies on analytical models, whose fast estimates of system performance and resource utilization avoid the need for time consuming simulations or prototyping. Typically these models make use of statistical methods, and machine learning algorithms to predict the system behavior in the light of important design parameters. Efficiently pruning the design space and concentrating on the most promising configurations from this efficient design space can be accomplished by combining analytical models with more detailed simulation tools. Design space exploration is enabled using rapid prototyping and FPGA based emulation. This facilitates fast hardware configuration implementation and testing to guide designers on realworld performance and resource utilization. Based on high level synthesis tools, and by employing modular design techniques, designers can perform rapid iteration of different architectural options and assess their impact on system level metrics. In recent years, machine learning has been used to assist design space exploration by utilizing artificial intelligence powers to navigate complicated design spaces quicker. In order to automate the exploration process and choose fruitful directions to search in, reinforcement learning and Bayesian optimization have been applied successfully, leaning on past design iterations. In general, these AI driven approaches can greatly decrease the effort and time expended in finding the best design solutions, especially when the system is large and complex.

## VERIFICATION AND VALIDATION STRATEGIES

The correctness and reliability of hardware/software co-designed systems is a major challenge, requiring effective verification and validation techniques able to cope with the complexity of integrated hardware and software parts. Traditional testing methods have limited capability when systems are made sophisticated, and new techniques are required for comprehensive evaluation of system behavior under different operational scenarios. Rigorous mathematical proof of system correctness has gained formal verification methods prominence in co design environments. Model checking and theorem proving provide designers means of verifying critical system properties for hardware and software components to guarantee the correct behavior of the system under all possible input conditions. Formal methods are computationally intensive, but they are very important for safety critical applications, where absolute correctness is what is required. Verification of the interaction between hardware and software components requires the use of co-simulation techniques. These approaches enable designers to simulate the entire system in a virtual environment and try out the integration of multiple elements early in the development cycle, before they are realized.

Mixed level simulation is supported by advanced co-simulation frameworks which use combinations of software models and highly detailed hardware descriptions which strike a balance between accuracy and speed. Hardware in the Loop (HIL) testing has taken a leading role as a powerful technique of validating jointly created systems in embedded or cyberphysical instances. HIL approaches have two advantages-first, by including the use of real hardware components in the testing environment, they can more accurately report results and pinpoint problems not detected by pure software simulations. This information is of particular value in verifying timing sensitive behaviours and the interactions of hardware and software. As the field of co-design moves forward, coverage driven verification strategies have become more important to corroborate that the system at large is fully tested. The approaches here build on metricized, sophisticated coverage metrics to guide generation of new test cases for parts of the design that were not exercised during testing. A built in advanced coverage analysis tool allows insight into both functional and architectural coverage, helping design engineers identify potential blind spots in verification efforts.<sup>[29]</sup>

## A COLLECTION OF CASE STUDIES AND REAL-WORLD APPLICATIONS FOR NETWORK DATA ANALYSIS

Real world application of hardware/software co design is examined for its practical benefits and the challenges. The co-design of hardware and software solutions enabled by these case studies are applied to many domains like embedded systems and high performance computing, showing the wide applicability and power of the integrated hardware/software solutions. Co design approaches have been used successfully in the field of image and video processing that resulted in efficient systems for real time applications. An example of one implementation that uses software tasks along with hardware accelerators is using a JPEG compression algorithm. So designers did this of course, by offloading computationally intensive operations like the Discrete Cosine Transform (DCT) onto reconfigurable hardware, and returning control and encoding to software, achieving significant speedups compared to pure software implementation. Not only did this hybrid approach increase performance, but it also provided more flexibility when adapting the system to accommodate different image set sizes and quality requirements.

Hardware/software co-design techniques have been successfully used to advance the field of wireless communications. Co-design approaches to the development of software defined radio (SDR) systems has enabled the creation of flexible, and efficient platforms suitable for supporting multiple communication standards. Merging computationally intensive signal processing algorithms in reconfigurable hardware and protocol stacks and control functions in software, these systems strike a balance between performance and adaptability. This flexibility is especially useful for fast moving fields, such as 5G and beyond, where new standards and protocols are always coming online. Hardware/software co-design has been a central driving factor in the development of the advanced driver assistance systems (ADAS) and especially autonomous vehicles in the automotive industry. Finally, these complex systems must rely on the simultaneous integration of many sensors, the real time processing of large masses of data, and sophisticated decision making algorithms.

With co-design approaches, efficient and scalable architectures have been created that can cope with these challenging requirements, whilst adhering to stringent safety and reliability standards. For example, designers have created ADAS systems that can adapt to changing driving conditions and scenarios by using reconfigurable hardware to accelerate computer vision and machine learning tasks and keeping the high level control logic in software. Hardware/ software co-design methodologies have also been used in the field of high performance computing (HPC) to solve increasingly complex and challenging scientific and engineering problems. Co-design approaches have been crucial to the development of exascale computing systems which require extreme power and performance and must be developed as a system. Through the intimate integration of hardware and software design concerns, researchers have been able to design system architectures, communication protocols, and programming models that achieve unparalleled performance and energy efficiency. The holistic ideas have resulted in the introduction of heterogeneous computing nodes consisting of traditional CPUs and specialized accelerators along with sophisticated runtime systems that dynamically resource based on application need.

## **FUTURE TRENDS AND CHALLENGES**

Since hardware/software co-design has been evolving over the years, several trends and challenges are ahead that shape the future of this field. What these developments portend is a thickening of the boundaries of what is possible in system design, as well as new obstacles that inventors and engineers will need to tackle. One of the significant trend is that the use of artificial intelligence and machine learning techniques in co design methodologies is growing. Today's Al driven design space exploration, automated partitioning and intelligent resource allocation algorithms allow the designers to deal with highly complex systems. Although these AI-based tools have proven to be valuable additions to the design flow, their large scale integration, their reliability and explainability are open challenges. Hardware/software co-design is facing opportunities and challenges in the context of heterogeneous computing architectures. With more disparate resources coming into play: CPUs, GPUs, FPGAs, specialized accelerators, etc., the task of optimizing where and how to best run a workload on this heterogeneous resource mix gets harder and harder. There is an active research in developing unified programming models and runtime systems that can easily take advantage of heterogeneous platforms.

The design of system is becoming more and more important in terms of energy efficiency and sustainability. At the same time as computing systems become an area of increasingly intense scrutiny for their environmental impact, co-design methodologies are evolving toward also integrating power optimization with traditional performance metrics. Such a shift has created new opportunities for advancements in energy aware design techniques, from low power circuit designs to intelligent power management strategies at the system level. Hardware / software co design is enabled by the convergence of edge computing and Internet of Things (IoT) technologies, creating new opportunities and new challenges. With more and more processing moving toward the edge of networks, designers will need to design efficient and adaptive systems that can operate in constrained power and resource conditions. In this landscape of evolving capabilities we will rely heavily on co-design approaches that can balance local processing capabilities with cloud offloading strategies. In safety critical applications security and reliability considerations are becoming more important in co designed systems. As one of security features integrated into hardware and software, while maintaining system performance and flexibility, it is getting to be a growing challenge. An active area of research is the development of techniques for robust verification and validation to guarantee the integrity and resilience of complex, co-designed systems.

## CONCLUSION

As a powerful paradigm, hardware/software co-design has led to the development of a holistic approach to system development that utilizes the strengths of the hardware and software domains concurrently in order to optimize resource allocation in reconfigurable systems. By removing hardware from the software development process, this methodology frees hardware and software designers from traditional constraints and creates more efficient, flexible and powerful computing systems for a wide class of applications. In this article, we have explored the core principles of co design from state of the art partitioning algorithms and scheduling schemes to emerging approaches for

combining hardware and software components. We have done this, showing how these methodologies are being applied in real word if such as embedded systems or high performance computing and thereby demonstrating the versatility and reusability of co design approaches. Looking ahead, there will be further evolutionary progress made in hardware/software co-design with the advent of artificial intelligence, heterogeneous compute architectures, and ever increasing application such as automated driving. The benefits of co-design methodologies for creating more powerful, efficient and adaptable computing systems are indeed clear while challenges remain in such areas as both the design automation, and energy efficiency as well as security but seem to offer great potential. World's leading designers and engineers adopting hardware software co design principles and out of the box use of the latest tools and techniques in this and other domains are pushing the limits into the what is possible in system design, ushering innovations that will influence future computing in every domain. The work we address will be central to solving modern computing challenges as we navigate them and its coincidental nature with hardware and software co design will likely contribute to creating new possibilities in the years to come.

## **R**EFERENCES:

- 1. Kim, W., Gupta, M. S., Wei, G. Y., & Brooks, D. (2008, February). System level analysis of fast, per-core DVFS using on-chip switching regulators. In 2008 IEEE 14th International Symposium on High Performance Computer Architecture (pp. 123-134). IEEE.
- Krestinskaya, O., Salama, K. N., & James, A. P. (2018). Learning in memristive neural network architectures using analog backpropagation circuits. *IEEE Transactions on Circuits and Systems I: Regular Papers*, 66(2), 719-732.
- Kursun, V., Friedman, E., 2006. Multi-voltage CMOS Circuit Design. Wiley. URL: https://books.google.com.sa/ books?id=QClTAAAAMAAJ.
- 4. Javadi, M. A., Ghomashi, H., Taherinezhad, M., Nazarahari, M., & Ghasemiasl, R. (2021, May). Comparison of Monte Carlo simulation and genetic algorithm in optimal wind farm layout design in manjil site based on Jensen model. In 7th Iran Wind Energy Conference (IWEC2021) (pp. 1-4). IEEE.
- Szegedy, C., Vanhoucke, V., Ioffe, S., Shlens, J., & Wojna, Z. (2016). Rethinking the inception architecture for computer vision. In *Proceedings of the IEEE conference on computer vision and pattern recognition* (pp. 2818-2826).

- de la Fuente, D., Barba, J., Caba, J., Peñil, P., López, J. C., & Sánchez, P. (2016). Building a dynamically reconfigurable system through a high-level development flow. Languages, Design Methods, and Tools for Electronic System Design: Selected Contributions from FDL 2015, 51-73.
- Kumar, R., & Gordon-Ross, A. (2015, May). An automated high-level design framework for partially reconfigurable FPGAs. In 2015 IEEE International Parallel and Distributed Processing Symposium Workshop (pp. 170-175). IEEE.
- Zheng, T., Nellans, D., Zulfiqar, A., Stephenson, M., & Keckler, S. W. (2016, March). Towards high performance paged memory for GPUs. In 2016 IEEE International Symposium on High Performance Computer Architecture (HPCA) (pp. 345-357). IEEE.
- Tan, M., & Le, Q. (2019, May). Efficientnet: Rethinking model scaling for convolutional neural networks. In *International conference on machine learning* (pp. 6105-6114). PMLR.
- 10. Vallabhuni, R. R., Sravana, J., Pittala, C. S., Divya, M., Rani, B. M. S., & Vijay, V. (2021). Universal shift register designed at low supply voltages in 20 nm FinFET using multiplexer. In *Intelligent Sustainable Systems: Proceedings of ICISS 2021* (pp. 203-212). Singapore: Springer Singapore.
- Mrabet, H., Belguith, S., Alhomoud, A., & Jemai, A. (2020). A survey of IoT security based on a layered architecture of sensing and data analysis. *Sensors*, 20(13), 3625.
- 12. Shao, Y. S., Clemons, J., Venkatesan, R., Zimmer, B., Fojtik, M., Jiang, N., ... & Keckler, S. W. (2019, October). Simba: Scaling deep-learning inference with multi-chipmodule-based architecture. In *Proceedings of the 52nd annual IEEE/ACM international symposium on microarchitecture* (pp. 14-27).
- 13. Chen, Y. H., Krishna, T., Emer, J. S., & Sze, V. (2016). Eyeriss: An energy-efficient reconfigurable accelerator for deep convolutional neural networks. *IEEE journal of solid-state circuits*, 52(1), 127-138.
- 14. Sze, V., Chen, Y. H., Yang, T. J., & Emer, J. S. (2017). Efficient processing of deep neural networks: A tutorial and survey. *Proceedings of the IEEE*, 105(12), 2295-2329.
- Mocnej, J., Seah, W. K., Pekar, A., & Zolotova, I. (2018). Decentralised IoT architecture for efficient resources utilisation. *Ifac-Papersonline*, 51(6), 168-173.
- 16. Atmani, A., Kandrouch, I., Hmina, N., & Chaoui, H. (2020). Big data for internet of things: A survey on iot frameworks and platforms. In Advanced Intelligent Systems for Sustainable Development (AI2SD'2019) Volume 6-Advanced Intelligent Systems for Networks and Systems (pp. 59-67). Springer International Publishing.
- Singh, I., Shriraman, A., Fung, W. W., O'Connor, M., & Aamodt, T. M. (2013, February). Cache coherence for GPU architectures. In 2013 IEEE 19th International Sym-

posium on High Performance Computer Architecture (HPCA) (pp. 578-590). IEEE.

- Jouppi, N. P. (1990). Improving direct-mapped cache performance by the addition of a small fully-associative cache and prefetch buffers. ACM SIGARCH Computer Architecture News, 18(2SI), 364-373.
- 19. Uriarte, A., & Ontañón, S. (2016). Improving Monte Carlo tree search policies in StarCraft via probabilistic models learned from replay data. In *Proceedings of the AAAI Conference on Artificial Intelligence and Interactive Digital Entertainment* (Vol. 12, No. 1, pp. 100-106).
- Pittala, C. S., Lavanya, M., Saritha, M., Vijay, V., Venkateswarlu, S. C., & Vallabhuni, R. R. (2021, May). Biasing techniques: validation of 3 to 8 decoder modules using 18nm FinFET nodes. In 2021 2nd International Conference for Emerging Technology (INCET) (pp. 1-4). IEEE.
- 21. Dann, C., Lattimore, T., & Brunskill, E. (2017). Unifying PAC and regret: Uniform PAC bounds for episodic reinforcement learning. *Advances in Neural Information Processing Systems*, 30.
- 22. Chen, T., Du, Z., Sun, N., Wang, J., Wu, C., Chen, Y., & Temam, O. (2014). Diannao: A small-footprint high-throughput accelerator for ubiquitous machine-learning. ACM SIGARCH Computer Architecture News, 42(1), 269-284.
- 23. Akram, A., Akella, V., Peisert, S., & Lowe-Power, J. (2021). Enabling design space exploration for risc-v secure compute environments.
- 24. Biondi, A., & Buttazzo, G. (2017, July). Timing-aware FPGA partitioning for real-time applications under dynamic partial reconfiguration. In 2017 NASA/ESA Conference on Adaptive Hardware and Systems (AHS) (pp. 172-179). IEEE.
- 25. Zhou, S., & Prasanna, V. K. (2017, October). Accelerating graph analytics on CPU-FPGA heterogeneous platform. In 2017 29th International Symposium on Computer Architecture and High Performance Computing (SBAC-PAD) (pp. 137-144). IEEE.
- 26. Pittala, C. S., Lavanya, M., Vijay, V., Reddy, Y. V. J. C., Venkateswarlu, S. C., & Vallabhuni, R. R. (2021, May). Energy Efficient Decoder Circuit Using Source Biasing Technique in CNTFET Technology. In 2021 Devices for Integrated Circuit (DevIC) (pp. 610-615). IEEE.
- 27. Zhou, S., & Prasanna, V. K. (2017, October). Accelerating graph analytics on CPU-FPGA heterogeneous platform. In 2017 29th International Symposium on Computer Architecture and High Performance Computing (SBAC-PAD) (pp. 137-144). IEEE.
- 28. Kahle, J. (2005, November). The cell processor architecture. In 38th Annual IEEE/ACM International Symposium on Microarchitecture (MICRO'05) (pp. 3-3). IEEE.
- 29. Lowe-Power, J., Akella, V., Farrens, M. K., King, S. T., & Nitta, C. J. (2018, June). Position paper: Acase for exposing extra-architectural state in the isa. In *Proceedings*

of the 7th International Workshop on Hardware and Architectural Support for Security and Privacy (pp. 1-6)

- 30. .Mejail, M., Nestares, B. K., & Gravano, L. (2024). The evolution of telecommunications: Analog to digital. Progress in Electronics and Communication Engineering, 2(1), 16-26. https://doi.org/10.31838/PECE/02.01.02
- 31. Muralidharan, J. (2024). Optimization techniques for energy-efficient RF power amplifiers in wireless communication systems. SCCTS Journal of Embedded Systems Design and Applications, 1(1), 1-6. https://doi. org/10.31838/ESA/01.01.01
- 32. Prasath, C. A. (2024). Energy-efficient routing protocols for IoT-enabled wireless sensor networks. *Journal of Wireless Sensor Networks and IoT*, 1(1), 1-7. https://doi. org/10.31838/WSNIOT/01.01.01
- 33. Muralidharan, J. (2024). Innovative materials for sustainable construction: A review of current research. *Innovative Reviews in Engineering and Science*, 1(1), 16-20. https://doi.org/10.31838/INES/01.01.04
- 34. Prasath, C. A. (2024). Optimization of FPGA architectures for real-time signal processing in medical devices.

Journal of Integrated VLSI, Embedded and Computing Technologies, 1(1), 11-15. https://doi.org/10.31838/ JIVCT/01.01.03

- 35. Rahim, R. (2023). Effective 60 GHz signal propagation in complex indoor settings. *National Journal of RF Engineering and Wireless Communication*, 1(1), 23-29. https://doi.org/10.31838/RFMW/01.01.03
- 36. Alnumay, W. S. (2024). Use of machine learning for the detection, identification, and mitigation of cyber-attacks. International Journal of Communication and Computer Technologies, 12(1), 38-44. https://doi.org/10.31838/ IJCCTS/12.01.05
- 37. Smith, O. J. M., de Mendonça, F., Kantor, K. N., Zaky, A. A., & Freire, G. F. (2022). Ultra Low Potential Operated Fundamental Arithmetic Module Design for High-Throughput Applications. Journal of VLSI Circuits and Systems, 4(1), 52-59. https://doi.org/10.31838/jvcs/04.01.08
- Yeonjin, K., Hee-Seob, K., Hyunjae, L., & Sungho, J. (2023). Venting the potential of wirelessly reconfigurable antennas: Innovations and future directions. *National Journal of Antennas and Propagation*, 5(2), 1-6.