You are on fire!
If you are here, you should have been successful in completing a basic version of your recipe recommendation agent. You will have been able to implement this basic version by following the project instructions in the other sections. This will already enable you to pass the project, that is, if you also write a good report (see Final Report ).
An implementation of only this basic version, however, will not get you a (very) high grade (see the 2024 Assessment Rubric for more information). Therefore, we encourage you to read through this section. It will provide you with some ideas of how you can extend your recipe recommendation agent. By implementing extensions, you will be able to improve your grade.
First of all, we want to emphasize that you can implement any extension that you can think of that makes sense (argue for that in your report). We thus want to encourage you to be creative! Feel free, for example, to add anything that you think will enhance user experience. The more creative, innovative, or sophisticated your design idea is and the better your implementation of it is, the more points you will get for it. Feel free to go beyond what we have suggested for this reason. Even if your design idea has not been perfectly implemented and testing still reveals issues with it, we may still award you some points if you explain everything well in your report: you should justify the extensions and, in case it is not working optimally, explain what is not working and how you could fix it.
There are a lot of suggestions we provide below that you may consider extending your agent. Again, we provide some examples below, but you should feel free to explore other options we do not mention below. The list has been ordered from the relatively easier extensions to more elaborate extensions. Of course, this also depends on the effort that you put into it!
Here is the list of suggestions that you can use for inspiration:
Add a Filter: Make a new filter by adding a rule and entity to filter recipes in a new way.
Add a Capability: The basic agent is quite limited in what it can do, so you could add, for example:
Check if the user has all the ingredients: before confirming the recipe, your agent could ask the user if they have the ingredients the recipe requires, so they can check before starting. This would require a new page, pattern, and response.
Ask to restart or quit at any point in time: you would need to add a pattern, intent, entity, etc.
Repair: Add more advanced handling for repair of a conversational breakdown. There is a lot you can work on:
Agents should have helpful recovery prompts for each step of the dialog. Check out this and other Best practices for repair suggested by Google.
More specific feedback: rather than stating misunderstanding, the agent could provide more information on what aspect of the user utterance it did not understand, or provide pointers to what the user can say at that point in the conversation.
Suggest alternatives: A breakdown may be due to the fact that a user does not know how to continue the conversation. In that case, the agent could suggest one or more ways to continue.
User-initiated repair: It may also happen that a user initiates repair (e.g, “I don’t understand that”, “what do you mean by ‘X’?”). Add a capability that enables the agent to know how to respond to such a user move. That is, make the agent understand such user-initiated repair, and respond with an appropriate explanation to address the user’s move.
Small talk capabilities related to the recipe domain: small talk can make the agent more engaging for a user. It would require you to think of small talk patterns, either initiated by the user or by the agent, that can be naturally integrated at some point in the recipe recommendation conversation. You would need one or more new intents, patterns, and responses.
Extend Visuals: In the visuals section, we already talk about ways to extend it. We mostly mentioned some aesthetic changes that you can add. Now, we are specifically referring to extending the functionality of the visuals, i.e. adding something that makes the visuals more supportive. An example would be to show the filtering history at any point. Another example would be to add a rating system for the agent to get feedback. However, keep in mind that the interaction should primarily be conversational in nature!
Agent personality, style, and characteristics: You can work on designing and shaping the responses from your agent to suggest a particular personality, to provide it with a specific conversational style, or with social characteristics that may increase the user experience. See e.g. this paper for more ideas.
We can highly recommend more than one extension, unless the extension is a large and time-consuming one. We will rate extensions on perceived added contribution to the agent. Multiple useful smaller things that contribute about the same as one bigger thing will merit about the same grade. Also see the 2024 Assessment Rubric .