SDIO协议物理层简化规范V7.10:SD卡协会标准更新历史

需积分: 10 6 下载量 88 浏览量 更新于2024-07-15 收藏 4.34MB PDF 举报
SDIO(Secure Digital Input/Output)是一种广泛应用于移动设备和电子产品的接口标准,用于连接各种外部存储卡,如SD(Secure Digital)卡、SDHC(High Capacity Memory Card)、SDXC(Extended Capacity Memory Card)以及更高容量的存储解决方案。《Part1_Physical_Layer_Simplified_Specification_Ver7.10.pdf》是SDCard Association发布的SDIO物理层简化规范的最新版本,于2020年3月25日更新,旨在提供易理解且便于实施的规范,便于制造商设计兼容的设备。 该版本历史中,可以看到从早期的1.10版到7.10版的演变: 1. **版本1.10** (2006年4月3日):首次发布简化物理层规范,同时附带了Supplementary Notes Ver1.00。 2. **版本2.00** (2006年9月25日):增加了对高速SDHC支持,包括不同速度等级(Speed Class 2/4/6),进一步扩展了应用范围。 3. **版本3.01** (2010年5月18日):引入了SDXC卡和UHS-I(Ultra High Speed I)技术,提升了数据传输速度,以及Speed Class 10等级,提高了性能。 4. **版本4.10** (2013年1月22日):增添了UHS-II接口,提升了数据传输速率至更高级别,并引入了UHSSpeedGrade 3,以及电源限制功能,确保设备能更高效地管理功耗。 5. **版本5.00** (2016年8月10日):增加了视频速度等级VSC(Video Speed Class),针对视频应用优化,提供了VSC 4/6/10/30/60/90等不同的速度规格。 6. **版本6.00** (2017年4月10日):这一版可能进一步细化了规范,提升了标准或补充了新的功能,但具体改动未在提供的部分列出。 这些版本的变化反映了SDIO技术随着硬件进步和市场需求的增长而不断演进,不仅提高了存储卡的性能,也适应了多媒体应用的需求。在使用SDIO时,了解这些规范版本至关重要,因为它影响着设备兼容性、数据传输速度和功能实现。如果需要下载简化版本的规范,建议访问QUECTEL官网或其他官方授权渠道获取最新的文档。

优化这段代码:def calTravelCost(route_list,model): timetable_list=[] distance_of_routes=0 time_of_routes=0 obj=0 for route in route_list: timetable=[] vehicle=model.vehicle_dict[route[0]] travel_distance=0 travel_time=0 v_type = route[0] free_speed=vehicle.free_speed fixed_cost=vehicle.fixed_cost variable_cost=vehicle.variable_cost for i in range(len(route)): if i == 0: next_node_id=route[i+1] travel_time_between_nodes=model.distance_matrix[v_type,next_node_id]/free_speed departure=max(0,model.demand_dict[next_node_id].start_time-travel_time_between_nodes) timetable.append((int(departure),int(departure))) elif 1<= i <= len(route)-2: last_node_id=route[i-1] current_node_id=route[i] current_node = model.demand_dict[current_node_id] travel_time_between_nodes=model.distance_matrix[last_node_id,current_node_id]/free_speed arrival=max(timetable[-1][1]+travel_time_between_nodes,current_node.start_time) departure=arrival+current_node.service_time timetable.append((int(arrival),int(departure))) travel_distance += model.distance_matrix[last_node_id, current_node_id] travel_time += model.distance_matrix[last_node_id, current_node_id]/free_speed+\ + max(current_node.start_time - arrival, 0) else: last_node_id = route[i - 1] travel_time_between_nodes = model.distance_matrix[last_node_id,v_type]/free_speed departure = timetable[-1][1]+travel_time_between_nodes timetable.append((int(departure),int(departure))) travel_distance += model.distance_matrix[last_node_id,v_type] travel_time += model.distance_matrix[last_node_id,v_type]/free_speed distance_of_routes+=travel_distance time_of_routes+=travel_time if model.opt_type==0: obj+=fixed_cost+travel_distance*variable_cost else: obj += fixed_cost + travel_time *variable_cost timetable_list.append(timetable) return timetable_list,time_of_routes,distance_of_routes,obj

2023-06-11 上传

降低这段代码的重复率:def calTravelCost(route_list,model): timetable_list=[] distance_of_routes=0 time_of_routes=0 obj=0 for route in route_list: timetable=[] vehicle=model.vehicle_dict[route[0]] travel_distance=0 travel_time=0 v_type = route[0] free_speed=vehicle.free_speed fixed_cost=vehicle.fixed_cost variable_cost=vehicle.variable_cost for i in range(len(route)): if i == 0: next_node_id=route[i+1] travel_time_between_nodes=model.distance_matrix[v_type,next_node_id]/free_speed departure=max(0,model.demand_dict[next_node_id].start_time-travel_time_between_nodes) timetable.append((int(departure),int(departure))) elif 1<= i <= len(route)-2: last_node_id=route[i-1] current_node_id=route[i] current_node = model.demand_dict[current_node_id] travel_time_between_nodes=model.distance_matrix[last_node_id,current_node_id]/free_speed arrival=max(timetable[-1][1]+travel_time_between_nodes,current_node.start_time) departure=arrival+current_node.service_time timetable.append((int(arrival),int(departure))) travel_distance += model.distance_matrix[last_node_id, current_node_id] travel_time += model.distance_matrix[last_node_id, current_node_id]/free_speed+\ + max(current_node.start_time - arrival, 0) else: last_node_id = route[i - 1] travel_time_between_nodes = model.distance_matrix[last_node_id,v_type]/free_speed departure = timetable[-1][1]+travel_time_between_nodes timetable.append((int(departure),int(departure))) travel_distance += model.distance_matrix[last_node_id,v_type] travel_time += model.distance_matrix[last_node_id,v_type]/free_speed distance_of_routes+=travel_distance time_of_routes+=travel_time if model.opt_type==0: obj+=fixed_cost+travel_distance*variable_cost else: obj += fixed_cost + travel_time *variable_cost timetable_list.append(timetable) return timetable_list,time_of_routes,distance_of_routes,obj

2023-06-10 上传

优化代码,加背景图import tkinter as tk import numpy as np def change_label(): button.destroy() label.config(text="请输入您的身高体重以及目标体重:") height_label.place(relx=0.5, rely=0.4, anchor="center") height_entry.place(relx=0.5, rely=0.45, anchor="center") weight_label.place(relx=0.5, rely=0.5, anchor="center") weight_entry.place(relx=0.5, rely=0.55, anchor="center") target_label.place(relx=0.5, rely=0.6, anchor="center") target_entry.place(relx=0.5, rely=0.65, anchor="center") submit_button.place(relx=0.5, rely=0.8, anchor="center") def show_buttons(): calculate_low_carb() calculate_medium_carb() calculate_high_carb() label.config(text="您的营养素分配如下:") label.place(relx=0.5, rely=0.2, anchor="center") height_label.destroy() height_entry.destroy() weight_label.destroy() weight_entry.destroy() target_label.destroy() target_entry.destroy() submit_button.destroy() submit_button_1.place(relx=0.5, rely=0.8, anchor="center") def calculate_low_carb(): global low_protein_intake, low_carb_intake, low_fat_intake height = float(height_entry.get()) weight = float(weight_entry.get()) target_weight = float(target_entry.get()) # 根据BMI计算蛋白质摄入量 bmi = weight / (height / 100)**2 if bmi >= 27: low_protein_intake = weight elif bmi >= 24 and bmi < 27: low_protein_intake = weight * 1.5 else: low_protein_intake = weight * 2 # 计算低碳日的碳水摄入量和脂肪摄入量 low_carb_intake = weight low_fat_intake = weight low_carb_label = tk.Label(root, text = "您低碳日的碳水摄入量为{:.1f}克,蛋白质摄入量为{:.1f}克,脂肪摄入量为{:.1f}克".format(low_carb_intake, low_protein_intake, low_fat_intake), font=("Arial", 18)) low_carb_label.place(relx=0.5, rely=0.4, anchor="center") def calculate_medium_carb(): global medium_protein_intake, medium_carb_intake, medium_fat_intake height = float(height_entry.get()) weight = float(weight_entry.get()) target_weight = float(target_entry.get()) # 根据BMI计算蛋白质摄入量 bmi = weight / (height / 100)**2 if bmi >= 27: medium_protein_intake = weight elif bmi >= 24 and bmi < 27: medium_protein_intake = weight * 1.5 else: medium_protein_intake = weight * 2 # 计算中碳日的碳水摄入量和脂肪摄入量 medium_carb_intake = weight * 2 medium_fat_intake = weight * 0.5 medium_carb_label = tk.Label(root, text = "您中碳日的碳水摄入量为{:.1f}克,蛋白质摄入量为{:.1f}克,脂肪摄入量为{:.1f}克".format(medium_carb_intake, medium_protein_intake, medium_fat_intake), font=("Arial", 18)) medium_carb_label.place(relx=0.5, rely=0.5, anchor="center")

2023-05-31 上传