SAMPLING & SURVEY TECHNIQUES

Laporan Analisis Finance & Investment dengan 7 QC Tools

Logo


Data Dummy

1. Check Sheet: Tipe Transaksi Gagal

2. Control Chart: Fluktuasi Mingguan Portofolio

3. Fishbone Diagram: Penyebab Keterlambatan Transfer

4. Flowchart: Proses Investasi

5. Histogram: Frekuensi Pengeluaran

6. Pareto Chart: Tipe Transaksi Bermasalah

7. Scatter Diagram: Hubungan Nilai Investasi dan Return

---  
title: "SAMPLING & SURVEY TECHNIQUES"  
subtitle: "Laporan Analisis Finance & Investment dengan 7 QC Tools"  
author: 
  - "DADAN RAMDAN HIDAYAT NIM_52240028"
  - "M.Alfayed Safaad NIM_52240009"  
date:  "Minggu, 20/04/2025" 
output:  
  rmdformats::readthedown:  
    self_contained: true  
    thumbnails: true  
    lightbox: true  
    gallery: true  
    lib_dir: libs  
    df_print: "paged"  
    code_folding: "show"  
    code_download: true  
    css: "style.css"  
---  

<img src="statistika.jpg" alt="Logo" style="width:200px; display: block; margin: auto;">

---

## Data Dummy

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Pastikan library DT sudah terpasang
library(DT)

# Membuat data dummy untuk Finance & Investment delay
set.seed(456)
dates <- sample(seq(as.Date("2025-04-01"), as.Date("2025-04-30"), by = "day"), 100, replace = TRUE)
reasons <- c(
  "Market Volatility",
  "System Error",
  "Insufficient Funds",
  "Transaction Timeout",
  "Regulatory Delay",
  "Manual Approval Needed",
  "Data Mismatch",
  "Transfer Limit Exceeded"
)

finance_investment_delay <- data.frame(
  Date = dates,
  Reason = sample(reasons, 100, replace = TRUE)
)

# Tampilkan DataTable
datatable(
  finance_investment_delay,
  options = list(
    scrollCollapse = TRUE,
    searching = TRUE,   # Jika ingin ada fitur pencarian
    paging = TRUE,      # Jika ingin ada pagination
    pageLength = 10     # Jumlah baris per halaman
  ),
  caption = htmltools::tags$caption(
    style = 'caption-side: top; text-align: left; font-size: 18px; font-weight: bold;',
    'Data Delay Keuangan dan Investasi'
  ),
  class = 'stripe hover compact'
)
```

## 1. Check Sheet: Tipe Transaksi Gagal

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Pastikan library yang diperlukan sudah terpasang
library(dplyr)
library(DT)
library(htmltools)

# Membuat dataset dummy transaksi keuangan dan investasi
set.seed(123)

# Generate tanggal dalam bulan April 2025
dates <- sample(seq(as.Date("2025-04-01"), as.Date("2025-04-30"), by = "day"), 100, replace = TRUE)

# Daftar alasan delay umum dalam konteks keuangan dan investasi
reasons <- c(
  "Market Volatility",
  "System Error",
  "Insufficient Funds",
  "Transaction Timeout",
  "Regulatory Delay",
  "Manual Approval Needed",
  "Data Mismatch",
  "Transfer Limit Exceeded"
)

# Membuat dataset dummy delay transaksi
finance_investment_delay <- data.frame(
  Date = dates,
  Reason = sample(reasons, 100, replace = TRUE)
)

# Menghitung frekuensi setiap alasan delay
reason_summary <- finance_investment_delay %>%
  count(Reason, sort = TRUE) %>%
  rename(Failure_Reason = Reason, Frequency = n)

# Menampilkan tabel interaktif dengan DT
datatable(
  reason_summary,
  options = list(
    scrollCollapse = TRUE,
    searching = FALSE,
    paging = FALSE,
    autoWidth = TRUE
  ),
  rownames = FALSE,
  caption = tags$caption(
    style='caption-side: top; text-align: left; font-size: 18px; font-weight: bold;',
    'Check Sheet: Summary of Delay Reasons in Finance & Investment'
  ),
  class = 'stripe hover compact'
)
```
```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Pastikan library yang diperlukan sudah terpasang
library(dplyr)
library(DT)
library(plotly)
library(htmltools)

# 1. Membuat dataset dummy untuk Delay di bidang Keuangan & Investasi
set.seed(123)
dates <- sample(seq(as.Date("2025-04-01"), as.Date("2025-04-30"), by = "day"), 100, replace = TRUE)
reasons <- c(
  "Market Volatility",
  "System Error",
  "Insufficient Funds",
  "Transaction Timeout",
  "Regulatory Delay",
  "Manual Approval Needed",
  "Data Mismatch",
  "Transfer Limit Exceeded"
)

finance_investment_delay <- data.frame(
  Date = dates,
  Reason = sample(reasons, 100, replace = TRUE)
)

# 2. Hitung frekuensi alasan delay
reason_summary <- finance_investment_delay %>%
  count(Reason, sort = TRUE) %>%
  rename(Failure_Reason = Reason, Frequency = n)

# 3. Tampilkan tabel interaktif DT
datatable(
  reason_summary,
  options = list(
    scrollCollapse = TRUE,
    searching = FALSE,
    paging = FALSE,
    autoWidth = TRUE
  ),
  rownames = FALSE,
  caption = tags$caption(
    style='caption-side: top; text-align: left; font-size: 18px; font-weight: bold;',
    'Check Sheet: Summary of Delay Reasons in Finance & Investment'
  ),
  class = 'stripe hover compact'
)

# 4. Buat bar chart interaktif menggunakan plotly
plot_ly(reason_summary,
        x = ~Frequency,
        y = ~reorder(Failure_Reason, Frequency),
        type = 'bar',
        orientation = 'h',
        marker = list(
          color = ~Frequency,
          colorscale = 'Viridis',  # Alternatif: 'Bluered', 'Cividis', 'YlOrRd'
          showscale = TRUE
        )
) %>%
  layout(
    title = list(text = "Check Sheet: Frequency of Delay Reasons", font = list(size = 18)),
    xaxis = list(title = "Frequency"),
    yaxis = list(title = "Reason"),
    margin = list(l = 150)
  )
```

## 2. Control Chart: Fluktuasi Mingguan Portofolio

```{r, message=FALSE, warning=FALSE, echo=FALSE}

# Load libraries
library(plotly)
library(dplyr)

# Data delay keuangan dan investasi (sesuai data Anda)
set.seed(456)
dates <- sample(seq(as.Date("2025-04-01"), as.Date("2025-04-30"), by = "day"), 100, replace = TRUE)
reasons <- c(
  "Market Volatility",
  "System Error",
  "Insufficient Funds",
  "Transaction Timeout",
  "Regulatory Delay",
  "Manual Approval Needed",
  "Data Mismatch",
  "Transfer Limit Exceeded"
)

finance_investment_delay <- data.frame(
  Date = dates,
  Reason = sample(reasons, 100, replace = TRUE)
)

# Hitung jumlah delay per hari
daily_delay <- finance_investment_delay %>%
  group_by(Date) %>%
  summarise(Jumlah_Delay = n())

# Hitung statistik dasar untuk control chart
mean_delay <- mean(daily_delay$Jumlah_Delay)
sd_delay <- sd(daily_delay$Jumlah_Delay)

# Tentukan batas kendali (3-sigma)
UCL <- mean_delay + 3 * sd_delay
LCL <- ifelse(mean_delay - 3 * sd_delay < 0, 0, mean_delay - 3 * sd_delay)
CL <- mean_delay

# Tandai outliers (terganjur melampaui batas kendali)
daily_delay <- daily_delay %>%
  mutate(Outlier = ifelse(Jumlah_Delay > UCL | Jumlah_Delay < LCL, "Ya", "Tidak"))

# Buat plot Control Chart
plot_ly(daily_delay, x = ~Date, y = ~Jumlah_Delay, type = 'scatter', mode = 'lines+markers',
        line = list(color = 'blue'), 
        marker = list(size = 8, color = ifelse(daily_delay$Outlier == "Ya", "red", "blue")),
        hoverinfo = 'text',
        text = ~paste("Tanggal:", Date, "<br>Jumlah Delay:", Jumlah_Delay)) %>%
  add_lines(y = rep(CL, nrow(daily_delay)), name = "CL", line = list(color = 'green', dash = 'dot')) %>%
  add_lines(y = rep(UCL, nrow(daily_delay)), name = "UCL", line = list(color = 'red', dash = 'dot')) %>%
  add_lines(y = rep(LCL, nrow(daily_delay)), name = "LCL", line = list(color = 'red', dash = 'dot')) %>%
  layout(title = "Control Chart – Jumlah Delay Keuangan & Investasi",
         xaxis = list(title = "Tanggal"),
         yaxis = list(title = "Jumlah Delay"),
         legend = list(orientation = 'h', x = 0.3, y = -0.2))
```

## 3. Fishbone Diagram: Penyebab Keterlambatan Transfer

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Pastikan library DiagrammeR sudah terpasang
library(DiagrammeR)

# Data alasan delay dari dataset kamu
reasons <- c(
  "Market Volatility",
  "System Error",
  "Insufficient Funds",
  "Transaction Timeout",
  "Regulatory Delay",
  "Manual Approval Needed",
  "Data Mismatch",
  "Transfer Limit Exceeded"
)

# Buat Fishbone Diagram
grViz("
digraph fishbone {
  graph [layout = 'dot', rankdir='LR']
  
  # Masalah utama
  node [shape=box, style=filled, fillcolor=lightblue, fontname=Helvetica]
  Masalah [label='Delay Keuangan & Investasi']
  
  # Faktor utama
  node [shape=ellipse, style=filled, fillcolor=orange]
  Manajemen [label='Manajemen']
  Proses [label='Proses']
  Mesin [label='Mesin/ Teknologi']
  Manusia [label='Manusia']
  Data [label='Data & Informasi']
  Regulasi [label='Regulasi & Kebijakan']
  
  # Hubungkan faktor utama ke masalah utama
  Masalah -> Manajemen
  Masalah -> Proses
  Masalah -> Mesin
  Masalah -> Manusia
  Masalah -> Data
  Masalah -> Regulasi
  
  # Sub-faktor di bawah Manajemen
  node [shape=ellipse, style=filled, fillcolor=yellow]
  Kebijakan [label='Kebijakan']
  Struktur [label='Struktur Organisasi']
  Manajemen -> Kebijakan
  Manajemen -> Struktur
  
  # Sub-faktor di bawah Proses
  Prosedur [label='Prosedur']
  Standar [label='Standar Operasi']
  Proses -> Prosedur
  Proses -> Standar
  
  # Sub-faktor di bawah Mesin
  Hardware [label='Hardware']
  Software [label='Software']
  Mesin -> Hardware
  Mesin -> Software
  
  # Sub-faktor di bawah Manusia
  Training [label='Pelatihan']
  Keterampilan [label='Keterampilan']
  Manusia -> Training
  Manusia -> Keterampilan
  
  # Sub-faktor di Data
  DataQuality [label='Kualitas Data']
  DataSystem [label='Sistem Data']
  Data -> DataQuality
  Data -> DataSystem
  
  # Sub-faktor di Regulasi
  KebijakanRes [label='Kebijakan Regulatory']
  Pengawasan [label='Pengawasan']
  Regulasi -> KebijakanRes
  Regulasi -> Pengawasan
}
")
```
## 4. Flowchart: Proses Investasi

```{r, message=FALSE, warning=FALSE, echo=FALSE}

library(DiagrammeR)

grViz("
digraph proses_investasi {
  graph [layout = dot, rankdir = TB]
  node [fontname = Helvetica, fontsize = 12]

  // Node definitions with shape, color, and labels
  Start [label = 'Start', shape = ellipse, style=filled, fillcolor=lightblue]
  Info [label = 'Kumpulkan Informasi', shape = parallelogram, style=filled, fillcolor=lightgreen]
  Analisis [label = 'Analisis Risiko & Return', shape = box, style=filled, fillcolor=orange]
  Tujuan [label = 'Tentukan Tujuan Investasi', shape = diamond, style=filled, fillcolor=lightpink]
  Strategi [label = 'Tentukan Strategi Investasi', shape = box, style=filled, fillcolor=orange]
  Keputusan [label = 'Siap Berinvestasi?', shape = diamond, style=filled, fillcolor=lightpink]
  Tunda [label = 'Tunda & Evaluasi Ulang', shape = note, style=filled, fillcolor=gray]
  Eksekusi [label = 'Eksekusi Investasi', shape = box, style=filled, fillcolor=orange]
  Monitoring [label = 'Monitoring & Evaluasi', shape = trapezium, style=filled, fillcolor=thistle]
  Rebalancing [label = 'Rebalancing Portofolio?', shape = diamond, style=filled, fillcolor=lightpink]
  Selesai [label = 'Selesai', shape = ellipse, style=filled, fillcolor=lightblue]

  // Arrows between nodes (flow)
  Start -> Info
  Info -> Analisis
  Analisis -> Tujuan
  Tujuan -> Strategi
  Strategi -> Keputusan
  Keputusan -> Eksekusi [label = 'Ya']
  Keputusan -> Tunda [label = 'Tidak']
  Eksekusi -> Monitoring
  Monitoring -> Rebalancing
  Rebalancing -> Strategi [label = 'Ya', style=dashed]
  Rebalancing -> Selesai [label = 'Tidak']
}
")

```



## 5. Histogram: Frekuensi Pengeluaran

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Install dan load library yang diperlukan
library(plotly)

# Generate data distribusi normal (mean=50, sd=10)
set.seed(123)
normal_data <- rnorm(1000, mean = 50, sd = 10)  # 1000 data acak

# Hitung density data dari distribusi normal
density_data <- density(normal_data)

# Buat histogram dengan plotly dan tambahkan kurva density
histogram_plot <- plot_ly(
  x = normal_data,
  type = 'histogram',
  marker = list(color = 'lightblue', line = list(color = 'black', width = 1)),
  name = 'Histogram of Normal Data',
  nbinsx = 30,
  opacity = 0.6,
  showlegend = TRUE
) %>%
  # Tambahkan kurva density
  add_trace(
    x = density_data$x,
    y = density_data$y * length(normal_data) * diff(range(normal_data)) / 30,
    type = 'scatter',
    mode = 'lines',
    name = 'Density Curve',
    line = list(color = 'black', width = 3),
    showlegend = TRUE
  ) %>%
  layout(
    title = 'Histogram of Normal Distribution with Density Curve',
    xaxis = list(title = 'Value', showgrid = FALSE),
    yaxis = list(title = 'Frequency / Density', showgrid = FALSE),
    bargap = 0.1,
    plot_bgcolor = 'white',
    paper_bgcolor = 'white',
    showlegend = TRUE,
    legend = list(
      orientation = 'v',    # Legend vertikal
      x = 0.98,             # Posisi kanan atas
      xanchor = 'right',
      y = 0.98,             # Posisi atas
      yanchor = 'top',
      bgcolor = 'rgba(255,255,255,0.8)',  # Latar belakang semi-transparan
      bordercolor = 'black',
      borderwidth = 0.3
    )
  )

# Tampilkan plot
histogram_plot
```

## 6. Pareto Chart: Tipe Transaksi Bermasalah

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Load libraries
library(dplyr)
library(plotly)
library(RColorBrewer)

# Pastikan data sudah ada: finance_investment_delay
# Jika belum, gunakan data yang sudah dibuat sebelumnya

# Hitung jumlah delay per alasan
pareto_data <- finance_investment_delay %>%
  count(Reason, sort = TRUE) %>%
  mutate(
    cum_freq = cumsum(n) / sum(n) * 100  # persen kumulatif
  )

# Buat warna berbeda untuk setiap Reason
colors <- brewer.pal(n = nrow(pareto_data), name = "Set3")

# Buat Plotly Pareto Chart
fig <- plot_ly()

# Tambahkan bar chart (jumlah delay)
fig <- fig %>% add_bars(
  x = ~reorder(pareto_data$Reason, -pareto_data$n),
  y = ~pareto_data$n,
  name = 'Jumlah Delay',
  marker = list(color = colors),
  yaxis = "y1"
)

# Tambahkan garis kumulatif persen
fig <- fig %>% add_lines(
  x = ~reorder(pareto_data$Reason, -pareto_data$n),
  y = ~pareto_data$cum_freq,
  name = 'Kumulatif (%)',
  yaxis = "y2",
  line = list(color = 'red', dash = 'dash')
)

# Tambahkan garis batas 80%
fig <- fig %>% add_lines(
  x = ~reorder(pareto_data$Reason, -pareto_data$n),
  y = rep(80, nrow(pareto_data)),
  name = 'Batas 80%',
  yaxis = "y2",
  line = list(color = 'green', dash = 'dot')
)

# Atur layout
fig <- fig %>% layout(
  title = "Pareto Chart - Alasan Delay Keuangan & Investasi",
  xaxis = list(
    title = "Alasan Delay",
    tickangle = -45   # miring 45 derajat
  ),
  yaxis = list(title = "Jumlah Delay"),
  yaxis2 = list(
    title = "Persen Kumulatif (%)",
    overlaying = "y",
    side = "right",
    range = c(0, 100)
  ),
  legend = list(x = 0.8, y = 0.75),
  shapes = list(
    list(
      type = "line",
      x0 = -0.5,
      x1 = nrow(pareto_data) - 0.5,
      y0 = 80,
      y1 = 80,
      yref = "y2",
      line = list(color = "green", width = 2, dash = "dot")
    )
  )
)

# Tampilkan chart
fig
```

## 7. Scatter Diagram: Hubungan Nilai Investasi dan Return

```{r, message=FALSE, warning=FALSE, echo=FALSE}
# Pastikan library plotly sudah terpasang
library(plotly)

# Buat data dummy investasi dan return berdasarkan data delay per hari
set.seed(123)
daily_delay <- finance_investment_delay %>%
  group_by(Date) %>%
  summarise(Jumlah_Delay = n())

# Tambahkan data investasi dan return secara acak untuk contoh
daily_delay <- daily_delay %>%
  mutate(
    investasi = Jumlah_Delay * 1000 + rnorm(n(), mean = 0, sd = 2000),   # nilai investasi
    return_investasi = investasi * 0.05 + rnorm(n(), mean = 0, sd = 500)  # return
  )

# Hitung korelasi
cor_value <- cor(daily_delay$investasi, daily_delay$return_investasi)

# Buat scatter plot dengan regresi linier
fig <- plot_ly(daily_delay,
               x = ~investasi,
               y = ~return_investasi,
               type = 'scatter',
               mode = 'markers',
               marker = list(color = 'blue', size = 8)) %>%
  add_lines(x = ~investasi,
            y = predict(lm(return_investasi ~ investasi, data = daily_delay)),
            line = list(color = 'red', dash = 'dash', width = 2),
            name = 'Regression Line') %>%
  layout(title = paste("Scatter Diagram: Investasi vs Return<br>Koefisien Korelasi: ", round(cor_value, 2)),
         xaxis = list(title = "Investasi (Rp)"),
         yaxis = list(title = "Return (Rp)"))

# Tampilkan plot
fig
```



