Penanggulangan kemiskinan tetap menjadi prioritas utama dalam agenda pembangunan nasional Indonesia. Namun, tantangan besar sering muncul dalam menentukan skema intervensi yang paling efisien secara fiskal namun tetap memberikan dampak optimal. Di tengah keterbatasan ruang anggaran, kebijakan bantuan sosial (bansos) dituntut untuk tidak hanya sekadar menyalurkan dana, tetapi juga harus presisi dalam menentukan besaran (nominal) dan target sasaran (targeting).

Laporan ini menyajikan sebuah simulasi dampak bantuan sosial menggunakan data Susenas Maret 2025. Analisis ini bertujuan untuk memprediksi skenario terbaik dalam menurunkan angka kemiskinan sebesar 1 poin persentase. Melalui pendekatan berbasis data, dapat diuji berbagai kemungkinan: apakah bantuan harus diberikan secara universal, atau cukup difokuskan pada penduduk miskin yang selama ini belum terjangkau bantuan eksisting?

Pentingnya analisis ini terletak pada kemampuannya untuk membedah kebutuhan fiskal hingga tingkat wilayah. Mengingat disparitas ekonomi antarprovinsi yang cukup lebar, kebijakan “satu ukuran untuk semua” ( one size fits all) seringkali kurang efektif. Oleh karena itu, simulasi ini juga merinci kebutuhan top-up anggaran di masing-masing dari 38 provinsi di Indonesia, guna memastikan bahwa setiap rupiah yang dialokasikan benar-benar berkontribusi pada akselerasi penurunan angka kemiskinan nasional.

knitr::opts_chunk$set(echo = TRUE, message = FALSE, warning = FALSE)

Parameter Baseline

baseline_poverty <- sum(dataku$miskin_awal * dataku$weight) / sum(dataku$weight)
target_poverty <- max(0, baseline_poverty - 0.01)

cat("Baseline Poverty  :", round(baseline_poverty * 100, 2), "%\n")
## Baseline Poverty  : 8.47 %
cat("Target Poverty    :", round(target_poverty * 100, 2), "%\n")
## Target Poverty    : 7.47 %

Tahap awal analisis berfokus pada penetapan baseline kemiskinan menggunakan penimbang untuk merepresentasikan populasi nasional. Berdasarkan hasil pengolahan, diperoleh angka kemiskinan sebesar 8,47%. Angka ini menjadi acuan krusial untuk mengukur efektivitas intervensi bantuan sosial yang akan disimulasikan.

Sejalan dengan target akselerasi penghapusan kemiskinan, analisis ini menetapkan Target Kemiskinan baru sebesar 7,47%, atau penurunan sebesar 1 poin persentase. Selisih antara kondisi baseline dan target inilah yang akan menjadi fokus utama dalam perhitungan kebutuhan fiskal, guna menentukan berapa besar tambahan dana bantuan yang harus dialokasikan agar ambang batas target tersebut dapat tercapai secara efektif di seluruh wilayah.

1 Level Nasional

pop_total <- sum(dataku$weight * dataku$jart)
pop_miskin <- sum(dataku$weight[dataku$miskin_awal == 1] * dataku$jart[dataku$miskin_awal == 1])
pop_inklusi <- sum(dataku$weight[dataku$miskin_awal == 1 & (is.na(dataku$R2002)|dataku$R2002!=1) & (is.na(dataku$R2005)|dataku$R2005!=1)] * dataku$jart[dataku$miskin_awal == 1 & (is.na(dataku$R2002)|dataku$R2002!=1) & (is.na(dataku$R2005)|dataku$R2005!=1)])

solusi <- sim_results %>%
  filter(poverty <= target_poverty) %>%
  group_by(scenario) %>%
  filter(tambahan == min(tambahan)) %>%
  ungroup() %>%
  mutate(total_anggaran = case_when(
    scenario == "Universal" ~ tambahan * pop_total,
    scenario == "Perfect Targeting" ~ tambahan * pop_miskin,
    scenario == "Inklusi (Non-PKH/BPNT)" ~ tambahan * pop_inklusi
  ))
label_data <- sim_results %>% filter(tambahan == 0) %>% mutate(label_text = paste0(round(poverty * 100, 2), "%"))
info_solusi <- solusi %>% filter(scenario == "Perfect Targeting") %>% slice(1)

teks_anggaran <- paste0("Anggaran Turun 1%: Rp ", 
                        format(round(info_solusi$total_anggaran / 1e12, 2), nsmall = 2), 
                        " Triliun\n(Target Khusus Penduduk Miskin: Rp ", 
                        format(info_solusi$tambahan, big.mark=","), "/kapita)")

ggplot(sim_results, aes(x = tambahan, y = poverty, color = scenario)) +
  geom_line(size = 1.1) +
  geom_hline(yintercept = target_poverty, linetype = "dashed", color = "red") +
  annotate("label", x = max(sim_results$tambahan)*0.7, y = target_poverty + 0.005, 
           label = teks_anggaran, fill = "#FFF9C4", color = "darkred", fontface = "bold", size = 3.5) +
  scale_y_continuous(labels = percent, expand = expansion(mult = c(0.1, 0.2))) +
  scale_x_continuous(labels = comma) +
  theme_minimal() +
  labs(title = "Simulasi Dampak Bansos per Kapita terhadap Kemiskinan",
       subtitle = "Skenario Tambahan Bantuan di Atas Bantuan Eksisting (PKH, BPNT, Bantuan Pemda)",
       x = "Tambahan Bantuan per Kapita (Rp)",
       y = "Poverty Rate (%)",
       color = "Skenario") +
  theme(legend.position = "bottom")

Visualisasi di atas menggambarkan dinamika penurunan angka kemiskinan terhadap besaran tambahan bantuan sosial per kapita dalam tiga skenario yang berbeda. Sumbu horizontal (X) menunjukkan nominal tambahan bantuan yang diberikan, sementara sumbu vertikal (Y) menunjukkan proyeksi angka kemiskinan yang dihasilkan. Garis horizontal putus-putus berwarna merah merepresentasikan target kebijakan sebesar 7,47%.

  • Skenario Perfect Targeting: Menunjukkan efisiensi tertinggi, di mana kurva turun paling tajam. Ini membuktikan bahwa jika bantuan diberikan secara eksklusif hanya kepada penduduk miskin, target penurunan 1% dapat dicapai dengan biaya minimal.

  • Skenario Inklusi: Skenario ini menyasar penduduk miskin yang selama ini belum terjangkau PKH/BPNT (exclusion error). Kurva ini membantu mengidentifikasi besaran “top-up” yang dibutuhkan untuk menutup celah perlindungan sosial bagi kelompok rentan tersebut.

  • Skenario Universal: Kurva ini melandai paling lambat karena dana tersebar ke seluruh lapisan penduduk. Perbedaan jarak antara kurva ini dengan Perfect Targeting menunjukkan besarnya potensi penghematan anggaran yang bisa dilakukan melalui perbaikan akurasi data.

2 Level Provinsi

tabel_cetak <- tabel_akhir_prov %>% 
  arrange(R101) %>% 
  select(R101, baseline_pct, target_pct, tambahan_topup_kapita, total_anggaran_miliar)
#print(tabel_cetak, n = Inf)


# Rekap Total Fiskal
total_triliun <- sum(tabel_akhir_prov$total_anggaran_miliar, na.rm = TRUE) / 1000
cat("TOTAL ANGGARAN NASIONAL : Rp", round(total_triliun, 2), "Triliun\n")
## TOTAL ANGGARAN NASIONAL : Rp 22.96 Triliun

Analisis Kebutuhan Fiskal Nasional

Berdasarkan hasil agregasi simulasi dari 38 provinsi, estimasi total kebutuhan fiskal untuk menurunkan angka kemiskinan nasional sebesar 1 persen poin adalah sebesar Rp 22,96 Triliun. Angka ini merepresentasikan akumulasi dari biaya intervensi yang disesuaikan dengan karakteristik kemiskinan dan Garis Kemiskinan di masing-masing wilayah. Perhitungan ini memberikan gambaran objektif mengenai skala pendanaan yang diperlukan untuk mencapai target akselerasi penghapusan kemiskinan dalam jangka pendek.

Nilai Rp 22,96 Triliun ini berfungsi sebagai pedoman bagi perencanaan anggaran pusat dan daerah. Perlu dicatat bahwa angka ini merupakan estimasi biaya intervensi langsung kepada penduduk target. Dalam implementasi praktisnya, angka ini dapat menjadi acuan untuk mengevaluasi kecukupan alokasi dana bantuan sosial yang sedang berjalan atau sebagai dasar pengajuan dana tambahan (top-up) dalam mekanisme perubahan anggaran. Dengan mengetahui nilai fiskal ini, pemerintah dapat mengukur sejauh mana “harga” dari sebuah target kesejahteraan rakyat yang ingin dicapai.

total_triliun_prov <- sum(tabel_akhir_prov$total_anggaran_miliar, na.rm = TRUE) / 1000
wb <- createWorkbook()
addWorksheet(wb, "Simulasi_Provinsi")
writeData(wb, "Simulasi_Provinsi", "Hasil Simulasi Per Provinsi (Target Penurunan 1%)", startRow = 1)
writeData(wb, "Simulasi_Provinsi", tabel_akhir_prov %>% arrange(R101), startRow = 3)
saveWorkbook(wb, "Simulasi_Bansos_Provinsi_2026.xlsx", overwrite = TRUE)

Directorate of Welfare Statistics, BPS Statistic Indonesia,

---
title: "Simulasi Dampak Bantuan Sosial <br> terhadap Penurunan Kemiskinan"
author: "Sapta Hastho Ponco"
date: "`r Sys.Date()`"
output:
  html_document:
    code_download: yes
    code_folding: show
    number_sections: yes
    theme: journal
    toc: yes
    toc_float: yes
  word_document:
    toc: yes
---

```{=html}
<style>
body{
text-align: justify}
</style>
```

Penanggulangan kemiskinan tetap menjadi prioritas utama dalam agenda pembangunan nasional Indonesia. Namun, tantangan besar sering muncul dalam menentukan skema intervensi yang paling efisien secara fiskal namun tetap memberikan dampak optimal. Di tengah keterbatasan ruang anggaran, kebijakan bantuan sosial (bansos) dituntut untuk tidak hanya sekadar menyalurkan dana, tetapi juga harus presisi dalam menentukan besaran (nominal) dan target sasaran (targeting).

Laporan ini menyajikan sebuah simulasi dampak bantuan sosial menggunakan data Susenas Maret 2025. Analisis ini bertujuan untuk memprediksi skenario terbaik dalam menurunkan angka kemiskinan sebesar 1 poin persentase. Melalui pendekatan berbasis data, dapat diuji berbagai kemungkinan: apakah bantuan harus diberikan secara universal, atau cukup difokuskan pada penduduk miskin yang selama ini belum terjangkau bantuan eksisting?

Pentingnya analisis ini terletak pada kemampuannya untuk membedah kebutuhan fiskal hingga tingkat wilayah. Mengingat disparitas ekonomi antarprovinsi yang cukup lebar, kebijakan "satu ukuran untuk semua" ( _one size fits all_) seringkali kurang efektif. Oleh karena itu, simulasi ini juga merinci kebutuhan top-up anggaran di masing-masing dari 38 provinsi di Indonesia, guna memastikan bahwa setiap rupiah yang dialokasikan benar-benar berkontribusi pada akselerasi penurunan angka kemiskinan nasional.


```{r setup, include=TRUE}
knitr::opts_chunk$set(echo = TRUE, message = FALSE, warning = FALSE)
```


```{r, message=FALSE, warning=FALSE, echo=FALSE}
pacman::p_load(haven, dplyr, ggplot2, tidyr, scales, purrr, openxlsx)
```


```{r, echo=FALSE}
setwd("D:/2. Pengembangan diri/1 Exercise Bagus/Housing Analysis")
datagw<- read_sav("KOR25GAB_0309BANSOS.sav")
```


```{r, echo=FALSE}
dataku <- datagw %>%
  select(R101, R102, R105, R401, KAPITA, GK_PROV, FWT, 
         R2002, R2005, R2006BI2, R2006BI3, R2006BI4, R2006BI5,
         R2009A1, R2009A2, R2009A3, R2009A4, R2009A5, R2009B) %>%
  mutate(
    jart = as.numeric(R401),
    
    # 1. Nominal PKH
    pkh_val = ifelse(!is.na(R2002) & R2002 == 1, 400000, 0),
    
    # 2. BPNT 
    bpnt_total_4bln = rowSums(across(c(R2006BI2, R2006BI3, R2006BI4, R2006BI5, R2009B)), na.rm = TRUE),
    bpnt_val = bpnt_total_4bln / 4,
    
    # 3. Bantuan Lainnya
    kontinu_val = rowSums(across(c(R2009A1, R2009A2, R2009A3, R2009A4, R2009A5)), na.rm = TRUE),
    
    # 4. Total Bansos ruta dan per kapita
    total_bansos_rt = pkh_val + bpnt_val + kontinu_val,
    bansos_per_kapita = total_bansos_rt / jart,
    
    # 5. Variabel Simulasi
    gk = GK_PROV,
    weight = FWT,
    miskin_awal = ifelse(KAPITA < gk, 1, 0)
  )
```

**Parameter Baseline**

```{r}
baseline_poverty <- sum(dataku$miskin_awal * dataku$weight) / sum(dataku$weight)
target_poverty <- max(0, baseline_poverty - 0.01)

cat("Baseline Poverty  :", round(baseline_poverty * 100, 2), "%\n")
cat("Target Poverty    :", round(target_poverty * 100, 2), "%\n")
``` 

Tahap awal analisis berfokus pada penetapan baseline kemiskinan menggunakan penimbang untuk merepresentasikan populasi nasional. Berdasarkan hasil pengolahan, diperoleh angka kemiskinan sebesar 8,47%. Angka ini menjadi acuan krusial untuk mengukur efektivitas intervensi bantuan sosial yang akan disimulasikan.

Sejalan dengan target akselerasi penghapusan kemiskinan, analisis ini menetapkan Target Kemiskinan baru sebesar 7,47%, atau penurunan sebesar 1 poin persentase. Selisih antara kondisi baseline dan target inilah yang akan menjadi fokus utama dalam perhitungan kebutuhan fiskal, guna menentukan berapa besar tambahan dana bantuan yang harus dialokasikan agar ambang batas target tersebut dapat tercapai secara efektif di seluruh wilayah.

# Level Nasional

```{r, echo=FALSE}
calc_sim <- function(df, b, scenario_type = "Universal") {
  df_sim <- df %>%
    mutate(
      tambahan = case_when(
        scenario_type == "Universal" ~ b,
        scenario_type == "Perfect"  ~ ifelse(miskin_awal == 1, b, 0),
        scenario_type == "Inklusi" ~ ifelse(miskin_awal == 1 & (is.na(R2002)|R2002!=1) & (is.na(R2005)|R2005!=1), b, 0),
        TRUE ~ 0
      ),
      pengeluaran_baru = KAPITA + tambahan,
      miskin_baru = ifelse(pengeluaran_baru < gk, 1, 0)
    )
  sum(df_sim$miskin_baru * df_sim$weight) / sum(df_sim$weight)
}

# Run Iterasi
sim_results <- data.frame()
step_bantuan <- seq(0, 300000, 5000) 

for (b in step_bantuan) {
  sim_results <- rbind(sim_results, 
    data.frame(tambahan = b, poverty = calc_sim(dataku, b, "Universal"), scenario = "Universal"),
    data.frame(tambahan = b, poverty = calc_sim(dataku, b, "Perfect"), scenario = "Perfect Targeting"),
    data.frame(tambahan = b, poverty = calc_sim(dataku, b, "Inklusi"), scenario = "Inklusi (Non-PKH/BPNT)"))
}
```


```{r}
pop_total <- sum(dataku$weight * dataku$jart)
pop_miskin <- sum(dataku$weight[dataku$miskin_awal == 1] * dataku$jart[dataku$miskin_awal == 1])
pop_inklusi <- sum(dataku$weight[dataku$miskin_awal == 1 & (is.na(dataku$R2002)|dataku$R2002!=1) & (is.na(dataku$R2005)|dataku$R2005!=1)] * dataku$jart[dataku$miskin_awal == 1 & (is.na(dataku$R2002)|dataku$R2002!=1) & (is.na(dataku$R2005)|dataku$R2005!=1)])

solusi <- sim_results %>%
  filter(poverty <= target_poverty) %>%
  group_by(scenario) %>%
  filter(tambahan == min(tambahan)) %>%
  ungroup() %>%
  mutate(total_anggaran = case_when(
    scenario == "Universal" ~ tambahan * pop_total,
    scenario == "Perfect Targeting" ~ tambahan * pop_miskin,
    scenario == "Inklusi (Non-PKH/BPNT)" ~ tambahan * pop_inklusi
  ))
``` 

```{r}
label_data <- sim_results %>% filter(tambahan == 0) %>% mutate(label_text = paste0(round(poverty * 100, 2), "%"))
info_solusi <- solusi %>% filter(scenario == "Perfect Targeting") %>% slice(1)

teks_anggaran <- paste0("Anggaran Turun 1%: Rp ", 
                        format(round(info_solusi$total_anggaran / 1e12, 2), nsmall = 2), 
                        " Triliun\n(Target Khusus Penduduk Miskin: Rp ", 
                        format(info_solusi$tambahan, big.mark=","), "/kapita)")

ggplot(sim_results, aes(x = tambahan, y = poverty, color = scenario)) +
  geom_line(size = 1.1) +
  geom_hline(yintercept = target_poverty, linetype = "dashed", color = "red") +
  annotate("label", x = max(sim_results$tambahan)*0.7, y = target_poverty + 0.005, 
           label = teks_anggaran, fill = "#FFF9C4", color = "darkred", fontface = "bold", size = 3.5) +
  scale_y_continuous(labels = percent, expand = expansion(mult = c(0.1, 0.2))) +
  scale_x_continuous(labels = comma) +
  theme_minimal() +
  labs(title = "Simulasi Dampak Bansos per Kapita terhadap Kemiskinan",
       subtitle = "Skenario Tambahan Bantuan di Atas Bantuan Eksisting (PKH, BPNT, Bantuan Pemda)",
       x = "Tambahan Bantuan per Kapita (Rp)",
       y = "Poverty Rate (%)",
       color = "Skenario") +
  theme(legend.position = "bottom")
``` 


Visualisasi di atas menggambarkan dinamika penurunan angka kemiskinan terhadap besaran tambahan bantuan sosial per kapita dalam tiga skenario yang berbeda. Sumbu horizontal (X) menunjukkan nominal tambahan bantuan yang diberikan, sementara sumbu vertikal (Y) menunjukkan proyeksi angka kemiskinan yang dihasilkan. Garis horizontal putus-putus berwarna merah merepresentasikan target kebijakan sebesar 7,47%.

- Skenario Perfect Targeting: Menunjukkan efisiensi tertinggi, di mana kurva turun paling tajam. Ini membuktikan bahwa jika bantuan diberikan secara eksklusif hanya kepada penduduk miskin, target penurunan 1% dapat dicapai dengan biaya minimal.

- Skenario Inklusi: Skenario ini menyasar penduduk miskin yang selama ini belum terjangkau PKH/BPNT (exclusion error). Kurva ini membantu mengidentifikasi besaran "top-up" yang dibutuhkan untuk menutup celah perlindungan sosial bagi kelompok rentan tersebut.

- Skenario Universal: Kurva ini melandai paling lambat karena dana tersebar ke seluruh lapisan penduduk. Perbedaan jarak antara kurva ini dengan Perfect Targeting menunjukkan besarnya potensi penghematan anggaran yang bisa dilakukan melalui perbaikan akurasi data.


# Level Provinsi

```{r, echo=FALSE}
# 1. Menyiapkan Target 1% per Provinsi
target_prov <- dataku %>%
  group_by(R101) %>%
  summarise(
    baseline_poverty = sum(miskin_awal * weight) / sum(weight),
    target_poverty = max(0, baseline_poverty - 0.01),
    pop_jiwa = sum(weight * jart)
  ) %>%
  ungroup()

# 2. Fungsi untuk mencari Top-Up Optimal per Provinsi
# b_start: mulai dari 5rb, b_end: sampai 1jt, step: 5rb
cari_topup <- function(df_prov, target_val) {
  topup_steps <- seq(5000, 1000000, 5000)
  
  for (b in topup_steps) {
    # Simulasi: KAPITA saat ini (sudah ada bansos eksisting) + Tambahan Baru
    p_sim <- df_prov %>%
      mutate(p_baru = KAPITA + b,
             m_baru = ifelse(p_baru < gk, 1, 0)) %>%
      summarise(p = sum(m_baru * weight) / sum(weight)) %>%
      pull(p)
    
    if (p_sim <= target_val) return(b)
  }
  return(NA)
}

# 3. Eksekusi Simulasi per Provinsi
hasil_sim_prov <- dataku %>%
  group_split(R101) %>%
  purrr::map_dfr(function(df_prov) {
    kd_prov <- unique(df_prov$R101)
    target_val <- target_prov$target_poverty[target_prov$R101 == kd_prov]
    
    # Cari nilai top-up yang dibutuhkan
    topup_needed <- cari_topup(df_prov, target_val)
    
    # Hitung biaya fiskal provinsi tersebut
    jiwa_prov <- target_prov$pop_jiwa[target_prov$R101 == kd_prov]
    total_biaya_rp <- topup_needed * jiwa_prov
    
    data.frame(
      R101 = kd_prov,
      tambahan_topup_kapita = topup_needed,
      total_anggaran_miliar = total_biaya_rp / 1e9
    )
  })

# 4. Join dengan Baseline dan Sort Berdasarkan Kemiskinan Tertinggi
tabel_akhir_prov <- target_prov %>%
  left_join(hasil_sim_prov, by = "R101") %>%
  arrange(desc(baseline_poverty)) %>% # SORT BERDASARKAN PROVINSI TERMISKIN
  mutate(
    baseline_pct = round(baseline_poverty * 100, 2),
    target_pct = round(target_poverty * 100, 2)
  )
```

```{r}
tabel_cetak <- tabel_akhir_prov %>% 
  arrange(R101) %>% 
  select(R101, baseline_pct, target_pct, tambahan_topup_kapita, total_anggaran_miliar)
#print(tabel_cetak, n = Inf)


# Rekap Total Fiskal
total_triliun <- sum(tabel_akhir_prov$total_anggaran_miliar, na.rm = TRUE) / 1000
cat("TOTAL ANGGARAN NASIONAL : Rp", round(total_triliun, 2), "Triliun\n")
``` 

**Analisis Kebutuhan Fiskal Nasional**

Berdasarkan hasil agregasi simulasi dari 38 provinsi, estimasi total kebutuhan fiskal untuk menurunkan angka kemiskinan nasional sebesar 1 persen poin adalah sebesar Rp 22,96 Triliun. Angka ini merepresentasikan akumulasi dari biaya intervensi yang disesuaikan dengan karakteristik kemiskinan dan Garis Kemiskinan di masing-masing wilayah. Perhitungan ini memberikan gambaran objektif mengenai skala pendanaan yang diperlukan untuk mencapai target akselerasi penghapusan kemiskinan dalam jangka pendek.

Nilai Rp 22,96 Triliun ini berfungsi sebagai pedoman bagi perencanaan anggaran pusat dan daerah. Perlu dicatat bahwa angka ini merupakan estimasi biaya intervensi langsung kepada penduduk target. Dalam implementasi praktisnya, angka ini dapat menjadi acuan untuk mengevaluasi kecukupan alokasi dana bantuan sosial yang sedang berjalan atau sebagai dasar pengajuan dana tambahan (top-up) dalam mekanisme perubahan anggaran. Dengan mengetahui nilai fiskal ini, pemerintah dapat mengukur sejauh mana "harga" dari sebuah target kesejahteraan rakyat yang ingin dicapai.


```{r}
total_triliun_prov <- sum(tabel_akhir_prov$total_anggaran_miliar, na.rm = TRUE) / 1000
wb <- createWorkbook()
addWorksheet(wb, "Simulasi_Provinsi")
writeData(wb, "Simulasi_Provinsi", "Hasil Simulasi Per Provinsi (Target Penurunan 1%)", startRow = 1)
writeData(wb, "Simulasi_Provinsi", tabel_akhir_prov %>% arrange(R101), startRow = 3)
saveWorkbook(wb, "Simulasi_Bansos_Provinsi_2026.xlsx", overwrite = TRUE)

```  



--------------------------------------------------------------------------------
> Directorate of Welfare Statistics, BPS Statistic Indonesia, saptahas@bps.go.id


