IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 强化学习-动态规划-杰克租车问题 -> 正文阅读

[数据结构与算法]强化学习-动态规划-杰克租车问题

例4.2:

杰克管理一个全国性汽车出租公司的两个地点。每天一些顾客到这两个地点租车。如果有车可租,杰克就将车租出并从公司得到10美元的回扣。如果这个地点没车,杰克就失去了这笔生意。还回的车第二天就可以出租。为了使需要车的地点有车可租,每天晚上,杰克可以在两个地点间移动车辆,移动每辆车的费用是2美元。我们假设每个地点的车的需求量和归还量都是泊松分布变量。假设租车的期望值是3和4,还车的期望值是3和2。

为了简化问题,我们假设每个地点的车不多于20辆(多于的车被还回公司,在此问题中消失了)并且一晚上最多移动5辆车。折扣率为0.9,并描述为一个有限MDP问题,时刻按天计算,状态是每天结束时两个地点的车辆数,动作是晚上在两个地点间移动的车辆数。
?

一,求动力(dynamics)P(s',r|s,a)

首先困扰我的是动作发生时间,顺序是 移车-借车-还车,还是 借车-还车-移车。顺序不同,车辆数不同。 反复读题后选择了“ 移车-借车-还车” 的顺序。

第二个困扰我的是,如何统计状态转移概率?参考大佬代码后明白,分为以下几步

??????? 先由泊松分布公式,计算出A,B两地借还车数量的概率

def poisson_calculator(Lambda=3):
    result = {}
    for i in range(0, 21):
        result[i] = max(np.finfo(float).eps, abs((np.power(Lambda, i) / (np.math.factorial(i))) * np.exp(-Lambda)))#防止result中出现0
    return result

customer_A = poisson_calculator(3) 
customer_B = poisson_calculator(4) 
return_A = poisson_calculator(3)
return_B = poisson_calculator(2)

?????? 假设两地借还车相互独立,即可计算出所有借还车情况的概率p(customer_A,return_A,customer_B,return_B)

??????? 则p(s',r|s,a)可由模拟实际情况求得。

??????? 从状态(0,0)开始,遍历所有可能情况,累加所有符合P(s',r|(0,0),a) 的概率并命名储存备用

    for state_value_A in range(21):  # car left at the end of the day at A
        print("State " + str(state_value_A))
        for state_value_B in range(21):  # car left at the end of the day at B
            P = {}#字典类型的P
            for action in range(-5, 6):  # action range is from -5 to 5
                temp = {}
                #problem: action=-5 A=1 B=10
                #action要合理,不合理的不考虑
                if action <= state_value_A and -action <= state_value_B and action + state_value_B <= 20 and -action + state_value_A <= 20:
                    for customer_A in range(21):  # total customers come at the end of the day at A
                        for customer_B in range(21):  # total customers come at the end of the day at B
                            for returned_car_A in range(21):  # total cars returned at the end of the day at A
                                for returned_car_B in range(21):  # total cars returned at the end of the day at B
                                    #value_a_changed 指当天用户还完车时所余车辆与晚上移车,再到第二天还车 正确
                                    #情况一:value_A_Changed=20 当结束时车辆大于20
                                    #情况二:value_A_Changed=state_value_A -customer_A+ returned_car_A - action 当用户需求 < state_value_A- action
                                    #情况三value_A_Changed= returned_car_A 当用户需求 > state_value_A- action
                                    value_A_Changed = min(20, state_value_A - min(customer_A,
                                                                                  state_value_A- action) + returned_car_A - action)
                                    value_B_Changed = min(20, state_value_B - min(customer_B,
                                                                                  state_value_B+ action) + returned_car_B + action)
                                    #state_value_A 是上一天运车前的车数,state_value_A - action就是下一天所拥有的车数
                                    reward = 10 * min(customer_A, state_value_A - action ) + \
                                             10 * min(customer_B, state_value_B + action) - \
                                             abs(action) * 2  #动作费用  the reason for action here is the current action change the next stroes

二,策略评估

代码参考https://github.com/LyWangPX/Reinforcement-Learning-2nd-Edition-by-Sutton-Exercise-Solutions

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-10 14:44:49  更:2021-07-10 14:44:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:09:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码