-
Notifications
You must be signed in to change notification settings - Fork 3.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
### Motivation and Context <!-- Thank you for your contribution to the semantic-kernel repo! Please help reviewers and future users, providing the following information: 1. Why is this change required? 2. What problem does it solve? 3. What scenario does it contribute to? 4. If it fixes an open issue, please link to the issue here. --> ### Description <!-- Describe your changes, the overall approach, the underlying design. These notes will help understanding how your code works. Thanks! --> ### Contribution Checklist <!-- Before submitting this PR, please make sure: --> - [ ] The code builds clean without any errors or warnings - [ ] The PR follows the [SK Contribution Guidelines](https://github.com/microsoft/semantic-kernel/blob/main/CONTRIBUTING.md) and the [pre-submission formatting script](https://github.com/microsoft/semantic-kernel/blob/main/CONTRIBUTING.md#development-scripts) raises no violations - [ ] All unit tests pass, and I have added new tests where possible - [ ] I didn't break anyone 😄 --------- Co-authored-by: EvanChaki_MSFT <[email protected]> Co-authored-by: Roger Barreto <[email protected]>
- Loading branch information
1 parent
0aa04df
commit 9db225c
Showing
1 changed file
with
70 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
# Semantic Kernel Responsible AI FAQs | ||
|
||
## What is Microsoft Semantic Kernel? | ||
Microsoft Semantic Kernel is a lightweight, open-source development kit designed to facilitate the integration of AI models into applications written in languages such as C#, Python, or Java. | ||
|
||
It serves as efficient middleware that supports developers in building AI agents, automating business processes, and connecting their code with the latest AI technologies. Input to this system can range from text data to structured commands, and it produces various outputs, including natural language responses, function calls, and other actionable data. | ||
|
||
|
||
## What can Microsoft Semantic Kernel do? | ||
Building upon its foundational capabilities, Microsoft Semantic Kernel facilitates several functionalities: | ||
- AI Agent Development: Users can create agents capable of performing specific tasks or interactions based on user input. | ||
- Function Invocation: It can automate code execution by calling functions based on AI model outputs. | ||
- Modular and Extensible: Developers can enhance functionality through plugins and a variety of pre-built connectors, providing flexibility in integrating additional AI services. | ||
- Multi-Modal Support: The kernel easily expands existing applications to support modalities like voice and video through its architecture | ||
- Filtering: Developers can use filters to monitor the application, control function invocation or implement Responsible AI. | ||
- Prompt Templates: Developer can define their prompts using various template languages including Handlebars and Liquid or the built-in Semantic Kernel format. | ||
|
||
|
||
## What is/are Microsoft Semantic Kernel’s intended use(s)? | ||
The intended uses of Microsoft Semantic Kernel include: | ||
- Production Ready Applications: Building small to large enterprise scale solutions that can leverage advanced AI models capabilities. | ||
- Automation of Business Processes: Facilitating quick and efficient automation of workflows and tasks within organizations. | ||
- Integration of AI Services: Connecting client code with a variety of pre-built AI services and capabilities for rapid development. | ||
|
||
|
||
## How was Microsoft Semantic Kernel evaluated? What metrics are used to measure performance? | ||
Microsoft Semantic Kernel was reviewed for reliability and performance metrics that include: | ||
- Accuracy: Evaluated based on the correctness of the outputs generated against known facts. | ||
- Integration Speed: Assessed by the time taken to integrate AI models and initiate functional outputs based on telemetry. | ||
- Performance Consistency: Measurements taken to verify the system's reliability based on telemetry. | ||
|
||
|
||
## What are the limitations of Microsoft Semantic Kernel? | ||
Semantic Kernel integrates with Large Language Models (LLMs) to allow AI capabilities to be added to existing application. | ||
LLMs have some inherent limitations such as: | ||
- Contextual Misunderstanding: The system may struggle with nuanced requests, particularly those involving complex context. | ||
- Bias in LLM Outputs: Historical biases in the training data can inadvertently influence model outputs. | ||
- Users can mitigate these issues by: | ||
- Formulating clear and explicit queries. | ||
- Regularly reviewing AI-generated outputs to identify and rectify biases or inaccuracies. | ||
- Providing relevant information when prompting the LLM so that it can base it's responses on this data | ||
- Not all LLMs support all features uniformly e.g., function calling. | ||
Semantic Kernel is constantly evolving and adding new features so: | ||
- There are some components still being developed e.g., support for some modalities such as Video and Classification, memory connectors for certain Vector databases, AI connectors for certain AI services. | ||
- There are some components that are still experimental, these are clearly flagged and are subject to change. | ||
|
||
## What operational factors and settings allow for effective and responsible use of Microsoft Semantic Kernel? | ||
Operational factors and settings for optimal use include: | ||
- Custom Configuration Options: Users can tailor system parameters to match specific application needs, such as output style or verbosity. | ||
- Safe Operating Parameters: The system operates best within defined ranges of input complexity and length, ensuring reliability and safety. | ||
- Real-Time Monitoring: System behavior should be regularly monitored to detect unexpected patterns or malfunctions promptly. | ||
- Incorporate RAI and safety tools like Prompt Shield with filters to ensure responsible use. | ||
|
||
|
||
### Plugins and Extensibility | ||
|
||
#### What are plugins and how does Microsoft Semantic Kernel use them? | ||
Plugins are API calls that enhance and extend the capabilities of Microsoft Semantic Kernel by integrating with other services. They can be developed internally or by third-party developers, offering functionalities that users can toggle on or off based on their requirements. The kernel supports OpenAPI specifications, allowing for easy integration and sharing of plugins within developer teams. | ||
|
||
#### What data can Microsoft Semantic Kernel provide to plugins? What permissions do Microsoft Semantic Kernel plugins have? | ||
Plugins can access essential user information necessary for their operation, such as: | ||
- Input Context: Information directly related to the queries and commands issued to the system. | ||
- Execution Data: Results and performance metrics from previous operations, provided they adhere to user privacy standards. Developers retain control over plugin permissions, choosing what information plugins can access or transmit, ensuring compliance with data protection protocols. | ||
- Semantic Kernel supports filters which allow developers to integrate with RAI solutions | ||
|
||
#### What kinds of issues may arise when using Microsoft Semantic Kernel enabled with plugins? | ||
Potential issues that may arise include: | ||
- Invocation Failures: Incorrectly triggered plugins can result in unexpected outputs. | ||
- Output Misinformation: Errors in plugin handling can lead to generation of inaccurate or misleading results. | ||
- Dependency Compatibility: Changes in external dependencies may affect plugin functionality. To prevent these issues, users are advised to keep plugins updated and to rigorously test their implementations for stability and accuracy |