figure(); hold on; for n = 1:n_cars t_arrival = arrival_time(n); t_departure = departure_time(n); t_start = ceil(t_arrival / time_step) + 1; t_end = floor(t_departure / time_step) + 1; soc_arrival = energy_at_arrival(n) / bat_cap; soc_departure = soc_min; E_idx = round(soc_arrival * length(E)) + 1; step = t_start; while step <= t_end if path(n, step) == 1 if step == t_start soc = soc_arrival; else soc = soc_departure + (charge_power / bat_cap) * (step - k - 1) * time_step / 3600; end t = (step - 1) * time_step / 3600; plot([t, t+time_step/3600], [soc, soc], 'b-', 'LineWidth'); hold on; plot([t, t], [soc, soc-departure_time(n)+arrival_time(n)], 'r-', 'LineWidth', 2); k = step; end soc_departure = max(soc_min, soc_arrival - charge_demand(n) / bat_cap); step = step + 1; end end xlabel('Time (h)'); ylabel('State of Charge'); title('Charging Schedule'); grid on; hold on;为什么画不出来曲线
时间: 2024-02-04 12:03:16 浏览: 19
可能有多种原因导致绘图不成功,以下是一些可能的问题和解决方法:
1. 数据不正确:请检查输入到代码中的数据是否正确,可能存在数据错误导致绘图失败。
2. 变量未定义:请确保在代码中定义了所有使用的变量,例如 time_step、n_cars、arrival_time、departure_time、energy_at_arrival、bat_cap、soc_min、E、path、charge_power、charge_demand。
3. 图形窗口未显示:请检查是否正确打开了 MATLAB 图形窗口,在代码运行后是否正确显示图形窗口。
4. 代码中存在错误:请检查代码中是否存在错误,例如语法错误、逻辑错误等,这些错误可能导致绘图失败。
如果以上方法无法解决问题,请尝试将代码和数据一起发送给我,我会帮您检查问题所在。
相关问题
figure(); hold on; for n = 1:n_cars t_arrival = arrival_time(n); t_departure = departure_time(n); t_start = ceil(t_arrival / time_step) + 1; t_end = floor(t_departure / time_step) + 1; soc_arrival = energy_at_arrival(n) / bat_cap; soc_departure = soc_min; E_idx = round(soc_arrival * length(E)) + 1; step = t_start; while step <= t_end if path(n, step) == 1 if step == t_start soc = soc_arrival; else soc = soc_departure + (charge_power / bat_cap) * (step - k - 1) * time_step / 3600; end t = (step - 1) * time_step / 3600; plot([t, t+time_step/3600], [soc, soc], 'r', 'LineWidth', 2); hold on; plot([t, t], [soc, soc-departure_time(n)+arrival_time(n)], 'r-', 'LineWidth', 2); k = step; end soc_departure = max(soc_min, soc_arrival - charge_demand(n) / bat_cap); step = step + 1; end end xlabel('Time (h)'); ylabel('State of Charge'); title('Charging Schedule'); grid on; hold on;为什么无法生成曲线
根据代码,生成曲线的过程是在一个 for 循环中进行的,循环次数是 n_cars。因此,无法生成曲线可能是由于以下原因之一:
1. 变量 n_cars 的值为 0,即没有车辆需要生成曲线;
2. 变量 E 的值没有被初始化,导致无法计算 soc_arrival;
3. 变量 path 的值没有被初始化,导致无法判断需要绘制的路径;
4. 变量 charge_power、bat_cap、time_step、charge_demand、arrival_time、departure_time、energy_at_arrival、soc_min 的值没有被正确设置;
5. 曲线被生成,但是没有被正确显示。
需要检查以上原因,找出造成无法生成曲线的具体原因。
for i = 2:1000 arrival_time = arrival_times(i); service_time = service_times(i); if arrival_time >= crane_busy_until(i - 1) waiting_time = 0; crane_busy_until = arrival_time + service_time; else waiting_time = crane_busy_until(i - 1) - arrival_time; crane_busy_until = crane_busy_until(i - 1) + service_time; end waiting_times(i) = waiting_time; total_time_in_port(i) = waiting_time + service_time; end
这段代码看起来像是模拟一个港口的装卸货物过程,其中arrival_times是货船到达的时间,service_times是装卸货物需要的时间,waiting_times是每艘货船等待的时间,total_time_in_port是每艘货船在港口停留的总时间。
在循环中,首先获取当前货船的到达时间和需要的服务时间。然后判断当前货物是否需要等待,如果上一艘货船的装卸已经完成,那么当前货船就可以直接进行装卸,等待时间为0。如果上一艘货船的装卸还未完成,那么当前货船需要等待上一艘货船完成后再进行装卸,等待时间为上一艘货船的装卸结束时间减去当前货船的到达时间。最后将等待时间和总时间存储到相应的数组中。