LLM Agent Flow with RAG

Jul 23, 2024

Content

Share with:

Introduction

In recent years, the field of artificial intelligence has witnessed significant advancements, particularly in the development and application of Large Language Models (LLMs) and Retrieval-Augmented Generation (RAG) systems. This research report delves into the intricate dynamics of LLM agents and their integration with RAG methodologies, highlighting the challenges and opportunities that arise in this rapidly evolving landscape. Drawing on insights from industry experts, including Greg Bayer, the report emphasizes the necessity for smarter models and enhanced tooling to optimize the performance of LLM agents.

The exploration of RAG as a transformative approach to augmenting LLM capabilities is a central theme, with discussions on its architecture, implementation, and real-world applications. The report also addresses the importance of collaboration among developers and the need for tailored solutions that meet specific use cases. By examining various frameworks, including the Mosaic AI Agent Framework and the potential of programming languages like Elixir, the document provides a comprehensive overview of the current ecosystem surrounding LLM and RAG technologies.

Furthermore, the report highlights practical implementations, case studies, and the significance of continuous feedback in refining LLM performance. As the integration of external knowledge bases becomes increasingly vital for addressing issues such as outdated training data and hallucinations, this research aims to contribute to the ongoing discourse on enhancing the accuracy and relevance of AI-driven solutions in diverse applications.

Challenges and Opportunities in LLM Agent Development

The development of large language model (LLM) agents, particularly those utilizing Retrieval-Augmented Generation (RAG), faces a myriad of challenges and opportunities. One of the primary challenges is the inherent limitations of LLMs, which often struggle with providing up-to-date or contextually relevant information due to their static training data. This issue is compounded by the phenomenon of "hallucination," where LLMs generate plausible but incorrect or nonsensical responses. RAG addresses these challenges by integrating external knowledge sources, allowing LLMs to retrieve and utilize real-time data, thereby enhancing their accuracy and relevance in responses[4]].

However, implementing RAG effectively is not without its difficulties. The orchestration of retrieval and generation processes can introduce latency and complexity, particularly when multiple retrieval steps are involved. Each interaction with an LLM incurs computational costs, and the need for efficient state management and orchestration of agent workflows becomes critical. Builders must navigate these complexities to ensure that the agents operate smoothly and efficiently, which often requires sophisticated tooling and frameworks[2]].

Opportunities abound in the realm of LLM agent development, particularly through collaboration among builders. By sharing insights and best practices, developers can accelerate the evolution of agent frameworks. Collaborative efforts can lead to the creation of modular architectures that allow for the easy integration of various components, such as retrieval systems and LLMs, thereby enhancing the overall functionality and adaptability of agents. For instance, frameworks like LangGraph provide a computational graph abstraction that models the shared memory and flow of agents, facilitating rapid prototyping and deployment of complex agent systems[2]][[5]].

Moreover, the integration of RAG with advanced reasoning capabilities can significantly improve the performance of LLM agents. By employing guardrails—classifiers of user intent—developers can streamline the decision-making process, allowing agents to determine when to engage in retrieval and how to formulate queries effectively. This approach not only enhances the speed of responses but also reduces the computational burden associated with traditional agent architectures[1]].

In summary, while the development of LLM agents utilizing RAG presents significant challenges, particularly in terms of efficiency and accuracy, the potential for collaboration among builders offers a pathway to overcome these hurdles. By leveraging shared knowledge and innovative frameworks, the evolution of agent frameworks can be accelerated, leading to more robust and capable LLM applications in various domains.

Retrieval Augmented Generation (RAG) Overview

Retrieval Augmented Generation (RAG) is a transformative approach that enhances the capabilities of large language models (LLMs) by integrating external knowledge bases into the generative process. This methodology addresses the inherent limitations of LLMs, particularly their reliance on static training data, which can lead to outdated or inaccurate responses. By incorporating real-time data retrieval, RAG allows LLMs to access up-to-date information, thereby improving the relevance and accuracy of their outputs.

At its core, RAG operates through a three-step process: retrieval, augmentation, and generation. Initially, a user query is processed to identify relevant documents from an external knowledge base, such as a vector store or a database. This retrieval step is crucial as it ensures that the LLM has access to the most pertinent information related to the query. Once the relevant documents are identified, they are combined with the original user query to create a more informative prompt. This augmented prompt is then fed into the LLM, which generates a response grounded in the retrieved context[1]].

The significance of RAG lies in its ability to mitigate common issues associated with LLMs, such as hallucinations—where the model generates plausible but incorrect information—and the challenge of maintaining current knowledge. Traditional LLMs are limited by the data they were trained on, which can become stale over time. RAG effectively circumvents this limitation by allowing LLMs to pull in fresh, relevant data as needed, thus ensuring that the information provided is both accurate and contextually appropriate[4]].

Moreover, RAG facilitates the incorporation of proprietary or domain-specific knowledge that may not have been included in the original training dataset. This capability is particularly valuable in specialized fields where up-to-date information is critical, such as healthcare, finance, or legal sectors. By enabling LLMs to cite specific sources and provide verifiable information, RAG enhances the trustworthiness of AI-generated content, making it a powerful tool for applications requiring high levels of accuracy and reliability[5]].

In practical applications, RAG can be implemented in various ways, including through frameworks like LangChain and LlamaIndex, which simplify the integration of retrieval mechanisms with LLMs. These frameworks allow developers to create knowledge-aware applications quickly, leveraging RAG to improve user interactions with AI systems. For instance, chatbots utilizing RAG can provide accurate answers based on the latest company documents or external databases, significantly enhancing customer support and engagement[4]].

Overall, Retrieval Augmented Generation represents a significant advancement in the field of AI, enabling LLMs to operate with greater accuracy and relevance by seamlessly integrating external knowledge sources into their generative processes. This approach not only enhances the capabilities of LLMs but also opens up new possibilities for their application across various industries, ensuring that AI systems remain effective and reliable in an ever-evolving information landscape[1]][[5]].

Implementation Strategies for RAG Systems

Retrieval-Augmented Generation (RAG) systems leverage the strengths of large language models (LLMs) by integrating external knowledge sources to enhance their performance and accuracy. The design and implementation of RAG systems involve several strategic considerations, particularly in the flow patterns for fine-tuning and inference stages.

In the fine-tuning stage, there are three primary strategies: Retriever Fine-tuning, Generator Fine-tuning, and Dual Fine-tuning. Retriever Fine-tuning focuses on optimizing the retrieval component to improve the relevance of the documents fetched based on user queries. This is crucial as the quality of retrieved documents directly impacts the LLM's ability to generate accurate responses. Generator Fine-tuning, on the other hand, aims to enhance the LLM's performance in generating responses based on the context provided by the retrieved documents. Dual Fine-tuning simultaneously optimizes both the retriever and the generator, ensuring that they work in harmony to produce the best possible outcomes. An example of this is the RA-DIT framework, which fine-tunes both components to maximize the likelihood of correct answers while minimizing discrepancies between the retriever's scoring and the LLM's preferences[[7]].

The inference stage of RAG systems can be organized into four distinct flow patterns: Sequential, Conditional, Branching, and Loop. The Sequential flow is the most straightforward, where the user query is processed in a linear manner, typically involving a query rewrite before retrieval and a reranking of results afterward. This structure is commonly seen in applications like QAnything, where the retrieval process is straightforward and efficient[[7]].

In contrast, the Conditional flow allows for different retrieval pathways based on specific conditions, such as the type of query. This is particularly useful in scenarios where the nature of the question dictates the retrieval strategy, enabling the system to adapt its approach based on user intent. For instance, a Semantic Router can direct queries about sensitive topics to a more cautious retrieval process, ensuring that the responses are appropriate and contextually relevant[[7]].

The Branching flow introduces parallel processing, where multiple retrieval paths are explored simultaneously. This approach can enhance the system's ability to gather diverse information, which is then aggregated to form a comprehensive response. An example of this is the REPLUG framework, which utilizes a post-retrieval branching structure to predict token probabilities across different branches and combines them for final output[[7]].

Lastly, the Loop flow incorporates iterative or recursive retrieval processes, allowing the system to refine its queries based on previous outputs. This is particularly beneficial for complex questions that require multiple rounds of retrieval and reasoning. For example, the ITER-RETGEN framework employs iterative retrieval to enhance the quality of responses by leveraging outputs from previous iterations to inform subsequent queries[[7]].

Implementing these strategies requires careful orchestration of the various components involved in RAG systems. The orchestration layer plays a critical role in managing API calls, ensuring that the retrieval tools are effectively integrated with the LLM, and handling the complexities of prompt engineering. This layer is responsible for validating inputs, managing token limits, and ensuring that the retrieved context is appropriately formatted for the LLM to generate coherent and relevant responses[[4]].

In summary, the design and implementation of RAG systems involve a nuanced understanding of both the fine-tuning and inference stages. By strategically employing different flow patterns and optimizing the interaction between retrieval and generation components, developers can create robust RAG applications that significantly enhance the capabilities of LLMs in real-world scenarios.

RAG Applications in Real-World Scenarios

Retrieval Augmented Generation (RAG) has found numerous applications across various industries, significantly enhancing the accuracy and efficiency of large language models (LLMs). One prominent application is in customer support, where RAG enables chatbots to provide accurate and contextually relevant responses by retrieving information from a company's knowledge base. This capability allows businesses to automate customer interactions while ensuring that the information provided is up-to-date and specific to the user's query, thereby improving customer satisfaction and reducing response times[[4]].

In the healthcare sector, RAG is utilized to assist medical professionals in diagnosing conditions by retrieving relevant medical literature and patient data. For instance, a chatbot powered by RAG can engage with patients, asking diagnostic questions and retrieving pertinent information from a database of medical research. This not only streamlines the diagnostic process but also ensures that healthcare providers have access to the latest research and treatment options, ultimately leading to better patient outcomes[[10]].

Another significant application of RAG is in the field of finance, where it aids in risk assessment and compliance. Financial institutions can leverage RAG to pull data from regulatory documents, internal reports, and market analyses to generate comprehensive risk assessments. By integrating real-time data retrieval with LLMs, these institutions can ensure that their analyses are based on the most current information, thus enhancing decision-making processes and regulatory compliance[[6]].

RAG also plays a crucial role in content creation and marketing. By retrieving relevant articles, trends, and consumer data, RAG-powered tools can assist marketers in generating tailored content that resonates with target audiences. This capability not only improves the relevance of marketing materials but also enhances the efficiency of content production, allowing teams to focus on strategy rather than data gathering[[1]].

Moreover, RAG is increasingly being adopted in educational technologies. Learning platforms can utilize RAG to provide personalized learning experiences by retrieving resources that align with a student's specific needs and learning pace. This approach not only enhances the learning experience but also ensures that students have access to the most relevant and up-to-date educational materials[[5]].

The efficiency of RAG systems is further enhanced by their ability to minimize the computational costs associated with traditional LLMs. By relying on external knowledge bases rather than solely on the model's internal parameters, RAG allows for more scalable and cost-effective solutions. This is particularly beneficial in environments where rapid updates to information are necessary, as it reduces the need for frequent model retraining[4]].

In summary, the integration of RAG into various industries not only improves the accuracy of responses generated by LLMs but also enhances operational efficiency. By enabling real-time data retrieval and contextual augmentation, RAG empowers organizations to leverage their data more effectively, leading to better decision-making and improved user experiences across diverse applications.

Self-Reflective RAG and Logical Reasoning

Self-Reflective Retrieval Augmented Generation (RAG) is an advanced approach that enhances the capabilities of large language models (LLMs) by integrating logical reasoning into the retrieval and generation processes. This methodology addresses the limitations of traditional LLMs, which often rely solely on their pre-trained knowledge, leading to issues such as outdated information and hallucinations in generated responses. By incorporating external data sources, RAG allows LLMs to access up-to-date and contextually relevant information, thereby improving the accuracy and reliability of their outputs[4]].

The self-reflective aspect of RAG emphasizes the importance of logical reasoning in determining when and how to retrieve information. This involves several critical decision points, such as assessing the relevance of retrieved documents, rephrasing queries for better retrieval outcomes, and deciding when to discard irrelevant information and attempt retrieval again. The concept of self-reflective RAG captures the idea of using LLMs to evaluate and correct their own outputs, thereby enhancing the overall quality of the generated content[6]].

In practice, self-reflective RAG operates through a structured flow that includes multiple stages: retrieval, evaluation, and generation. Initially, a user query is processed to retrieve relevant documents from an external knowledge base. The LLM then evaluates the quality of these documents, determining their relevance to the query. If the retrieved documents are deemed insufficient, the LLM can reformulate the query and initiate a new retrieval process. This iterative approach allows for continuous improvement in the quality of the information being utilized, ultimately leading to more accurate and contextually appropriate responses[1]].

Logical reasoning plays a pivotal role in this self-reflective process. For instance, the LLM can employ state machines to define a series of steps that guide its decision-making, such as grading the relevance of documents and determining whether to re-attempt retrieval based on the evaluation results. This structured reasoning enables the LLM to adapt its approach dynamically, ensuring that it leverages the most pertinent information available[6]].

Moreover, the integration of self-reflective mechanisms allows RAG systems to not only enhance the retrieval process but also to refine the generation phase. By critically assessing the outputs generated from the retrieved data, the LLM can identify areas for improvement and make necessary adjustments, thereby reducing the likelihood of generating irrelevant or incorrect information. This self-correcting capability is particularly valuable in applications requiring high levels of accuracy and reliability, such as customer support systems and knowledge management tools[4]][[6]].

In summary, Self-Reflective RAG represents a significant advancement in the field of LLMs, combining the strengths of retrieval-augmented generation with logical reasoning to create a more robust and adaptive system. By enabling LLMs to self-evaluate and refine their outputs, this approach not only enhances the quality of information retrieval but also improves the overall effectiveness of generative AI applications.

Developing RAG Applications with Elixir

Elixir presents a compelling option for developing Retrieval-Augmented Generation (RAG) applications, particularly due to its strengths in concurrency and scalability. One of the primary advantages of using Elixir is its underlying Erlang VM (BEAM), which is designed for handling numerous concurrent processes efficiently. This capability is crucial for RAG applications that often require simultaneous handling of multiple user queries and data retrieval tasks. The lightweight process model in Elixir allows developers to create applications that can scale horizontally, accommodating increased loads without significant performance degradation[[8]].

Moreover, Elixir's immutable data structures and functional programming paradigm contribute to building robust and fault-tolerant systems. In RAG applications, where data integrity and consistency are paramount, these features help prevent issues related to shared state and mutable data, which can lead to unpredictable behavior in concurrent environments. This is particularly beneficial when integrating various components of a RAG system, such as data retrieval, processing, and response generation, as it ensures that each component operates independently and reliably[[8]].

However, there are challenges associated with developing RAG applications in Elixir. One significant hurdle is the relative immaturity of the ecosystem compared to more established languages like Python or JavaScript, which have extensive libraries and frameworks specifically designed for machine learning and natural language processing tasks. While Elixir has made strides with libraries like Bumblebee and Axon for machine learning, the available tools for implementing RAG-specific functionalities, such as vector databases and advanced retrieval techniques, are still developing. This can lead to increased development time as teams may need to build custom solutions or adapt existing libraries to fit their needs[[8]].

Additionally, the integration of RAG with Elixir may require a deeper understanding of both the language and the underlying machine learning concepts. Developers familiar with Elixir may find themselves needing to learn about embedding models, vector search algorithms, and the intricacies of LLMs (Large Language Models) to effectively implement RAG systems. This learning curve can be a barrier for teams looking to adopt Elixir for RAG applications, especially if they are accustomed to the more straightforward implementations available in other languages[[8]].

In summary, while Elixir offers significant advantages in concurrency and scalability for RAG applications, the challenges related to ecosystem maturity and the need for specialized knowledge can complicate the development process. As the Elixir community continues to grow and more tools become available, it may become an increasingly viable option for building sophisticated RAG systems.

Mosaic AI Agent Framework for RAG

The Mosaic AI Agent Framework on Databricks provides a robust environment for developing and evaluating Retrieval Augmented Generation (RAG) applications. This framework is designed to streamline the entire lifecycle of RAG application development, from initial design to deployment and evaluation, leveraging the capabilities of large language models (LLMs) in conjunction with external data sources.

One of the key features of the Mosaic AI Agent Framework is its end-to-end LLMOps workflow, which allows developers to iterate quickly on various aspects of RAG development. This includes the ability to create and log agents using any library, as well as utilizing MLflow for tracking experiments and managing model versions. The framework supports parameterization of agents, enabling rapid experimentation and iteration, which is crucial for optimizing RAG applications to meet specific user needs and performance metrics[[5]].

The framework also facilitates the deployment of agents to production with native support for token streaming and request/response logging. This built-in review app allows developers to gather user feedback, ensuring that the RAG applications are not only functional but also aligned with user expectations and requirements. Additionally, agent tracing capabilities enable developers to log, analyze, and compare traces across their agent code, which is essential for debugging and understanding how agents respond to various requests[[5]].

In terms of RAG functionality, the framework enhances LLMs by integrating external knowledge sources, which significantly improves the accuracy and relevance of generated responses. This is achieved through a structured retrieval process where user queries are used to fetch relevant data from vector databases or other external sources. The retrieved information is then combined with the user’s request to create a comprehensive prompt for the LLM, which generates a contextually informed response. This process not only allows for the inclusion of proprietary and up-to-date information but also enables the LLM to cite specific sources, enhancing the credibility of its outputs[4]].

Moreover, the Mosaic AI Agent Framework incorporates advanced evaluation tools that assist developers in assessing the quality, cost, and latency of their RAG applications. The AI-assisted Agent Evaluation feature includes a review app for collecting feedback from expert stakeholders, proprietary LLM judges for evaluating retrieval and request quality, and performance metrics that track latency and token costs. This comprehensive evaluation process ensures that RAG applications meet high standards of performance and reliability before they are fully deployed[[5]].

The integration of structured and unstructured data handling within the framework further enhances its versatility. Developers can ingest data from various sources, process it, and index it for efficient retrieval, making it suitable for a wide range of applications, from customer support chatbots to knowledge engines. The ability to handle both types of data allows for a more flexible approach to RAG implementation, catering to diverse use cases and user requirements[[5]].

Overall, the Mosaic AI Agent Framework on Databricks stands out as a powerful tool for developers looking to create sophisticated RAG applications. Its combination of rapid iteration capabilities, robust deployment features, and comprehensive evaluation tools makes it an ideal choice for organizations aiming to leverage the full potential of generative AI in their operations.

InterviewerGPT: Innovations in Conversational Agents

The InterviewerGPT Agent represents a significant evolution in the realm of conversational agents, particularly when compared to traditional question-answering systems. Unlike conventional systems that primarily focus on providing direct answers to user queries, the InterviewerGPT Agent is designed to engage users in a more interactive and dynamic manner, simulating the experience of a real-life interviewer. This capability is particularly beneficial in contexts such as job interviews and medical diagnostics, where the quality of interaction can significantly influence outcomes.

In job interviews, the InterviewerGPT Agent can facilitate a structured dialogue by asking relevant questions based on the candidate's responses, thereby creating a more natural flow of conversation. This approach allows the agent to assess not only the candidate's qualifications but also their soft skills, such as communication and critical thinking abilities. By employing Retrieval-Augmented Generation (RAG) techniques, the agent can pull in relevant information from external databases or documents, ensuring that the questions posed are contextually appropriate and tailored to the specific role being applied for[[10]]. This level of customization enhances the candidate's experience and provides recruiters with richer insights into the candidate's fit for the position.

In the medical field, the InterviewerGPT Agent can be utilized for diagnostic purposes, where it engages patients in a conversational format to gather symptoms and medical history. This method allows for a more thorough exploration of the patient's condition, as the agent can adapt its questions based on the patient's responses, similar to how a healthcare professional would conduct an interview. By integrating RAG, the agent can access up-to-date medical literature and guidelines, ensuring that the questions are informed by the latest research and best practices in healthcare[[12]]. This capability not only aids in accurate diagnosis but also empowers patients by making them feel heard and understood during the consultation process.

The distinction between the InterviewerGPT Agent and traditional question-answering systems lies in its ability to maintain context and adapt to the flow of conversation. Traditional systems often struggle with maintaining coherence over multiple turns of dialogue, leading to disjointed interactions. In contrast, the InterviewerGPT Agent leverages advanced algorithms to track the conversation's context, allowing it to ask follow-up questions that are relevant to previous answers, thereby creating a more engaging and meaningful dialogue[[6]]. This adaptability is crucial in both job interviews and medical diagnostics, where the nuances of conversation can lead to better outcomes.

Overall, the InterviewerGPT Agent exemplifies the potential of conversational AI to transform traditional processes in recruitment and healthcare. By moving beyond simple question-answering capabilities and embracing a more interactive, context-aware approach, this agent not only enhances user experience but also improves the quality of information gathered, ultimately leading to more informed decisions in both hiring and patient care[4]].

Enhancing LLM Performance in Specific Contexts

To enhance the performance of Large Language Models (LLMs) in specific contexts such as sales order data processing, several strategies can be employed, particularly through the integration of Retrieval-Augmented Generation (RAG) techniques. RAG allows LLMs to access external knowledge bases, which can significantly improve the accuracy and relevance of the generated responses. This is particularly useful in scenarios where up-to-date or domain-specific information is crucial, such as processing sales orders that may involve fluctuating prices or inventory levels[1]].

One effective strategy is to implement a structured RAG flow that includes multiple stages: retrieval, augmentation, and generation. In the retrieval phase, relevant documents or data points are fetched from a knowledge base or database, such as a price list or customer engagement records. This can be achieved using vector databases that allow for semantic searches, ensuring that the most pertinent information is retrieved based on the user's query[5]]. For instance, when a sales manager queries about a specific product's price, the system can quickly retrieve the latest pricing information from a database, which is then used to inform the LLM's response.

The augmentation phase involves combining the retrieved data with the user's original query to create a more contextually rich prompt for the LLM. This step is crucial as it ensures that the LLM generates responses that are not only relevant but also grounded in the most current data available. Effective prompt engineering during this phase can significantly enhance the quality of the output, making it more aligned with the user's needs[4]].

In addition to these strategies, feedback mechanisms play a vital role in refining the performance of LLMs in specific contexts. Implementing self-reflective RAG systems can allow the LLM to evaluate the quality of its responses and the relevance of the retrieved documents. For example, if the LLM generates a response that does not meet a certain threshold of relevance or accuracy, it can trigger a re-evaluation of the retrieved documents or even rephrase the query to fetch better results. This iterative process can help in continuously improving the model's performance over time[6]].

Moreover, integrating guardrails into the RAG process can streamline decision-making and enhance efficiency. By defining canonical forms of user queries, the system can quickly determine when to trigger the RAG pipeline, thus reducing latency and improving response times. This approach allows for a more dynamic interaction with users, as the system can adapt to various query types and contexts without the need for extensive LLM calls, which can be slow and costly[1]].

In summary, employing a structured RAG flow, enhancing prompt engineering, and integrating robust feedback mechanisms are key strategies for improving the performance of LLMs in specific contexts like sales order data processing. These methods not only enhance the accuracy and relevance of the generated responses but also ensure that the system remains adaptable to changing data and user needs.

References

[1] Making Retrieval Augmented Gen...(https://www.pinecone.io/learn/fast-retrieval-augmented-generation/)

[2] Agree & Join LinkedIn By click...(https://www.linkedin.com/posts/gbayer_insightful-post-about-the-state-of-llm-agents-activity-7185102189550309376-Udla)

[3] Navigation Menu Search code, r...(https://github.com/langchain-ai/langgraph/discussions/685)

[4] Retrieval augmented generation...(https://stackoverflow.blog/2023/10/18/retrieval-augmented-generation-keeping-llms-relevant-and-current/)

[5] Get started Load & manage data...(https://docs.databricks.com/en/generative-ai/retrieval-augmented-generation.html)

[6] Self-Reflective RAG with LangG...(https://blog.langchain.dev/agentic-rag-with-langgraph/)

[7] Sign up Sign in Sign up Sign i...(https://medium.com/@yufan1602/modular-rag-and-rag-flow-part-ii-77b62bf8a5d3)

[8] RAG app using Elixir. Feasible...(https://elixirforum.com/t/rag-app-using-elixir-feasible/60439)

[9] RAG tool Introduced 2.13 The R...(https://opensearch.org/docs/latest/ml-commons-plugin/agents-tools/tools/rag-tool/)

[10] Interviewer Agent (Rather than...(https://community.openai.com/t/interviewer-agent-rather-than-q-a-agent/320527)

[11] I have seen the AI make calls ...(https://www.linkedin.com/posts/gbayer_insightful-post-about-the-state-of-llm-agents-activity-7185102189550309376-Udla)

[12] filtered_record_content = {key...(https://github.com/langchain-ai/langgraph/discussions/685)

[13] CUSTOMER_ID = "C0001" SALES_MA...(https://github.com/langchain-ai/langgraph/discussions/685)


Start your journey today