Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      CodeSOD: A Unique Way to Primary Key

      July 22, 2025

      BrowserStack launches Figma plugin for detecting accessibility issues in design phase

      July 22, 2025

      Parasoft brings agentic AI to service virtualization in latest release

      July 22, 2025

      Node.js vs. Python for Backend: 7 Reasons C-Level Leaders Choose Node.js Talent

      July 21, 2025

      The best CRM software with email marketing in 2025: Expert tested and reviewed

      July 22, 2025

      This multi-port car charger can power 4 gadgets at once – and it’s surprisingly cheap

      July 22, 2025

      I’m a wearables editor and here are the 7 Pixel Watch 4 rumors I’m most curious about

      July 22, 2025

      8 ways I quickly leveled up my Linux skills – and you can too

      July 22, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025
      Recent

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025

      Zero Trust & Cybersecurity Mesh: Your Org’s Survival Guide

      July 22, 2025

      Execute Ping Commands and Get Back Structured Data in PHP

      July 22, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025
      Recent

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025

      “I don’t think I changed his mind” — NVIDIA CEO comments on H20 AI GPU sales resuming in China following a meeting with President Trump

      July 22, 2025

      Galaxy Z Fold 7 review: Six years later — Samsung finally cracks the foldable code

      July 22, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»Development»Machine Learning»Use Amazon SageMaker Unified Studio to build complex AI workflows using Amazon Bedrock Flows

    Use Amazon SageMaker Unified Studio to build complex AI workflows using Amazon Bedrock Flows

    July 1, 2025

    Organizations face the challenge to manage data, multiple artificial intelligence and machine learning (AI/ML) tools, and workflows across different environments, impacting productivity and governance. A unified development environment consolidates data processing, model development, and AI application deployment into a single system. This integration streamlines workflows, enhances collaboration, and accelerates AI solution development from concept to production.

    The next generation of Amazon SageMaker is the center for your data, analytics, and AI. SageMaker brings together AWS AI/ML and analytics capabilities and delivers an integrated experience for analytics and AI with unified access to data. Amazon SageMaker Unified Studio is a single data and AI development environment where you can find and access your data and act on it using AWS analytics and AI/ML services, for SQL analytics, data processing, model development, and generative AI application development.

    With SageMaker Unified Studio, you can efficiently build generative AI applications in a trusted and secure environment using Amazon Bedrock. You can choose from a selection of high-performing foundation models (FMs) and advanced customization and tooling such as Amazon Bedrock Knowledge Bases, Amazon Bedrock Guardrails, Amazon Bedrock Agents, and Amazon Bedrock Flows. You can rapidly tailor and deploy generative AI applications, and share with the built-in catalog for discovery.

    In this post, we demonstrate how you can use SageMaker Unified Studio to create complex AI workflows using Amazon Bedrock Flows.

    Solution overview

    Consider FinAssist Corp, a leading financial institution developing a generative AI-powered agent support application. The solution offers the following key features:

    • Complaint reference system – An AI-powered system providing quick access to historical complaint data, enabling customer service representatives to efficiently handle customer follow-ups, support internal audits, and aid in training new staff.
    • Intelligent knowledge base – A comprehensive data source of resolved complaints that quickly retrieves relevant complaint details, resolution actions, and outcome summaries.
    • Streamlined workflow management – Enhanced consistency in customer communications through standardized access to past case information, supporting compliance checks and process improvement initiatives.
    • Flexible query capability – A straightforward interface supporting various query scenarios, from customer inquiries about past resolutions to internal reviews of complaint handling procedures.

    Let’s explore how SageMaker Unified Studio and Amazon Bedrock Flows, integrated with Amazon Bedrock Knowledge Bases and Amazon Bedrock Agents, address these challenges by creating an AI-powered complaint reference system. The following diagram illustrates the solution architecture.

    The solution uses the following key components:

    • SageMaker Unified Studio – Provides the development environment
    • Flow app – Orchestrates the workflow, including:
      • Knowledge base queries
      • Prompt-based classification
      • Conditional routing
      • Agent-based response generation

    The workflow processes user queries through the following steps:

    1. A user submits a complaint-related question.
    2. The knowledge base provides relevant complaint information.
    3. The prompt classifies if the query is about resolution timing.
    4. Based on the classification using the condition, the application takes the following action:
      1. Routes the query to an AI agent for specific resolution responses.
      2. Returns general complaint information.
    5. The application generates an appropriate response for the user.

    Prerequisites

    For this example, you need the following:

    • Access to SageMaker Unified Studio. (You will need the SageMaker Unified Studio portal URL from your administrator). You can authenticate using either:
      • AWS Identity and Access Management (IAM) user credentials.
      • Single sign-on (SSO) credentials with AWS IAM Identity Center.
    • The IAM user or IAM Identity Center user must have appropriate permissions for:
      • SageMaker Unified Studio.
      • Amazon Bedrock (including Amazon Bedrock Flows, Amazon Bedrock Agents, Amazon Bedrock Prompt Management, and Amazon Bedrock Knowledge Bases).
      • For more information, refer to Identity-based policy examples.
    • Access to Amazon Bedrock FMs (make sure these are enabled for your account), for example:Anthropic’s Claude 3 Haiku (for the agent).
    • Configure access to your Amazon Bedrock serverless models for Amazon Bedrock in SageMaker Unified Studio projects.
    • Amazon Titan Embedding (for the knowledge base).
    • Sample complaint data prepared in CSV format for creating the knowledge base.

    Prepare your data

    We have created a sample dataset to use for Amazon Bedrock Knowledge Bases. This dataset has information of complaints received by customer service representatives and resolution information.The following is an example from the sample dataset:

    complaint_id,product,sub_product,issue,sub_issue,complaint_summary,action_taken,next_steps,financial_institution,state,submitted_via,resolution_type,timely_response
    FIN-2024-001,04/26/24,"Mortgage","Conventional mortgage","Payment issue","Escrow dispute","Customer disputes mortgage payment increase after recent escrow analysis","Reviewed escrow analysis, explained property tax increase impact, provided detailed payment breakdown","1. Send written explanation of escrow analysis 2. Schedule annual escrow review 3. Provide payment assistance options","Financial Institution-1","TX","Web","Closed with explanation","Yes"
    FIN-2024-002,04/26/24,"Money transfer","Wire transfer","Processing delay","International transfer","Wire transfer of $10,000 delayed, customer concerned about international payment deadline","Located wire transfer in system, expedited processing, waived wire fee","1. Confirm receipt with receiving bank 2. Update customer on delivery 3. Document process improvement needs","Financial Institution-2","FL","Phone","Closed with monetary relief","No"

    Create a project

    In SageMaker Unified Studio, users can use projects to collaborate on various business use cases. Within projects, you can manage data assets in the SageMaker Unified Studio catalog, perform data analysis, organize workflows, develop ML models, build generative AI applications, and more.

    To create a project, complete the following steps:

    1. Open the SageMaker Unified Studio landing page using the URL from your admin.
    2. Choose Create project.
    3. Enter a project name and optional description.
    4. For Project profile, choose Generative AI application development.
    5. Choose Continue.

    1. Complete your project configuration, then choose Create project.

    Create a prompt

    Let’s create a reusable prompt to capture the instructions for FMs, which we will use later while creating the flow application. For more information, see Reuse and share Amazon Bedrock prompts.

    1. In SageMaker Unified Studio, on the Build menu, choose Prompt under Machine Learning & Generative AI.

    1. Provide a name for the prompt.
    2. Choose the appropriate FM (for this example, we choose Claude 3 Haiku).
    3. For Prompt message, we enter the following:
    You are a complaint analysis classifier. You will receive complaint data from a knowledge base. Analyze the {{input}} and respond with a single letter:
    T: If the input contains information about complaint resolution timing, response time, or processing timeline (whether timely or delayed)
    F: For all other types of complaint information
    Return only 'T' or 'F' based on whether the knowledge base response is about resolution timing. Do not add any additional text or explanation - respond with just the single letter 'T' or 'F'.
    1. Choose Save.

    1. Choose Create version.

    Create a chat agent

    Let’s create a chat agent to handle specific resolution responses. Complete the following steps:

    1. In SageMaker Unified Studio, on the Build menu, choose Chat agent under Machine Learning & Generative AI.
    2. Provide a name for the prompt.
    3. Choose the appropriate FM (for this example, we choose Claude 3 Haiku).
    4. For Enter a system prompt, we enter the following:
    You are a Financial Complaints Assistant AI. You will receive complaint information from a knowledge base and questions about resolution timing.
    When responding to resolution timing queries:
    1. Use the provided complaint information to confirm if it was resolved within timeline
    2. For timely resolutions, provide:
       - Confirmation of timely completion
       - Specific actions taken (from the provided complaint data)
       - Next steps that were completed
    2. For delayed resolutions, provide:
       - Acknowledgment of delay
       - Standard compensation package:
         • $75 service credit
         • Priority Status upgrade for 6 months
         • Service fees waived for current billing cycle
       - Actions taken (from the provided complaint data)
       - Contact information for follow-up: Priority Line: ************** 
    Always reference the specific complaint details provided in your input when discussing actions taken and resolution process.
    1. Choose Save.

    1. After the agent is saved, choose Deploy.
    2. For Alias name, enter demoAlias.
    3. Choose Deploy.

    Create a flow

    Now that we have our prompt and agent ready, let’s create a flow that will orchestrate the complaint handling process:

    1. In SageMaker Unified Studio, on the Build menu, choose Flow under Machine Learning & Generative AI.

    1. Create a new flow called demo-flow.

    Add a knowledge base to your flow application

    Complete the following steps to add a knowledge base node to the flow:

    1. In the navigation pane, on the Nodes tab, choose Knowledge Base.
    2. On the Configure tab, provide the following information:
      1. For Node name, enter a name (for example, complaints_kb).
      2. Choose Create new Knowledge Base.
    3. In the Create Knowledge Base pane, enter the following information:
      1. For Name, enter a name (for example, complaints).
      2. For Description, enter a description (for example, user complaints information).
      3. For Add data sources, select Local file and upload the complaints.txt file.
      4. For Embeddings model, choose Titan Text Embeddings V2.
      5. For Vector store, choose OpenSearch Serverless.
      6. Choose Create.

    1. After you create the knowledge base, choose it in the flow.
    2. In the details name, provide the following information:
    3. For Response generation model, choose Claude 3 Haiku.
    4. Connect the output of the flow input node with the input of the knowledge base node.
    5. Connect the output of the knowledge base node with the input of the flow output node.

    1. Choose Save.

    Add a prompt to your flow application

    Now let’s add the prompt you created earlier to the flow:

    1. On the Nodes tab in the Flow app builder pane, add a prompt node.
    2. On the Configure tab for the prompt node, provide the following information:
    3. For Node name, enter a name (for example, demo_prompt).
    4. For Prompt, choose financeAssistantPrompt.
    5. For Version, choose 1.
    6. Connect the output of the knowledge base node with the input of the prompt node.
    7. Choose Save.

    Add a condition to your flow application

    The condition node determines how the flow handles different types of queries. It evaluates whether a query is about resolution timing or general complaint information, enabling the flow to route the query appropriately. When a query is about resolution timing, it will be directed to the chat agent for specialized handling; otherwise, it will receive a direct response from the knowledge base. Complete the following steps to add a condition:

    1. On the Nodes tab in the Flow app builder pane, add a condition node.
    2. On the Configure tab for the condition node, provide the following information:
      1. For Node name, enter a name (for example, demo_condition).
      2. Under Conditions, for Condition, enter conditionInput == "T".
      3. Connect the output of the prompt node with the input of the condition node.
    3. Choose Save.

    Add a chat agent to your flow application

    Now let’s add the chat agent you created earlier to the flow:

    1. On the Nodes tab in the Flow app builder pane, add the agent node.
    2. On the Configure tab for the agent node, provide the following information:
      1. For Node name, enter a name (for example, demo_agent).
      2. For Chat agent, choose DemoAgent.
      3. For Alias, choose demoAlias.
    3. Create the following node connections:
      1. Connect the input of the condition node (demo_condition) to the output of the prompt node (demo_prompt).
      2. Connect the output of the condition node:
        1. Set If condition is true to the agent node (demo_agent).
        2. Set If condition is false to the existing flow output node (FlowOutputNode).
      3. Connect the output of the knowledge base node (complaints_kb) to the input of the following:
        1. The agent node (demo_agent).
        2. The flow output node (FlowOutputNode).
      4. Connect the output of the agent node (demo_agent) to a new flow output node named FlowOutputNode_2.
    4. Choose Save.

    Test the flow application

    Now that the flow application is ready, let’s test it. On the right side of the page, choose the expand icon to open the Test pane.

    In the Enter prompt text box, we can ask a few questions related to the dataset created earlier. The following screenshots show some examples.

    Clean up

    To clean up your resources, delete the flow, agent, prompt, knowledge base, and associated OpenSearch Serverless resources.

    Conclusion

    In this post, we demonstrated how to build an AI-powered complaint reference system using a flow application in SageMaker Unified Studio. By using the integrated capabilities of SageMaker Unified Studio with Amazon Bedrock features like Amazon Bedrock Knowledge Bases, Amazon Bedrock Agents, and Amazon Bedrock Flows, you can rapidly develop and deploy sophisticated AI applications without extensive coding.

    As you build AI workflows using SageMaker Unified Studio, remember to adhere to the AWS Shared Responsibility Model for security. Implement SageMaker Unified Studio security best practices, including proper IAM configurations and data encryption. You can also refer to Secure a generative AI assistant with OWASP Top 10 mitigation for details on how to assess the security posture of a generative AI assistant using OWASP TOP 10 mitigations for common threats. Following these guidelines helps establish robust AI applications that maintain data integrity and system protection.

    To learn more, refer to Amazon Bedrock in SageMaker Unified Studio and join discussions and share your experiences in AWS Generative AI Community.

    We look forward to seeing the innovative solutions you will create with these powerful new features.


    About the authors

    Sumeet Tripathi is an Enterprise Support Lead (TAM) at AWS in North Carolina. He has over 17 years of experience in technology across various roles. He is passionate about helping customers to reduce operational challenges and friction. His focus area is AI/ML and Energy & Utilities Segment. Outside work, He enjoys traveling with family, watching cricket and movies.

    Vishal Naik is a Sr. Solutions Architect at Amazon Web Services (AWS). He is a builder who enjoys helping customers accomplish their business needs and solve complex challenges with AWS solutions and best practices. His core area of focus includes Generative AI and Machine Learning. In his spare time, Vishal loves making short films on time travel and alternate universe themes.

    Source: Read More 

    Facebook Twitter Reddit Email Copy Link
    Previous ArticleTen Forward – control a NAT-PMP gateway
    Next Article Accelerating AI innovation: Scale MCP servers for enterprise workloads with Amazon Bedrock

    Related Posts

    Machine Learning

    How to Evaluate Jailbreak Methods: A Case Study with the StrongREJECT Benchmark

    July 22, 2025
    Machine Learning

    Boolformer: Symbolic Regression of Logic Functions with Transformers

    July 22, 2025
    Leave A Reply Cancel Reply

    For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

    Continue Reading

    AEM Universal Editor: A Simpler, Smarter Way to Create Content

    AEM Universal Editor: A Simpler, Smarter Way to Create Content

    Development

    AMD Warns of New Transient Scheduler Attacks Impacting a Wide Range of CPUs

    Security

    My favorite headphones for watching movies are at their lowest price for Prime Day

    News & Updates

    Preorder the new Nothing Phone 3 at Amazon and get double the storage and $100 off

    News & Updates

    Highlights

    I changed 8 settings on my Pixel phone to significantly improve the battery life

    May 27, 2025

    With the right battery tweaks, your Pixel can last longer than ever, during the day…

    Google DeepMind at ICML 2024

    May 13, 2025

    Quantum Systems raises €160M for AI-powered aerial intelligence

    May 6, 2025

    Transport Management System (TMS) for Carriers: Features, Benefits, and Best Practices [2025 Guide]

    May 8, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.