Building a Horoscope app with Gemini AI & SwiftUI
Watch the video or follow along with the post below.
Previously, we saw how to easily integrate the Gemini AI SDK to perform simple text-only interactions, then created a multi-turn chat interface & followed it up with a multimodal chat interface that combined sending images as well as text. In this post we’ll look at one of the important capabilities of AI models i.e. Summarization.
You may have seen this when browsing the reviews section of Amazon where before the actual reviews, you see an AI generated summary of the reviews posted for the given product. For those unfamiliar, it looks something like this.
Most LLM’s these days are capable of summarization. The following text extract from Google’s Document AI best describes it:
Put simply, AI summarization is the use of AI technologies to distill text, documents, or content into a short and easily digestible format. For example, AI summarization can use natural language processing or understanding to condense a long PDF and restate its most important takeaways in just a few sentences.
This is extremely beneficial, again as described by Google’s Document AI
The benefits of AI summarization range from cost savings to improved accessibility to information. AI summarization can help businesses and organizations save time and money when producing research, business intelligence, or insights. AI-powered summarization can extract key information from news articles, research, legal and financial documents, technical literature, and even customer feedback. Summarization, then, means more time acting on information instead of sifting through it.
Broadly speaking, summarization helps you get to the juicy bits of information from the vast sea of data that exists. This data could be a book or as mentioned above, user reviews of a product on an e-commerce website.
I hadn’t really explored Gemini AI’s summarization capability until I was playing around with prompts in Google AI Studio
when I thought it would be cool to apply the technique of summarization with a twist. Enter tones
. We can ask Gemini to respond with a specific tone during our conversation. When queried about conversational tones, this is what Gemini responded with:
How can I set the conversation tone? What are the available options?
Available options for setting the conversation tone:
- Formal: Use polite and respectful language, avoid slang or colloquialisms, and maintain a professional demeanor.
- Informal: Use casual and conversational language, including slang or colloquialisms, and adopt a friendly and relaxed tone.
- Humorous: Infuse the conversation with humor, jokes, or witty remarks to create a lighthearted and enjoyable atmosphere.
- Serious: Maintain a somber and earnest tone, avoiding humor or casual language, and focus on discussing important or sensitive topics.
- Enthusiastic: Convey excitement and passion through your words and语气, using energetic language and expressive gestures.
- Empathetic: Demonstrate understanding and compassion by actively listening, using empathetic statements, and showing concern for the other person’s feelings.
- Assertive: Express your thoughts, feelings, and opinions confidently and directly, while respecting the other person’s perspective.
- Passive: Avoid expressing your thoughts, feelings, or opinions directly, and instead focus on accommodating the other person’s needs and desires.
- Aggressive: Express your thoughts, feelings, and opinions forcefully and insistently, potentially disregarding the other person’s perspective.
- Neutral: Maintain a neutral and objective tone, avoiding strong emotions or opinions, and focusing on presenting facts and information.
Using this capability, we could easily modify the tone of conversation the AI model has with a user.
enum HoroscopeStyle: String, CaseIterable {
case original
case formal
case informal
case humorous
case serious
case enthusiastic
case pessimistic
case empathetic
case assertive
case passive
case aggressive
case neutral
}
And that’s what we will use in our horoscope application. The process is simple, first we get the daily horoscope for a user and depending on the tone/style
selected we ask Gemini AI to summarize the received horoscope and display it to the user for a more adventurous reading. The good thing about Google AI Studio is that it has a <> Get Code
option that provides you with template code in cURL, Python, JS, Kotlin or as in our case, Swift.
We begin by creating a simple UI that allows the user to switch between zodiac signs and select a tonal style before fetching the horoscope.
Which gives us something like this:
We then fetch the daily horoscope, in this case I’m using an api created by Ashutosh Krishna:
https://horoscope-app-api.vercel.app/
The API allows GET
requests with the sign
and the day
such as ‘today’, ‘tomorrow’ etc. We then ask Gemini AI to summarize the horoscope with the selected style with a prompt like so:
"Summarize the following horoscope with a \(currentStyle.rawValue) tone:\n "
Finally we display the summarized horoscope reading to the user.
Thanks to Gemini’s summarization capabilities, we managed to create a fun little horoscope application :) And that’s it! The complete code can be found here.
Leave a comment if you have any questions!