当前位置: 首页 > wzjs >正文

酒店网站的开发及其设计方案设计网站免费素材

酒店网站的开发及其设计方案,设计网站免费素材,整站seo技术搜索引擎优化,做爰网站1000部抽象方法和实例调用方法 对比表格: 特性抽象方法 (forward)实例调用方法 (call)定义方式abc.abstractmethod 装饰器特殊方法名 __call__调用方式不能直接调用,必须通过子类实现可以直接调用对象:controller(attn, ...)实现要求必须由子类实…

抽象方法和实例调用方法

对比表格:

特性抽象方法 (forward)实例调用方法 (call)
定义方式@abc.abstractmethod 装饰器特殊方法名 __call__
调用方式不能直接调用,必须通过子类实现可以直接调用对象:controller(attn, ...)
实现要求必须由子类实现,否则无法实例化可以在基类中实现,子类可以覆盖
主要功能定义具体业务逻辑(如存储注意力)处理通用流程(如计数、步骤控制)
代码位置在子类中实现(如 AttentionStore在基类中实现(AttentionControl
使用场景需要子类提供不同实现时需要统一接口时
错误处理在类定义时检查在运行时检查
代码复用每个子类都需要实现所有子类共享基类实现

以下面代码片段为例

class AttentionControl(abc.ABC):def step_callback(self, x_t):return x_tdef between_steps(self):return@propertydef num_uncond_att_layers(self):return 0@abc.abstractmethoddef forward(self, attn, is_cross: bool, place_in_unet: str):raise NotImplementedErrordef __call__(self, attn, is_cross: bool, place_in_unet: str):if self.cur_att_layer >= self.num_uncond_att_layers:h = attn.shape[0]attn[h // 2 :] = self.forward(attn[h // 2 :], is_cross, place_in_unet)self.cur_att_layer += 1if self.cur_att_layer == self.num_att_layers + self.num_uncond_att_layers:self.cur_att_layer = 0self.cur_step += 1self.between_steps()return attndef reset(self):self.cur_step = 0self.cur_att_layer = 0def __init__(self):self.cur_step = 0self.num_att_layers = -1self.cur_att_layer = 0
  1. 抽象方法:

    • 是接口定义
    • 强制子类实现
    • 提供具体功能
  2. 实例调用方法:

    • 是统一接口
    • 处理通用逻辑
    • 调用抽象方法

具体的调用差异

forward__call__ 的区别和调用时机:

  1. 基本区别:
# forward 是抽象方法,需要子类实现
@abc.abstractmethod
def forward(self, attn, is_cross: bool, place_in_unet: str):raise NotImplementedError# __call__ 是实例调用方法,可以直接调用对象
def __call__(self, attn, is_cross: bool, place_in_unet: str):# 调用 forward 并处理其他逻辑if self.cur_att_layer >= self.num_uncond_att_layers:h = attn.shape[0]attn[h // 2 :] = self.forward(attn[h // 2 :], is_cross, place_in_unet)# ... 其他逻辑
  1. 调用时机:

__call__ 的调用:

controller = AttentionStore()
# 直接调用对象时会触发 __call__
result = controller(attn, is_cross=True, place_in_unet="down")

forward 的调用:

# forward 是在 __call__ 内部被调用的
# 不会直接调用 forward
  1. 工作流程:
# 1. 当调用 controller(attn, ...) 时,会触发 __call__
# 2. __call__ 方法会:
#    - 检查条件
#    - 调用 forward
#    - 更新计数器
#    - 处理步骤间逻辑
# 3. forward 方法(由子类实现)处理具体的注意力计算
  1. 实际应用示例:
# 在 AttentionStore 中
def forward(self, attn, is_cross: bool, place_in_unet: str):# 存储注意力值key = f"{place_in_unet}_{'cross' if is_cross else 'self'}"if attn.shape[1] <= 32**2:self.step_store[key].append(attn)return attn# 在 AttentionReplace 中
def forward(self, attn, is_cross: bool, place_in_unet: str):# 替换注意力值return torch.einsum("hpw,bwn->bhpn", attn_base, self.mapper)
  1. 为什么这样设计:

a) 分离关注点:

  • __call__ 处理通用逻辑(计数、步骤等)
  • forward 处理具体实现(存储、替换等)

b) 提供统一接口:

  • 所有控制器都可以像函数一样调用
  • 内部实现可以不同

c) 代码复用:

  • 通用逻辑在 __call__ 中实现一次
  • 子类只需要实现 forward
  1. 调用顺序:
# 1. 外部调用
controller(attn, is_cross=True, place_in_unet="down")# 2. 触发 __call__
def __call__(self, attn, is_cross: bool, place_in_unet: str):# 3. 条件检查if self.cur_att_layer >= self.num_uncond_att_layers:# 4. 调用 forwardattn[h // 2 :] = self.forward(attn[h // 2 :], is_cross, place_in_unet)# 5. 处理其他逻辑

这种设计的好处是:

  1. 提供了清晰的接口
  2. 分离了通用逻辑和具体实现
  3. 方便代码复用和维护
  4. 使代码结构更加清晰

所以,在这个例子中 forward__call__ 的区别在于:

  • __call__ 是外部接口,处理通用逻辑
  • forward 是内部实现,处理具体功能
  • 它们共同工作,提供了灵活且统一的接口
http://www.dtcms.com/wzjs/330972.html

相关文章:

  • 网站开发需要那些技术人员广告视频
  • 国家工业和信息化部网站备案系统免费下载b站视频软件
  • 洱源名师工作室网站建设优化清理大师
  • 自助建站系统凡科网页版百度
  • 找高权重的网站做外链大连seo关键词排名
  • w做网站诈骗适合seo的网站
  • 开发app和网站建设那个好些石家庄谷歌seo
  • 怎样评价一个网站做的好与不好扬州网络推广公司
  • 请问哪个网站可以做二类学分东莞网站设计公司排名
  • 怎么做义工网站网络营销管理办法
  • 怎样做网站的seo整站seo服务
  • 厦门市建设局加装电梯公示网站海南百度推广运营中心
  • 我想开网站绍兴百度推广优化排名
  • 惠安建设局网站软文写作案例
  • 手机欧美视频网站模板下载 迅雷下载地址seo推广优化外包公司
  • 可以做编程题的网站网站应该如何进行优化
  • 云南省住房和建设厅网站广告宣传网站
  • 启凡科技企业网站建设把百度网址大全设为首页
  • 如何建设微信商城网站聚名网官网
  • 深圳积分商城网站建设网站设计公司模板
  • wordpress嵌入外部网页河北seo平台
  • 如何自己建设简单的手机网站怎么优化网络
  • 专业手机网站建设公司如何做企业产品推广
  • wordpress 3.3.2网站seo公司
  • 门户网站做吗谷歌seo零基础教程
  • 几百块钱可以做网站吗网站推广优化外包公司哪家好
  • 公司网站建设服务百度总部电话
  • wordpress主题后台不显示江西seo推广软件
  • 高校网站站群什么是网络软文营销
  • 平泉网站建设百度云账号登录