It is possible to rework the functions in this package to make a spatial, rather than temporal, price index using a star model by simply replacing “time” with “space”. Although this is not a suitable approach for making a system of purchasing power parities, is it useful for making indexes that adjust pay for cost-of-living differences relative to a fixed location. These sorts of indexes are made by the United Nations International Civil Service Commission, Eurostat, and various governments and private-sector organizations for administering cost-of-living allowances.
The basic workflow is the same as with a temporal index, just treating each country as a different “time period” in a fixed-based index.
library(piar)
set.seed(12345)
# Make indexes for 6 basic headings for 4 countries.
bh_index <- matrix(
c(rep(1, 6), runif(6 * 3, 0.8, 1.2)),
nrow = 6,
dimnames = list(
paste0("BH", 1:6),
paste("Country", 1:4)
)
) |>
as_index(chainable = FALSE)
head(bh_index)
## Fixed-base price index for 6 levels over 4 time periods
## Country 1 Country 2 Country 3 Country 4
## BH1 1 1.0883616 0.9300382 1.0942740
## BH2 1 1.1503093 1.0036897 0.8004546
## BH3 1 1.1043929 1.0910821 0.9564813
## BH4 1 1.1544498 1.1958948 0.9849979
## BH5 1 0.9825924 0.8138142 0.9552576
## BH6 1 0.8665487 0.8609494 0.9609941
# Make fixed aggregation weights.
# 1
# |-----+-----|
# 11 12
# |---+---| |---+---|
# B1 B2 B3 B4 B5 B6
weights <- data.frame(
level1 = 1,
level2 = rep(11:12, each = 3),
bh = levels(bh_index),
weights = runif(6, 100, 200)
)
head(weights)
## level1 level2 bh weights
## 1 1 11 BH1 117.8964
## 2 1 11 BH2 195.1659
## 3 1 11 BH3 145.3728
## 4 1 12 BH4 132.6752
## 5 1 12 BH5 196.5415
## 6 1 12 BH6 170.7482
The indexes at the basic-heading level can be aggregated as usual to get a collection of indexes that give the difference in purchasing power relative to the base country (country 1 in this example). Different choices for weights make different assumptions about how people change their spending patterns between each country and the base country.
index <- aggregate(bh_index, weights)
As it can be costly to collect price data from various countries on a regular basis, these sorts of indexes are often updated over time by changes in exchange rates and inflation rates for each country.
as.matrix(index[1, -1])
## Country 2 Country 3 Country 4
## 1 1.051349 0.9701244 0.9461596
## Country 2 Country 3 Country 4
## 1 1.112134 0.9273724 1.021301