280 MyFitnessPlanner Report
280 MyFitnessPlanner Report
My Fitness Planner
Team Members
Submitted to
Instructor: Prof. Chandrasekar Vuppalapati
Fall 2024
CONTENTS
1. Project Description
2. Requirements
3. Web UI Requirement Principles – VOC, Personas, Job Shadowing
4. Web UI Design Principles – Storyboard, Wireframes
5. High-Level Architecture Design
6. Data Flow Diagram & Component Level Design
7. Sequence or Workflow
8. HTML5 Features Used
9. Interfaces – RESTful & Server Side Design
10. Client-Side Design
11. Testing (UI or Stress test)
12. Automation (Selenium)
13. Cross Browser Compatibility
14. Java Script Libraries – documentation
15. Design Patterns Used
16. Pagination
17. Localization
18. SEO
19. Profiling
1. Project Description
In the world of health and fitness, where innovation meets well-being, Our Fitness Planner is
transforming how we approach personal fitness. By harnessing the power of cutting-edge AI
technology, this platform offers a unique and tailored experience, providing customized workout
plans, personalized meal suggestions, adaptable challenges, and real-time progress monitoring.
With our Fitness Planner, every user embarks on a journey toward better health, supported by
intelligent algorithms and a thoughtfully designed interface. Let’s explore the features that make this
platform a game-changer in the fitness space.
2. Requirements
Functional Requirements
1. Requirements
Functional Requirements:
Non-functional Requirements:
1.) Performance
● The app is designed to respond to user interactions in under 2 seconds, ensuring a smooth and
hassle-free experience.
● Responses from the OpenAI API will be processed and displayed within 5 seconds, keeping
everything efficient and timely.
2.) Security
● User credentials are encrypted both during storage and transmission to protect your privacy.
● Personal health information is anonymized and stored using top-tier security standards to ensure
it remains confidential.
3.) Usability
● The app’s interface is built to be easy to navigate, making it enjoyable for everyone to use.
● Accessibility features ensure the platform is welcoming and usable for people of all abilities.
1. Age Range: Our app is designed for individuals aged 18 to 60 who are seeking customized fitness
and dietary solutions.
2. Diversity: We welcome users with varied fitness levels, dietary preferences, and health
backgrounds, ensuring inclusivity and adaptability.
1. Focus Groups: We plan to organize small, interactive discussions with fitness enthusiasts to
uncover their unique needs and preferences.
2. Interviews: One-on-one sessions with individuals representing different user personas will help us
gather deeper insights.
3. Surveys and Questionnaires: Short and engaging surveys will capture valuable feedback on user
expectations and suggestions for improvement.
1. Ease of Use: Users want a simple, intuitive interface that caters to everyone, regardless of
technical skill or experience.
2. Engaging Features: Features that keep users motivated and invested in their fitness journey are a
top priority.
3. Trust and Transparency: The app must be transparent and reliable, ensuring users feel confident
in its guidance for their fitness and dietary needs.
4. Personalized Experience: Tailored plans that align with individual preferences and goals are
essential to providing value and satisfaction.
Personas:
Persona 1: Beginner
These individuals are novices embarking on their fitness journey or initiating a healthy dietary regimen.
They are in search of direction and encouragement to kickstart their endeavors.
Job Shadowing:
Job shadowing is essential as it offers insights into how potential users of the "My Fitness Planner"
application integrate fitness and dietary routines into their daily lives. The objective of job shadowing
is to grasp real-world usage patterns and obstacles to improve the design and functionality of the app.
Objectives
1. Understanding Routines: Explore how individuals incorporate fitness and diet tracking into their
daily lives.
2. Addressing Challenges: Identify pain points and uncover opportunities to enhance current fitness
and diet tracking practices.
3. Informed Design Decisions: Gather qualitative insights to guide user-specific design choices for
the application.
Methodology
1. User Selection: Participants were chosen from a variety of demographics and fitness levels for
in-depth observation.
2. Observation Period: Each user was shadowed for an entire day to gain a thorough understanding of
their fitness and dietary habits.
3. Data Gathering: Detailed observations were recorded to capture behaviors, preferences, and
challenges.
Observations
1. Persona 1 (The Beginner): Struggles with planning effective workouts and prefers quick,
convenient meal options due to limited time. They showed enthusiasm for social features that provide
motivation.
2. Persona 2 (Busy Professional): Relies on a combination of traditional and digital tools to track
progress. They prioritize efficient workouts that fit tight schedules and want personalized meal plans
tailored to their work-life balance.
3. Persona 3 (The Health Enthusiast): Seeks comprehensive tracking tools for both workouts and
dietary habits. They value customization in fitness plans to match their precise goals.
4. Persona 4 (Elderly Users): Prefers a straightforward and easy-to-navigate app due to limited
familiarity with technology.
Challenges
1. Lack of Personalization: Many existing apps fail to offer fitness and diet plans tailored to
individual needs.
2. Time Constraints: Users often struggle to integrate fitness routines into their busy schedules.
Recommendations
1. Advanced Customization: Leverage AI to create highly personalized fitness and dietary plans that
align with unique user requirements.
2. Quick & Effective Solutions: Provide options for short, impactful workout routines paired with
practical dietary plans to support users with limited time.
3. Web UI Design Principles – Storyboard, Wireframes
a.) Storyboard- The outline of the flow and interactions within the user interface.
b.) Wireframes
HOME PAGE
LOGIN PAGE
SIGNUP PAGE
WORKOUT/DIET PLANS PAGE:
The front end is built with React JS, offering an interactive and user-friendly interface. It includes all the
components and styling needed to ensure seamless navigation and an enjoyable user experience.
Middleware (Node.js)
The middleware, powered by Node.js, handles essential functionalities such as user authentication,
authorization, and core business logic. It also manages integrations with OpenAI and Firebase, ensuring
smooth communication between different parts of the application.
Database
Firebase is used for both authentication and data storage, providing a secure and reliable foundation for
managing user information and application data.
OpenAI Integration
The application integrates OpenAI’s language model to create personalized fitness and dietary plans,
making the user experience smarter and more tailored to individual needs.
5. Data Flow Diagram and Component Level Design
User Interaction
External users can easily engage with My Fitness Planner through its intuitive web interface, designed for a
seamless experience.
The app guides users through a simple process of registration, login, and profile setup. During this process,
users can share personal details, dietary preferences, and allergy information to ensure their experience is
tailored to their needs.
User information is securely stored in a robust database, protected by advanced encryption and
comprehensive security protocols to safeguard sensitive data and maintain user trust.
Backend Functionality
Users submit their preferences for fitness, diet, and exercise plans through the backend. The system then
processes these inputs and communicates with OpenAI to generate highly personalized recommendations.
OpenAI Integration
By integrating seamlessly with OpenAI, the app delivers smarter, more relevant fitness, diet, and exercise
plans. This advanced AI-driven approach ensures users receive personalized suggestions that align with their
unique goals and preferences.
● Responsibilities:
○ Handle user registration and authentication (including login/logout functionality).
○ Manage user profiles, including dietary preferences and allergy information.
○ Ensure secure storage of user data with encryption.
○ Enable integration with external identity providers, such as social media logins.
User Form
● Responsibilities:
○ Collect and manage user-submitted fitness, diet, and exercise plans.
○ Store and retrieve these plans securely in the database.
○ Oversee the handling and organization of plan details.
Plans
● Responsibilities:
○ Create detailed day-to-day plans based on user inputs.
○ Allow users to edit and customize their plans to suit their preferences.
○ Ensure that all generated plans remain synchronized with the user’s profile.
Trainers
● Responsibilities:
○ Facilitate interactions between users and their selected trainers.
○ Provide users with personalized training plans crafted by the trainers.
Authentication Process
The user begins by logging into the application. Their credentials are securely verified against the database to
ensure proper authentication and authorized access.
Users provide their input through the application interface. This information is then sent to OpenAI, which
processes it to deliver a personalized and enhanced user experience.
Document Structure
Purpose of Standardization
Adopting the HTML5 document structure brings uniformity across web pages by ensuring a standardized
format. Elements like <html>, <head>, <meta>, <title>, and <body> add semantic clarity, improving both
readability and accessibility.
● Consistency: A uniform structure makes it easier for developers to maintain and manage the code.
● SEO Advantages: Semantic HTML makes it easier for search engines to crawl and index content,
improving visibility.
Semantic Elements
Purpose
Semantic elements provide meaningful context to their content, supporting better understanding by both
developers and assistive technologies like screen readers.
● Improved Readability: Elements like <header>, <section>, <h1>, and <h2> create a clear
information hierarchy, simplifying the structure of code.
● SEO Benefits: Search engines value semantic tags as they make it easier to identify content structure
and context.
Meta Tags
Meta tags provide key information about a web page, such as character encoding and viewport settings. They
also play a vital role in responsive web design.
Styling
Purpose of Styling
Styling improves the visual appeal of a web page, creating a more engaging and user-friendly experience.
● Modular Design: Including CSS in conjunction with HTML allows for logical design grouping and
easier maintenance.
● Aesthetic Details: Attributes like font-family, margin, and accent colors like color: #3498db; applied
to the <h1> tag enhances the page's visual design, making it distinctive and appealing.
The use of HTML5 features in the My Fitness Planner app is rooted in creating a clean, accessible, and
visually appealing user interface. This approach not only enhances user experience but also supports easier
development, better maintainability, and improved SEO performance.
a) RESTful Design
Endpoints:
Login - /login
Signup - /signup
Profile Page - /dashboard
Logout - /logout
Plans - /get plan.
HTTP Methods: -
b) Server-Side Design
9. Client-Side Design
The following requirements focus on the client-side design elements of the My Fitness Planner AI
Application to ensure an intuitive and seamless user experience:
1. User-Friendly Interface
Designing an intuitive and visually appealing interface to ensure users find it easy and pleasant to navigate
the application.
2. Input Validation
Client-side validation is implemented to check user inputs before sending them to the server, ensuring a
smoother, more responsive interaction and minimizing server load.
3. Real-Time Feedback
The application provides instant, dynamic feedback on user actions by updating the interface in real time,
keeping users informed about the status and completion of their tasks.
Before clearing the cache, a client-side prompt ensures users don’t accidentally lose stored preferences or
progress, improving the user experience.
5. Responsive Design
The application is optimized to function smoothly across various screen sizes and devices, ensuring
accessibility and usability for all users, regardless of platform.
Consistent visual themes and branding are applied on the client-side to reinforce the application’s identity and
enhance the overall user experience.
7. Client-Side Caching
Static assets, such as images and stylesheets, are cached on the client side to reduce server requests,
improving application speed and responsiveness.
8. Cross-Browser Compatibility
The application is designed to work consistently across all major web browsers, ensuring all users have the
same smooth experience, regardless of their preferred browser.
● User Registration: Test sign-up with unique usernames and passwords, and verify successful login
with valid credentials.
● Profile Management: Ensure users can edit their profile and update diet plan preferences.
3. Fitness Plans
● Plan Selection: Test users' ability to choose fitness goals (mass gain, fitness, weight loss) and select
time durations.
4. Diet Plans
● Allow users to select diet plans considering preferences and budget constraints.
5. Exercise Plans
● Plan Selection: Enable users to pick different exercise plans (home workout, calisthenics, yoga) and
select their experience levels.
● Plan Generation: Ensure users view detailed daily exercise plans (warm-up, strength, cardio) and can
regenerate plans.
6. Social Sharing
● Test sharing user profiles on social media platforms to encourage community engagement.
Non-Functional Testing
1. Performance Testing
● Ensure the application responds within 2 seconds for user actions and OpenAI responses are
processed within 5 seconds.
2. Security Testing
● User Credentials: Ensure credentials are securely stored and encrypted during transmission.
● Health Data: Confirm anonymization and adherence to industry-standard data storage security
protocols.
Usability Testing
● Assess the user interface for ease of use and accessibility to ensure inclusivity for all users.
● Selenium Scripts: Automated Selenium scripts are created to test key UI workflows and user
interactions, including user registration, workout planning, and meal tracking scenarios.
2. Cross-Browser Compatibility
● WebDriver Testing: Selenium WebDriver runs tests on multiple browsers (e.g., Chrome, Firefox,
Safari) to ensure the application’s interface performs consistently across different environments.
● Test scripts are designed to adhere to UI design standards, ensuring that user interactions and visual
elements are evaluated as they are intended in the user experience.
● Selenium tests are integrated into the CI/CD pipeline, enabling automated testing with every code
change. This allows issues to be detected early, maintaining development efficiency.
● Test scripts are parameterized to run with various input sets, improving test coverage and flexibility
without the need to rewrite scripts for different scenarios.
Efficiency Gains
● Time & Resource Savings: Automated Selenium testing accelerates the testing process and frees
resources for other development tasks.
● Consistent Test Execution: Selenium ensures uniform test execution, eliminating inconsistencies
from manual testing.
Future Directions
● Implement visual regression testing to capture and compare UI screenshots over time, identifying
unintended visual changes.
Accessibility Testing
● Expand Selenium's use to assess accessibility, ensuring that the app’s design supports users with
disabilities.
The primary objective is to ensure that the My Fitness Planner app functions consistently and seamlessly
across various web browsers, including but not limited to Chrome, Firefox, Safari, and Edge.
Implementation:
a. Selenium WebDriver:
Selenium WebDriver is employed to automate testing scenarios across different browsers. This includes
writing test scripts that simulate user interactions on the app using Selenium, ensuring functionality across
multiple browser environments.
b. Responsive Design:
The app's UI is designed responsively, allowing it to adapt and display optimally on various screen sizes
and resolutions. This is particularly important for ensuring a consistent experience on both desktop and
mobile browsers.
c. Cross-Browser Testing Suites:
A dedicated cross-browser testing suite is developed to ensure the application works consistently across
various browsers and versions. This suite includes a comprehensive collection of test cases designed to
verify both functionality and visual appearance on each supported browser.
d. Regular Testing Cycles:
Cross-browser testing is a vital part of the application’s testing routine, especially during the testing
phase for new features or updates. It identifies and resolves browser-specific issues early in
development.
Efficiency Gains
● Early Issue Detection: Incorporating cross-browser testing during development identifies potential issues
early, preventing them from reaching production.
● Enhanced User Satisfaction: Ensuring compatibility across all popular browsers enhances user experience, as
users can access the app seamlessly, regardless of their preferred browser.
The My Fitness Planner app utilizes various JavaScript libraries to enhance functionality, optimize
performance, and ensure a dynamic user experience. These libraries simplify development, provide advanced
features, and enable the creation of a seamless and interactive user interface.
Libraries Used
1. ReactJS
● Purpose: ReactJS serves as the primary JavaScript library for building intuitive and dynamic user
interfaces.
● Why ReactJS? Its component-based architecture allows the development of modular, reusable, and
maintainable UI elements.
● How It's Used:
○ React components are implemented extensively to create a responsive and interactive user
interface.
○ React's virtual DOM ensures efficient UI rendering and updates, improving overall
performance.
● JSX (JavaScript + XML): Embedded HTML-like syntax within JavaScript for creating reusable
components easily.
● State Management: Simplifies dynamic data handling and updates.
● Gradual Adoption: Allows developers to adopt React at varying levels—adding small features or
building full-scale applications.
● Flexible Design Philosophy: React doesn't enforce rigid conventions, offering flexibility in structure
and implementation.
ReactJS's versatility, ease of use, and focus on performance make it essential for creating a seamless user
experience in My Fitness Planner.
Getting Started with React:
To start with React, you should have a basic understanding of HTML, CSS, and JavaScript. React uses
JSX, which blends HTML and JavaScript. This approach can make building UIs more intuitive once you
are familiar with it. React components can manage their state and props, allowing for dynamic and
interactive UIs.
React Installation and Setup:
You can experiment with React without installing anything by using online sandboxes like CodeSandbox,
StackBlitz, or CodePen. For a more permanent setup, you can start a new React project or add React to an
existing project. The documentation provides guides on setting up your editor and installing React
Developer Tools.
Learning React Concepts:
The React documentation covers essential concepts like component creation, handling events, managing
state, working with effects, and using refs. These topics are crucial for building a dynamic and responsive
application. The documentation also includes examples and code snippets to aid understanding.
React's Approach to UI Building:
React aims to minimize UI bugs through its component-based architecture. Components are self-
contained units that manage their state and composition, simplifying the UI development process. This
approach allows for scalable and maintainable codebases.
Benefits of Incorporating JavaScript Libraries:
Efficient Development:
JavaScript libraries streamline development, allowing developers to focus on building features rather than
handling low-level tasks.
Enhanced User Experience:
Libraries like ReactJS contribute to a responsive and dynamic user interface, enhancing the overall user
experience.
Maintainability:
Well-documented libraries, such as Redux, facilitate code maintainability by providing clear guidelines
and best practices.
Visual Appeal:
Chart.js enables the creation of visually appealing charts, contributing to the presentation of fitness- related
data in an engaging manner.
14. Design Patterns Used
2. Singleton Pattern
● Purpose: Ensures a class has only one instance, while providing a global point of access.
● Application:
○ Use for global components like user authentication managers or API handlers, ensuring
consistent state management across sessions.
● Purpose: Defines an interface for creating objects while allowing subclasses to define the specific
type of object created.
● Application:
○ Create different types of fitness plans and diet plans dynamically based on user preferences.
4. Observer Pattern
● Purpose: Establishes a one-to-many relationship, ensuring that dependent objects are automatically
notified of state changes.
● Application:
○ Enable real-time UI updates when changes are made to user profiles, fitness plans, or other
dynamic user data.
Choosing and applying appropriate design patterns can significantly improve the maintainability,
scalability, and flexibility of the project. The patterns mentioned above address various aspects of the
project, promoting modularity and ease of extension. However, the selection of design patterns should be
based on specific project requirements and architecture considerations.
15. Pagination
Pagination improves usability by dividing large datasets into smaller, manageable sections, allowing users
to interact with content without feeling overwhelmed. In My Fitness Planner, pagination enhances
navigation and user experience in workout and meal planning sections.
Purpose of Pagination
1. Workout Plans
2. Meal Plans
Implementation Details
1. ReactJS Component
● A dedicated ReactJS pagination component is created to manage and render paginated content
dynamically.
● The frontend communicates with the backend API to fetch only the data required for the current
page.
● This reduces data transfer, enhances performance, and minimizes latency.
3. User-Configurable Settings
User Benefits
● Key Features: Quick links to essential sections like user profiles, fitness plans, and meal plans.
● Motivational Elements: Inspirational content to keep users engaged on their fitness journey.
● Quick Access Options: Easy navigation to key sections to support intuitive user interaction.
Sign-up form prominently features fields for the user's email address, allowing for unique identification
and communication.
Users enter their login credentials (username and password) into the designated input.
Upon clicking the "Login" button, the authentication component sends a request to the server via a RESTful
API endpoint specifically designed for user authentication. If the login is successful, users are redirected to
the home page of the application. However, in the case of authentication failure, an error message is
displayed, allowing users to either retry logging in or navigate to the "Forgot Password" section to reset
their credentials.
The Trainers Page showcases a carefully curated list of fitness trainers. Each trainer profile features essential
information such as their photo, name, expertise, and a brief bio. Users can click on individual trainer
profiles to explore detailed insights into their qualifications, specialties, and training philosophies. This
allows users to connect with trainers that align with their fitness objectives and preferences.
The Progress Form is a vital component of the application, allowing users to input critical health-related
information such as height, weight, age, existing health conditions, and allergies. This data serves as the
foundation for generating personalized and effective diet recommendations tailored to each user’s unique
needs and fitness goals. The information collected ensures a targeted and safe approach to achieving fitness
objectives, enhancing the user experience through customization and attention to individual health factors.
This user-friendly page empowers individuals to select the path that aligns with their goals, preferences,
and overall wellness objectives.
Users can browse through different exercise categories and select the type they are interested in. The list
of exercises dynamically updates based on the chosen category and experience level.
Presents a snapshot of the user's overall fitness progress. This page lists the personalized exercise plans
saved by the user. Each plan includes the name, type of exercises, dietary recommendations, meal
schedules, and nutritional information. Allows users to click on a plan for more details or to start the
workout.
Users can also download their personalized plan.
16. Localization
Localization plays a vital role in making the My Fitness Planner app globally accessible and user-friendly.
Recognizing the diverse backgrounds of its user base, the app incorporates robust localization features to
ensure that users from different regions can interact with the application in a way that feels natural and
intuitive.
Purpose of Localization:
1. Multilingual Support: The app offers comprehensive multilingual support that goes beyond simple
language translation. This includes adapting elements like content, date formats, and cultural nuances
to match the expectations and preferences of specific regions. This approach ensures that every user
can engage with the app in a familiar context, improving accessibility and enhancing user experience
across different geographies.
Implementation Details:
User Benefits:
1. Improved User Engagement: Presenting content in a user’s native or preferred language fosters
inclusivity and enhances interaction with the app. Users feel more connected when the information
aligns with their language and culture.
2. Cultural Sensitivity: Localization incorporates cultural norms and expectations, ensuring that the app
respects the diversity of its users while enhancing the overall user experience.
3. Access to Tailored Content: Users gain access to content that is both translated and adapted to
regional fitness and dietary practices, making the app more valuable across different locations.
Future Directions:
1. User-Generated Translations: The app plans to introduce features allowing users to contribute their
own translations. This community-driven approach will enhance translation accuracy, diversity, and
relevance.
2. Automated Regional Adaptation: The future vision includes incorporating machine learning
algorithms to automatically adjust content based on a user’s geolocation, creating a more seamless,
intuitive, and personalized experience.
17. SEO (Search Engine Optimization)
Search Engine Optimization (SEO) is fundamental for enhancing the discoverability and visibility of the
My Fitness Planner app in online search results. A strategic approach to SEO ensures that the app ranks
higher in search engine results, attracting more users interested in health and fitness. Here's an elaboration
on how SEO strategies have been incorporated into the app:
1. Fitness-Centric Keywords:
Thorough keyword research has been conducted to identify relevant fitness and wellness terms that
align with user intent. These fitness-centric keywords are strategically embedded across various
elements of the app, such as meta tags, headers, and body content, to ensure alignment with user
search queries. This approach ensures that users searching for terms related to fitness, nutrition, and
wellness can discover the app easily.
2. Localized Keywords:
In addition to universal fitness-related terms, localized keywords are strategically integrated to target
users searching for fitness resources within their specific regions. This approach enhances the app’s
local search visibility, allowing it to connect with a diverse, global audience.
Content Optimization
Technical SEO
1. Mobile-Friendly Design:
Given the growing trend of mobile usage, mobile responsiveness is prioritized in the app's design.
This ensures that users accessing the platform from smartphones or tablets have an optimal and
seamless user experience, aligning with search engines' focus on mobile-first indexing.
2. Fast Loading Speed:
The app incorporates optimizations like image compression, browser caching, and efficient code
practices to ensure a fast loading speed. Faster load times improve user experience and contribute to
better SEO rankings since page speed is a critical ranking factor for search engines.
Backlink Building
1. Strategic Backlinking:
A well-planned backlink strategy is implemented to secure high-quality links from reputable fitness
and wellness websites. These backlinks build credibility, enhance domain authority, and signal
trustworthiness to search engines, thereby improving search visibility.
2. User-Generated Content:
The app encourages users to contribute user-generated content like reviews, testimonials, and shared
fitness achievements. This type of content naturally generates backlinks as users share experiences,
building organic traffic from other platforms and communities.
1. Analytics Integration:
The app uses advanced analytics tools to monitor user behavior, track traffic sources, and evaluate
keyword performance. Regular analysis of this data allows for adjustments to SEO strategies,
ensuring alignment with user interactions and engagement patterns.
2. Algorithm Updates Adaptation:
Search engine algorithms frequently change. To maintain a strong search presence, SEO strategies
are continuously reviewed and adapted in response to these updates. Staying informed about changes
ensures that the app maintains its rankings and visibility.
18. Profiling
Profiling
Performance Profiling
1. Response Time:
The response time of critical user interactions must remain under 2 seconds to ensure a smooth and
seamless user experience. Tools will be used to identify bottlenecks in the application, enabling code
optimizations to improve performance.
2. API Processing:
The application communicates with the OpenAI API, and it is critical that responses are processed and
displayed within 5 seconds. Optimization of API calls and response handling mechanisms will reduce
latency and ensure a faster user experience.
Security Profiling
1. User Credentials:
Security protocols must ensure that user credentials are encrypted during storage and transmission.
Security audits will identify and rectify vulnerabilities within the authentication process.
Usability Profiling
1. User Interface:
Usability testing will confirm that the app's user interface is intuitive, user-friendly, and easily
navigable. Based on user feedback from these tests, adjustments will be made to enhance user
experience.
2. Accessibility:
The application will adhere to established accessibility standards to ensure inclusivity for all users,
including those with disabilities. Testing will identify and address navigation or readability challenges.
Regeneration Profiling
1. Plan Regeneration:
Users generate custom workout and diet plans based on preferences. Profiling will evaluate how long
these plans take to regenerate. Caching mechanisms will be implemented to store frequently used data,
minimizing plan regeneration time and improving performance.