使用Get进行Http通信

--------------siwuxie095

   

   

   

   

   

   

   

有道翻译官网:http://fanyi.youdao.com/

   

找到官网页面下方的 有道翻译API,选择 调用数据接口,申请一个 key

   

(申请内容可随意填写)

   

   

   

   

   

申请成功:

   

   

   

   

   

自动生成一个对应的数据接口:http://fanyi.youdao.com/openapi.do?keyfrom=siwuxie095-test&key=2140200403&type=data&doctype=<doctype>&version=1.1&q=要翻译的文本

   

需要指定 <doctype>要翻译的文本

   

   

   

   

   

关于 API 的说明:

   

   

   

   

   

   

   

工程名:TestHttpGet

包名:com.siwuxie095.http

类名:TestGet.java

   

   

   

工程结构目录如下:

   

   

   

   

代码:

   

package com.siwuxie095.http;

   

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.net.MalformedURLException;

import java.net.URL;

import java.net.URLConnection;

   

public class TestGet {

   

public static void main(String[] args) {

   

//调用线程 ReadByGet,使用匿名对象

new ReadByGet().start();

}

 

 

//创建一个新的线程,这是一个内部的类,继承自 Thread

//因为要在主方法(静态)中调用,所以要声明成静态

//不加 static 也可以,需要把 ReadByGet 移出 TestGet,不过这时就不是内部类了

static class ReadByGet extends Thread{

 

//覆盖父类的run()方法

@Override

public void run() {

//创建一个URL对象,注意:是 java.net 包中的

//url 即网络路径,传入String

//(当在整个链接中使用回车时,链接自动断开,形成多个字符串)

//指定doctype类型为:XML,翻译:welcome

//doctype 还可以指定为 json jsonp

//最终返回结果的数据格式是 XML 类型

//有异常抛出,用 try catch 捕获

try {

 

URL url=new URL("http://fanyi.youdao.com/openapi.do?"

+ "keyfrom=siwuxie095-test&key=2140200403&type=data"

+ "&doctype=xml&version=1.1&q=welcome");

 

 

//使用openConnection()方法打开链接

//返回值是URLConnection类型,创建以接收返回值

//同样是 java.net 包中的类

//有异常抛出,用 try catch 捕获

URLConnection connection=url.openConnection();

 

//获取网络连接输入流,返回值是InputStream类型

//创建一个InputStream,接收返回值

InputStream is=connection.getInputStream();

 

//创建一个InputStreamReader,包装InputStream

//如果读取的数据有乱码,在字节流包装成字符流时可以指定编码

InputStreamReader isr=new InputStreamReader(is,"UTF-8");

//InputStreamReader isr=new InputStreamReader(is);

 

//创建一个BufferedReader,包装InputStreamReader

BufferedReader br=new BufferedReader(isr);

 

//包装完成,将数据全部读取

String line;

StringBuilder builder=new StringBuilder();

//当读取的一行数据不为空,则当前内容没有结束,添加到StringBuilder

while ((line=br.readLine())!=null) {

builder.append(line);

}

 

 

//读取完毕,关闭输入流,后打开的先关闭

br.close();

isr.close();

is.close();

 

//打印StringBuilder中的所有数据

System.out.println(builder.toString());

 

} catch (MalformedURLException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

 

   

}

   

   

运行一览:

   

   

   

   

将输出的 XML 数据,复制->粘贴->格式化:

   

   

   

   

   

   

   

【made by siwuxie095】

转载于:https://www.cnblogs.com/siwuxie095/p/6649711.html

### RT-DETRv3 网络结构分析 RT-DETRv3 是一种基于 Transformer 的实时端到端目标检测算法,其核心在于通过引入分层密集正监督方法以及一系列创新性的训练策略,解决了传统 DETR 模型收敛慢和解码器训练不足的问题。以下是 RT-DETRv3 的主要网络结构特点: #### 1. **基于 CNN 的辅助分支** 为了增强编码器的特征表示能力,RT-DETRv3 引入了一个基于卷积神经网络 (CNN) 的辅助分支[^3]。这一分支提供了密集的监督信号,能够与原始解码器协同工作,从而提升整体性能。 ```python class AuxiliaryBranch(nn.Module): def __init__(self, in_channels, out_channels): super(AuxiliaryBranch, self).__init__() self.conv = nn.Conv2d(in_channels, out_channels, kernel_size=3, padding=1) self.bn = nn.BatchNorm2d(out_channels) def forward(self, x): return F.relu(self.bn(self.conv(x))) ``` 此部分的设计灵感来源于传统的 CNN 架构,例如 YOLO 系列中的 CSPNet 和 PAN 结构[^2],这些技术被用来优化特征提取效率并减少计算开销。 --- #### 2. **自注意力扰动学习策略** 为解决解码器训练不足的问题,RT-DETRv3 提出了一种名为 *self-att 扰动* 的新学习策略。这种策略通过对多个查询组中阳性样本的标签分配进行多样化处理,有效增加了阳例的数量,进而提高了模型的学习能力和泛化性能。 具体实现方式是在训练过程中动态调整注意力权重分布,确保更多的高质量查询可以与真实标注 (Ground Truth) 进行匹配。 --- #### 3. **共享权重解编码器分支** 除了上述改进外,RT-DETRv3 还引入了一个共享权重的解编码器分支,专门用于提供密集的正向监督信号。这一设计不仅简化了模型架构,还显著降低了参数量和推理时间,使其更适合实时应用需求。 ```python class SharedDecoderEncoder(nn.Module): def __init__(self, d_model, nhead, num_layers): super(SharedDecoderEncoder, self).__init__() decoder_layer = nn.TransformerDecoderLayer(d_model=d_model, nhead=nhead) self.decoder = nn.TransformerDecoder(decoder_layer, num_layers=num_layers) def forward(self, tgt, memory): return self.decoder(tgt=tgt, memory=memory) ``` 通过这种方式,RT-DETRv3 实现了高效的目标检测流程,在保持高精度的同时大幅缩短了推理延迟。 --- #### 4. **与其他模型的关系** 值得一提的是,RT-DETRv3 并未完全抛弃经典的 CNN 技术,而是将其与 Transformer 结合起来形成混合架构[^4]。例如,它采用了 YOLO 系列中的 RepNCSP 模块替代冗余的多尺度自注意力层,从而减少了不必要的计算负担。 此外,RT-DETRv3 还借鉴了 DETR 的一对一匹配策略,并在此基础上进行了优化,进一步提升了小目标检测的能力。 --- ### 总结 综上所述,RT-DETRv3 的网络结构主要包括以下几个关键组件:基于 CNN 的辅助分支、自注意力扰动学习策略、共享权重解编码器分支以及混合编码器设计。这些技术创新共同推动了实时目标检测领域的发展,使其在复杂场景下的表现更加出色。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值