1. Introduction
  2. Research Objectives
  3. Data & Method Overview
  4. Conjoint Analysis
  5. Brand Perceptions & Attitudes toward UNO
  6. Purchase Intent & Willingness to Pay
  7. Consumer Segmentation (Demographics)
  8. Managerial Implications
  9. Limitations & Conclusion
library(readxl)
library(dplyr)
## 
## Attaching package: 'dplyr'
## The following objects are masked from 'package:stats':
## 
##     filter, lag
## The following objects are masked from 'package:base':
## 
##     intersect, setdiff, setequal, union
library(tidyr)
library(ggplot2)
library(broom)
library(forcats)

excel_path <- "UNO Survey Responses v4.xlsx"

1 Data Import (from scratch, explicit)

# Conjoint (individual-level)
conjointData <- read_excel(excel_path, sheet = "Conjoint_Long")

# UNO Brand & Attitudes (aggregated)
uno_q1 <- read_excel(excel_path, sheet = "UNO Question1")
uno_q2 <- read_excel(excel_path, sheet = "UNO Question2")
uno_q3 <- read_excel(excel_path, sheet = "UNO Question3")

# Demographics (aggregated)
ageData <- read_excel(excel_path, sheet = "Age")
incomeData <- read_excel(excel_path, sheet = "Income")
genderData <- read_excel(excel_path, sheet = "Gender")
educationData <- read_excel(excel_path, sheet = "Education")

Rule:
- conjointData → modeling
- everything else → visualization & interpretation


2 1. Introduction

The packaged bread market has evolved beyond basic functional needs, with consumers increasingly valuing health, quality, sustainability, and premium cues. UNO is a leading brand in this category and is well positioned to explore premium product extensions.

The objective of this study is to analyze consumer perceptions, behavioral intentions, and product attribute trade-offs related to packaged bread, with a specific focus on UNO. The analysis combines survey-based descriptive insights with a rating-based conjoint model to derive actionable managerial implications.

3 2. Conjoint Analysis

rating_model <- lm(
  Rating ~ Bread_Type + Slice_Type + Package_Type + Price,
  data = conjointData
)

summary(rating_model)
## 
## Call:
## lm(formula = Rating ~ Bread_Type + Slice_Type + Package_Type + 
##     Price, data = conjointData)
## 
## Residuals:
##     Min      1Q  Median      3Q     Max 
## -3.3940 -1.4284 -0.2546  1.3089  4.8860 
## 
## Coefficients:
##                         Estimate Std. Error t value Pr(>|t|)    
## (Intercept)              4.10782    0.17067  24.069  < 2e-16 ***
## Bread_TypeTraditional   -0.01912    0.12146  -0.157  0.87496    
## Bread_TypeWhole grain    0.38851    0.12146   3.199  0.00141 ** 
## Slice_TypeThick         -0.29523    0.12207  -2.419  0.01570 *  
## Slice_TypeThin          -0.37151    0.12740  -2.916  0.00360 ** 
## Package_TypePlastic Bag -0.89179    0.10087  -8.841  < 2e-16 ***
## Price150 TL             -0.78767    0.15431  -5.105 3.74e-07 ***
## Price25 TL              -0.10233    0.17102  -0.598  0.54969    
## Price35 TL              -0.17494    0.14914  -1.173  0.24098    
## Price50 TL              -0.35000    0.15710  -2.228  0.02604 *  
## ---
## Signif. codes:  0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
## 
## Residual standard error: 1.876 on 1484 degrees of freedom
## Multiple R-squared:  0.08997,    Adjusted R-squared:  0.08446 
## F-statistic:  16.3 on 9 and 1484 DF,  p-value: < 2.2e-16

📌 This is your only regression model in the project.


3.1 Coefficient plot (MANDATORY visual)

coef_df <- tidy(rating_model) %>%
  filter(term != "(Intercept)")

ggplot(coef_df, aes(x = estimate, y = reorder(term, estimate))) +
  geom_point(size = 3) +
  geom_errorbarh(
    aes(xmin = estimate - 1.96 * std.error,
        xmax = estimate + 1.96 * std.error),
    height = 0.2
  ) +
  geom_vline(xintercept = 0, linetype = "dashed") +
  labs(
    title = "Conjoint Part-Worth Utilities",
    x = "Impact on Rating",
    y = "Attribute Level"
  ) +
  theme_minimal()
## Warning: `geom_errorbarh()` was deprecated in ggplot2 4.0.0.
## ℹ Please use the `orientation` argument of `geom_errorbar()` instead.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.
## `height` was translated to `width`.


3.2 Price sensitivity (derived from conjoint)

conjointData %>%
  group_by(Price) %>%
  summarise(MeanRating = mean(Rating), .groups = "drop") %>%
  ggplot(aes(x = Price, y = MeanRating)) +
  geom_line() +
  geom_point(size = 2) +
  labs(
    title = "Price Sensitivity of Bread Ratings",
    x = "Price Level",
    y = "Average Rating"
  ) +
  theme_minimal()
## `geom_line()`: Each group consists of only one observation.
## ℹ Do you need to adjust the group aesthetic?


4 Demographic Profile (DESCRIPTIVE)

4.1 Demographic Profile of Respondents

ggplot(ageData, aes(x = Age_Range, y = Count)) +
  geom_col() +
  labs(
    title = "Age Distribution of Respondents",
    x = "Age Range",
    y = "Number of Respondents"
  ) +
  theme_minimal()

(Same logic for Income, Gender, Education → all geom_col())


5 UNO Question 1 – Brand Perceptions

5.1 Brand Perceptions of UNO

library(dplyr)
library(tidyr)
library(ggplot2)
library(stringr)

uno_q1_long <- uno_q1 %>%
  pivot_longer(
    cols = c("1","2","3","4","5"),
    names_to = "Level",
    values_to = "Count"
  ) %>%
  mutate(
    Level = factor(Level, levels = c("1","2","3","4","5")),
    Statement = UNO_Agreement_Level
  )

ggplot(uno_q1_long, aes(x = Level, y = Count)) +
  geom_col() +
  facet_wrap(~ Statement, ncol = 2, labeller = label_wrap_gen(width = 35)) +
  labs(
    title = "UNO Q1 – Agreement Distribution by Statement",
    x = "Agreement Level (1–5)",
    y = "Number of Respondents"
  ) +
  theme_minimal() +
  theme(
    legend.position = "none",
    strip.text = element_text(size = 10),
    axis.text.x = element_text(size = 9)
  )

5.2 Interpretation of Agreement Distributions

Figure X presents the distribution of agreement levels (1–5) for each brand statement related to UNO.
Across all statements, responses are concentrated around agreement levels 3 and 4, indicating a generally positive but moderate brand perception.

Statements related to quality, taste, and trust show low frequencies at the extreme negative end (level 1), suggesting that strong dissatisfaction is rare.
However, the relatively limited number of responses at level 5 indicates that very strong agreement is also uncommon.

Overall, these distributions suggest that UNO is perceived as a reliable, good-quality, and good-value everyday bread brand, rather than a strongly differentiated premium or innovative brand.
This moderate perception highlights both stability in current brand equity and potential room for improvement through targeted positioning and communication strategies.


6 UNO Question 2 – Action Likelihood (FUNNEL)

6.1 Behavioral Intentions toward UNO Premium Bread

library(dplyr)
library(tidyr)
library(ggplot2)

uno_q2_long <- uno_q2 %>%
  pivot_longer(
    cols = c("1","2","3","4","5","6","7"),
    names_to = "Likelihood_Level",
    values_to = "Count"
  ) %>%
  mutate(
    Likelihood_Level = factor(Likelihood_Level, levels = c("1","2","3","4","5","6","7")),
    Action = UNO_Premium_Bread_Action_Likelihood
  )

ggplot(uno_q2_long, aes(x = Likelihood_Level, y = Count)) +
  geom_col() +
  facet_wrap(~ Action, ncol = 2, labeller = label_wrap_gen(width = 35)) +
  labs(
    title = "UNO Q2 – Likelihood of Actions for Premium Bread",
    x = "Likelihood Level (1–7)",
    y = "Number of Respondents"
  ) +
  theme_minimal() +
  theme(
    legend.position = "none",
    strip.text = element_text(size = 10),
    axis.text.x = element_text(size = 9)
  )

6.2 Interpretation of Likelihood Distributions

Figure Y shows the distribution of likelihood levels (1–7) for different consumer actions related to a potential UNO premium bread line.
Across actions, responses tend to cluster around the mid-to-upper range (roughly levels 4–6), indicating generally positive but not extreme intentions.

Lower-commitment actions (e.g., trying at least once or buying on promotion) typically receive higher likelihood responses than higher-commitment actions (e.g., switching brands or purchasing weekly).
Overall, this suggests consumers are open to engaging with UNO’s premium offering, but stronger commitment may require clearer differentiation and a compelling value proposition.

---
title: "Data Insights for Marketing (MiM810) - Group4"
subtitle: "UNO Bread Consumer Survey & Conjoint Analysis Results"
author: "Group 4"
date: "`r format(Sys.Date(), '%B %d, %Y')`"
output:
  html_document:
    theme: flatly
    highlight: pygments
    toc: true
    toc_depth: 3
    toc_float:
      collapsed: true
      smooth_scroll: true
    number_sections: true
    code_folding: show
    code_download: true
    df_print: paged
    self_contained: true
    mathjax: default
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
```

1. Introduction
2. Research Objectives
3. Data & Method Overview
4. Conjoint Analysis
5. Brand Perceptions & Attitudes toward UNO
6. Purchase Intent & Willingness to Pay
7. Consumer Segmentation (Demographics)
8. Managerial Implications
9. Limitations & Conclusion


```{r package_install }

library(readxl)
library(dplyr)
library(tidyr)
library(ggplot2)
library(broom)
library(forcats)

excel_path <- "UNO Survey Responses v4.xlsx"

```


# Data Import (from scratch, explicit)

```{r data-import}
# Conjoint (individual-level)
conjointData <- read_excel(excel_path, sheet = "Conjoint_Long")

# UNO Brand & Attitudes (aggregated)
uno_q1 <- read_excel(excel_path, sheet = "UNO Question1")
uno_q2 <- read_excel(excel_path, sheet = "UNO Question2")
uno_q3 <- read_excel(excel_path, sheet = "UNO Question3")

# Demographics (aggregated)
ageData <- read_excel(excel_path, sheet = "Age")
incomeData <- read_excel(excel_path, sheet = "Income")
genderData <- read_excel(excel_path, sheet = "Gender")
educationData <- read_excel(excel_path, sheet = "Education")

```


**Rule:**  
- `conjointData` → modeling  
- everything else → visualization & interpretation

---

# 1. Introduction

The packaged bread market has evolved beyond basic functional needs, with consumers increasingly valuing health, quality, sustainability, and premium cues. UNO is a leading brand in this category and is well positioned to explore premium product extensions.

The objective of this study is to analyze consumer perceptions, behavioral intentions, and product attribute trade-offs related to packaged bread, with a specific focus on UNO. The analysis combines survey-based descriptive insights with a rating-based conjoint model to derive actionable managerial implications.

# 2. Conjoint Analysis

```{r conjoint-model}
rating_model <- lm(
  Rating ~ Bread_Type + Slice_Type + Package_Type + Price,
  data = conjointData
)

summary(rating_model)

```


📌 This is your **only regression model** in the project.

---

## Coefficient plot (MANDATORY visual)

```{r conjoint-coef-plot}
coef_df <- tidy(rating_model) %>%
  filter(term != "(Intercept)")

ggplot(coef_df, aes(x = estimate, y = reorder(term, estimate))) +
  geom_point(size = 3) +
  geom_errorbarh(
    aes(xmin = estimate - 1.96 * std.error,
        xmax = estimate + 1.96 * std.error),
    height = 0.2
  ) +
  geom_vline(xintercept = 0, linetype = "dashed") +
  labs(
    title = "Conjoint Part-Worth Utilities",
    x = "Impact on Rating",
    y = "Attribute Level"
  ) +
  theme_minimal()
```


---

## Price sensitivity (derived from conjoint)


```{r conjoint-price}
conjointData %>%
  group_by(Price) %>%
  summarise(MeanRating = mean(Rating), .groups = "drop") %>%
  ggplot(aes(x = Price, y = MeanRating)) +
  geom_line() +
  geom_point(size = 2) +
  labs(
    title = "Price Sensitivity of Bread Ratings",
    x = "Price Level",
    y = "Average Rating"
  ) +
  theme_minimal()
```



---

# Demographic Profile (DESCRIPTIVE)

## Demographic Profile of Respondents

```{r age-plot}
ggplot(ageData, aes(x = Age_Range, y = Count)) +
  geom_col() +
  labs(
    title = "Age Distribution of Respondents",
    x = "Age Range",
    y = "Number of Respondents"
  ) +
  theme_minimal()

```


(Same logic for Income, Gender, Education → all `geom_col()`)

---

# UNO Question 1 – Brand Perceptions

## Brand Perceptions of UNO

```{r uno-q1}

library(dplyr)
library(tidyr)
library(ggplot2)
library(stringr)

uno_q1_long <- uno_q1 %>%
  pivot_longer(
    cols = c("1","2","3","4","5"),
    names_to = "Level",
    values_to = "Count"
  ) %>%
  mutate(
    Level = factor(Level, levels = c("1","2","3","4","5")),
    Statement = UNO_Agreement_Level
  )

ggplot(uno_q1_long, aes(x = Level, y = Count)) +
  geom_col() +
  facet_wrap(~ Statement, ncol = 2, labeller = label_wrap_gen(width = 35)) +
  labs(
    title = "UNO Q1 – Agreement Distribution by Statement",
    x = "Agreement Level (1–5)",
    y = "Number of Respondents"
  ) +
  theme_minimal() +
  theme(
    legend.position = "none",
    strip.text = element_text(size = 10),
    axis.text.x = element_text(size = 9)
  )



```

## **Interpretation of Agreement Distributions**

Figure X presents the distribution of agreement levels (1–5) for each brand statement related to UNO.  
Across all statements, responses are concentrated around agreement levels **3 and 4**, indicating a generally positive but moderate brand perception.

Statements related to **quality, taste, and trust** show low frequencies at the extreme negative end (level 1), suggesting that strong dissatisfaction is rare.  
However, the relatively limited number of responses at level 5 indicates that very strong agreement is also uncommon.

Overall, these distributions suggest that UNO is perceived as a **reliable, good-quality, and good-value everyday bread brand**, rather than a strongly differentiated premium or innovative brand.  
This moderate perception highlights both stability in current brand equity and potential room for improvement through targeted positioning and communication strategies.

---

# UNO Question 2 – Action Likelihood (FUNNEL)

## Behavioral Intentions toward UNO Premium Bread

```{r uno-q2}
library(dplyr)
library(tidyr)
library(ggplot2)

uno_q2_long <- uno_q2 %>%
  pivot_longer(
    cols = c("1","2","3","4","5","6","7"),
    names_to = "Likelihood_Level",
    values_to = "Count"
  ) %>%
  mutate(
    Likelihood_Level = factor(Likelihood_Level, levels = c("1","2","3","4","5","6","7")),
    Action = UNO_Premium_Bread_Action_Likelihood
  )

ggplot(uno_q2_long, aes(x = Likelihood_Level, y = Count)) +
  geom_col() +
  facet_wrap(~ Action, ncol = 2, labeller = label_wrap_gen(width = 35)) +
  labs(
    title = "UNO Q2 – Likelihood of Actions for Premium Bread",
    x = "Likelihood Level (1–7)",
    y = "Number of Respondents"
  ) +
  theme_minimal() +
  theme(
    legend.position = "none",
    strip.text = element_text(size = 10),
    axis.text.x = element_text(size = 9)
  )

```


## **Interpretation of Likelihood Distributions**

Figure Y shows the distribution of likelihood levels (1–7) for different consumer actions related to a potential UNO premium bread line.  
Across actions, responses tend to cluster around the mid-to-upper range (roughly levels 4–6), indicating generally positive but not extreme intentions.

Lower-commitment actions (e.g., trying at least once or buying on promotion) typically receive higher likelihood responses than higher-commitment actions (e.g., switching brands or purchasing weekly).  
Overall, this suggests consumers are open to engaging with UNO’s premium offering, but stronger commitment may require clearer differentiation and a compelling value proposition.


