R:如何防止滞后和利兹从我的数据/图表中删除过去几年的内容

发布于 2025-01-17 18:15:19 字数 1106 浏览 2 评论 0原文

我和一个同学一起在剧本上工作,但我对R的经验不足。

我想在条形图中展示从1960年到2021年的民主化情节的发展,但是在图中从未显示过过去三年(2018年至2021年)。我们设定了测试下面显示的部分中是否存在一集的条件。我对问题的想法是以下内容: 条件之一是,如果这些值在4年内停滞不前,则没有发作。由于滞后或铅对此测试了4年的值,因此未考虑2018-2021,因为可以提前三年测试它们。但是,我不知道我是否对此有正确的轨道,还是如何解决问题。

d_dem <- d1 %>% 
group_by(iso3c) %>%
arrange(iso3c, year) %>%
mutate(
d_dem = v2x_libdem,
    d_lag = lag(d_dem),
d_diff = v2x_libdem - d_lag,
d_lead_diff1 = lead(d_diff, n = 1),
d_lead_diff2 = lead(d_diff, n = 2),
d_lead_diff3 = lead(d_diff, n = 3),
d_lead_diff4 = lead(d_diff, n = 4),
d_up01 = if_else(d_diff > 0.01, 1, 0),
  d_down02 = if_else(d_diff < -0.02, 1, 0)) %>%
ungroup %>%
rowwise() %>%
mutate(
d_change4 =
max(
 d_diff,
d_lead_diff1,
d_lead_diff2,
d_lead_diff3,
na.rm = TRUE)) %>%
ungroup %>%
mutate(
d_stag = if_else(d_change4 < .01, 1, 0) ) %>%
mutate(
d_potstart = d_up01,
d_potend = if_else(d_stag | d_down02, 1, 0)




 # I already tried to solve it by adding this: 

#     d_potend = if_else(year == 2021, 1, d_potend),
#     d_potend = if_else(between(year, 2018, 2021), 0, d_potend))

I worked on the script with a fellow student, but I am quite inexperienced with R myself.

I want to show the development of democratisation episodes from 1960 to 2021 in a bar chart, but the last three years (2018 to 2021) are never shown in the graph. We have set the conditions for testing whether an episode exists in the section shown below. My idea about the problem was the following:
One of the conditions is that there is no episode if the values are stagnant over 4 years. Since the values of the 4 following years are tested for this by lag or lead, 2018-2021 are not taken into account, since they can be tested for a maximum of three years in advance. However, I have no idea whether I am on the right track with this, or how I could solve the problem.

d_dem <- d1 %>% 
group_by(iso3c) %>%
arrange(iso3c, year) %>%
mutate(
d_dem = v2x_libdem,
    d_lag = lag(d_dem),
d_diff = v2x_libdem - d_lag,
d_lead_diff1 = lead(d_diff, n = 1),
d_lead_diff2 = lead(d_diff, n = 2),
d_lead_diff3 = lead(d_diff, n = 3),
d_lead_diff4 = lead(d_diff, n = 4),
d_up01 = if_else(d_diff > 0.01, 1, 0),
  d_down02 = if_else(d_diff < -0.02, 1, 0)) %>%
ungroup %>%
rowwise() %>%
mutate(
d_change4 =
max(
 d_diff,
d_lead_diff1,
d_lead_diff2,
d_lead_diff3,
na.rm = TRUE)) %>%
ungroup %>%
mutate(
d_stag = if_else(d_change4 < .01, 1, 0) ) %>%
mutate(
d_potstart = d_up01,
d_potend = if_else(d_stag | d_down02, 1, 0)




 # I already tried to solve it by adding this: 

#     d_potend = if_else(year == 2021, 1, d_potend),
#     d_potend = if_else(between(year, 2018, 2021), 0, d_potend))

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文