位置: IT常识 - 正文

【生成模型】Stable Diffusion原理+代码(生成stl基本过程)

编辑:rootadmin
【生成模型】Stable Diffusion原理+代码

推荐整理分享【生成模型】Stable Diffusion原理+代码(生成stl基本过程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:stl模型怎么做,生成模型vae,stl模型怎么做,stl模型怎么做,生成模型vae,生成模型vae,生成模型gan,生成模型有,内容如对您有帮助,希望把文章链接给更多的朋友!

文章目录前言一、Latent space二、AutoEncoder 和 VAE1.AutoEncoder:2.VAE:三、Diffusion扩散模型1.前向过程2.逆向过程四、多模态 cross attention五、Stable Diffusion原理1.训练过程:ResnetBlockSpatial Transformer(Cross Attention)DownSample/UpSample2.前向过程*、代码解析1.整体代码2.unet解析1、self.input_blocks2、middle_blocks3、self.output_blocks总结前言

Stable diffusion是一个基于 Latent Diffusion Models(潜在扩散模型,LDMs)的文图生成(text-to-image)模型。具体来说,得益于 Stability AI 的计算资源支持和在 LAION-5B 的一个子集数据支持训练,用于文图生成。

Latent Diffusion Models 通过在一个潜在表示空间中迭代“去噪”数据来生成图像,然后将表示结果解码为完整的图像,让文图生成能够在消费级GPU上,在10秒级别时间生成图片。目前,Stable Diffusion发布了v2版本。v1版是Latent Diffusion Models的一个具体实现,模型架构设置:自动编码器下采样因子为8,UNet大小为860M,文本编码器为CLIP ViT-L/14。官方目前提供了以下权重:

提示:以下是本篇文章正文内容,下面案例可供参考

一、Latent space

隐空间是压缩数据的一个表示。数据压缩的目的是学习数据中较重要的信息。以编码器-解码器网络为例,首先使用全卷积神经网(FCN)络学习图片特征,我们将特征提取中对数据的降维看作一种有损压缩。由于解码器需要重建(reconstruct)数据,模型必须学习如何储存所有相关信息并且忽略噪音,压缩(降维)的好处在于可以去掉多余的信息从而关注于最关键的特征。

二、AutoEncoder 和 VAE1.AutoEncoder:

(1)AE是一个预训练的自编码器,优化目标是通过 Encoder 压缩数据,再通过decoder 还原数据,使得输入输出的数据尽量相同

(2)对于图像数据,decoder 还原数据可以看做是一个生成器,由于 decoder 输入数据z属于R空间,输入z的分布无法被固定住,所以大部分生成的图片是无意义的。

2.VAE:

(1)给定输入解码器的z一个分布可以解决上述问题,假设一个服从标准多元高斯分布的多维随机变量的数据集X,根据已知分布采样得到的zi,来训练decoder神经网络,从而得到多元高斯分布的均值和方差,从而成功得到一个逼近真实分布p(X)的p’(X)

(2)求解p’(X|z)的概率分布 (3)通过极大似然估计,最大化p’(X)的概率,但由于xi的维度很大,zi的维度也很大,需要准确找到与xi分布相关的zi,需要大量的采样,因此需要在encoder中引入后验分布p’(z|xi),让xi与zi关联起来

(4)利用encoder通过假设已知数据的分布,拟合其参数,从而逼近真实的后验分布p’(z|xi),在这里假设后验分布是基于多元高斯分布,则让encoder输出分布的均值和方差

(5)总体流程

三、Diffusion扩散模型1.前向过程

1.t 时刻的分布等于 t-1 时刻的分布+随机高斯分布的噪音,其中α是噪音的衰减值 2.任意时刻的分布 Xt ,都可以通过 X0 初始状态,以及步数计算出来:

2.逆向过程

已知 Xt,求初始状态的 X0,这里利用贝叶斯公式来预测 X0: 首先求已知 Xt 的分布求 **Xt-1**时刻的分布 (详细推导见上篇博客) :

四、多模态 cross attention

在 Unet 中间层引入cross attention,加入多模态的条件(文本,类别,layout,mask),实现如下:其中Q来自latent space,K,V来自文本等另一序列:

五、Stable Diffusion原理【生成模型】Stable Diffusion原理+代码(生成stl基本过程)

1.训练过程:

(1)使用预训练的CLIP模型,对需要训练的图像数据生成对应的描述词语。

(2)使用预训练的通用VAE,先用Encoder,将输入图片降维到 latent space(通常降采样倍数4-16)

(3) 将latent space输入diffusion model,进行扩散(正向采样),一步步生成噪声(在这个过程中,通过权重 β 控制每步生成噪声的强度,直到生成纯噪声,并记录每步生成噪声的数据,作为GT

(4)利用cross attention 将 latent space的特征与另一模态序列的特征融合,并添加到diffusion model的逆向过程,通过Unet逆向预测每一步需要减少的噪音,通过GT噪音与预测噪音的损失函数计算梯度。

(5)其中Denoising Unet的结构如下:

ResnetBlock

左下角小图所示, ResnetBlock 接受两个输入:latent 向量经过卷积变换后和经过全连接投影的 timestep_embedding 做加和,再和经过 skip connection 的原始 latent 向量做加和,送入另一个卷积层,得到经 Resnet 编码变换后的 latent 输出。

注意左侧的 ResnetBlock 和右侧的 ResnetBlock 的细微不同。左侧的 Resnet Block 接受的 latent 向量从 UNET 的上一层传入,而右侧的 ResnetBlock 除了接受 UNET 上一层的结果 latent 外,还需要接受左侧对应的 UNET 层的输出,两个 latent concat 起来作为 输入。所以,如果右侧的 ResnetBlock 上层的输出结果 shape 为 (64, 64, 320),左侧对应 UNET 层的输出结果为 (64, 64, 640),那么这个 ResnetBlock 得到的输入 latent 的 shape 为 (64, 64, 960)。

Spatial Transformer(Cross Attention)

右下角小图所示,Spatial Transformer 同样接受两个输入:经过上一个网络模块(一般为 ResnetBlock)处理和变换后的 latent 向量(对应的是是图片 token),及对应的 context embedding(文本 prompt 经过 CLIP 编码后的输出), cross attention 之后,得到变换后的 latent 向量(通过注意力机制,将 token 对应的语义信息注入到模型认为应该影响的图片 patch 中)。 Spatial Transformer 输出的 shape 和输入一致,但在对应的位置上融合了语义信息。

DownSample/UpSample

DownSample 将 latent 向量的前两个轴的大小缩减 50%,而 UpSample 将 latent 向量的前两个轴的大小增大一倍。DownSample 使用一个步长为 2 的二维卷积来实现,同时将输入 latent 向量的 channel 数变化成输出 latent 向量的 channel 数;而 UpSample 使用插值算法来实现,在插值之后进行一个步长为 1 的卷积,同时通过一个步长为 1 的二维卷积来将输入 latent 向量的 channel 数变化成输出 latent 向量的 channel 数。

需要注意的是,在整个 UNET 执行一次的过程中,timestep_embedding 和 content embedding 始终保持不变。而在 UNET 反复执行多次的过程中,timestep_embedding 每次都会发生变化,而 content embedding 始终保持不变。在迭代过程中,每次 UNET 输出的 noise_slice 都与原来 latent 向量相减,作为下次迭代时,UNET 的 Latent 输入。

2.前向过程

一个 Image Auto Encoder-Decoder,用于将 Image 编码成隐含向量 ,或者从隐含向量 中还原出图片; 一个 UNET 结构,使用 UNET 进行迭代降噪,在文本引导下进行多轮预测,将随机高斯噪声 转化成图片隐含向量 。

1.用文本编码器( CLIP 的 ViT-L/14 ),将用户输入的 Prompt 文本转化成 text embedding; 2.根据假定分布(一般是多元高斯分布),生成一张纯噪音图像; 3.利用VAE encoder 压缩到latent space; 4.执行Denoising Unet,利用cross attention融合多模态信息,并预测每一步需要减去的噪音: 5.利用VAE decoder还原到同一分布下的原图大小

*、代码解析1.整体代码1、prompt编码为token。编码器为FrozenCLIPEmbedde(包括1层的 CLIPTextEmbeddings 和12层的自注意力encoder)c = self.cond_stage_model.encode(c) # (c为输入的提示语句,重复2次) 输出:(2,77,768) batch_encoding = self.tokenizer(text, truncation=True, max_length=self.max_length, return_length=True, return_overflowing_tokens=False, padding="max_length", return_tensors="pt") # self.tokenizer来自 transformers包中的 预训练CLIPTokenizer tokens = batch_encoding["input_ids"].to(self.device) # (2,77)一句话编码为77维 outputs = self.transformer(input_ids=tokens).last_hidden_state # 12层self-atten,结果(2,77,768)2、samples_ddim, _ = sampler.sample(S=opt.ddim_steps, conditioning=c, batch_size=opt.n_samples, shape=shape, verbose=False, unconditional_guidance_scale=opt.scale, unconditional_conditioning=uc, eta=opt.ddim_eta, x_T=start_code) 01、self.make_schedule(ddim_num_steps=S, ddim_eta=eta, verbose=verbose) # S=50 # 这一步是ddim中,预先register超参数,如a的连乘等 # Data shape for PLMS sampling is (2, 4, 32, 32) 02、samples, intermediates = self.plms_sampling(conditioning, size, callback=callback, img_callback=img_callback, quantize_denoised=quantize_x0, mask=mask, x0=x0, ddim_use_original_steps=False, noise_dropout=noise_dropout, temperature=temperature, score_corrector=score_corrector, corrector_kwargs=corrector_kwargs, x_T=x_T ) img = torch.randn(shape, device=device) # (2,4,32,32) for i, step in enumerate(iterator): index = total_steps - i - 1 # index=50-i-1, step=981 ts = torch.full((b,), step, device=device, dtype=torch.long) # [981,981] outs = self.p_sample_plms(img, cond, ts, index=index, use_original_steps=ddim_use_original_steps, quantize_denoised=quantize_denoised, temperature=temperature, noise_dropout=noise_dropout, score_corrector=score_corrector, corrector_kwargs=corrector_kwargs, unconditional_guidance_scale=unconditional_guidance_scale, unconditional_conditioning=unconditional_conditioning, old_eps=old_eps, t_next=ts_next) c_in = torch.cat([unconditional_conditioning, c]) # 添加一个空字符,与promt拼接 e_t_uncond, e_t = self.model.apply_model(x_in, t_in, c_in).chunk(2) t_emb = timestep_embedding(timesteps, self.model_channels, repeat_only=False) # timesteps:[981,981,981,981] -> (4,320) emb = self.time_embed(t_emb) # 2*linear:(4,320) -> (4,1280) # unet中带入embed与prompt,具体代码见下节 for module in self.input_blocks: h = module(h, emb, context) # 输入(4,4,32,32) (4,1280) (4,77,768) hs.append(h) h = self.middle_block(h, emb, context) for module in self.output_blocks: h = th.cat([h, hs.pop()], dim=1) # (4,1280,4,4) -> (4,2560,4,4) h = module(h, emb, context) return self.out(h) # (4,320,32,32)卷积为(4,4,32,32)3、e_t_uncond, e_t = self.model.apply_model(x_in, t_in, c_in).chunk(2) # 上步中得到的结果拆开:(2,4,32,32 e_t = e_t_uncond + unconditional_guidance_scale * (e_t - e_t_uncond) # 用7.5乘以二者差距,再加回空语句生成的图 x_prev, pred_x0 = get_x_prev_and_pred_x0(e_t, index) # DDIM计算:e_t(2,4,32,32) index:49 -> (2,4,32,32)4、x_samples_ddim = model.decode_first_stage(samples_ddim) # (2,4,32,32) h = self.conv_in(z) # 卷积4->512 x = torch.nn.functional.interpolate(h, scale_factor=2.0, mode="nearest") #(2,512,64,64) h = self.up[i_level].block[i_block](h) # 经过几次卷积与上采样 h = self.norm_out(h) # (2,128,256,256) h = nonlinearity(h) # x*torch.sigmoid(x) h = self.conv_out(h) # conv(128,3) -》(2,3,256,256)5、后处理x_samples_ddim = torch.clamp((x_samples_ddim + 1.0) / 2.0, min=0.0, max=1.0)x_samples_ddim = x_samples_ddim.cpu().permute(0, 2, 3, 1).numpy()x_checked_image, has_nsfw_concept = check_safety(x_samples_ddim)x_checked_image_torch = torch.from_numpy(x_checked_image).permute(0, 3, 1, 2)x_sample = 255. * rearrange(x_sample.cpu().numpy(), 'c h w -> h w c')img = Image.fromarray(x_sample.astype(np.uint8))img.save(os.path.join(sample_path, f"{base_count:05}.png"))2.unet解析

DDIM中的Unet 包含输入模块、中间模块、输出模块三部分:

1、self.input_blocks

包含12个不同的 TimestepEmbedSequential结构,下面列举三种:

1、self.input_blocksModuleList( (0): TimestepEmbedSequential( (0): Conv2d(4, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (1): TimestepEmbedSequential( (0): ResBlock( (in_layers): Sequential( (0): GroupNorm32(32, 320, eps=1e-05, affine=True) (1): SiLU() (2): Conv2d(320, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (h_upd): Identity() (x_upd): Identity() (emb_layers): Sequential( (0): SiLU() (1): Linear(in_features=1280, out_features=320, bias=True) ) (out_layers): Sequential( (0): GroupNorm32(32, 320, eps=1e-05, affine=True) (1): SiLU() (2): Dropout(p=0, inplace=False) (3): Conv2d(320, 320, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (skip_connection): Identity() ) (1): SpatialTransformer( (norm): GroupNorm(32, 320, eps=1e-06, affine=True) (proj_in): Conv2d(320, 320, kernel_size=(1, 1), stride=(1, 1)) (transformer_blocks): ModuleList( (0): BasicTransformerBlock( (attn1): CrossAttention( (to_q): Linear(in_features=320, out_features=320, bias=False) (to_k): Linear(in_features=320, out_features=320, bias=False) (to_v): Linear(in_features=320, out_features=320, bias=False) (to_out): Sequential( (0): Linear(in_features=320, out_features=320, bias=True) (1): Dropout(p=0.0, inplace=False) ) ) (ff): FeedForward( (net): Sequential( (0): GEGLU( (proj): Linear(in_features=320, out_features=2560, bias=True) ) (1): Dropout(p=0.0, inplace=False) (2): Linear(in_features=1280, out_features=320, bias=True) ) ) (attn2): CrossAttention( (to_q): Linear(in_features=320, out_features=320, bias=False) (to_k): Linear(in_features=768, out_features=320, bias=False) (to_v): Linear(in_features=768, out_features=320, bias=False) (to_out): Sequential( (0): Linear(in_features=320, out_features=320, bias=True) (1): Dropout(p=0.0, inplace=False) ) ) (norm1): LayerNorm((320,), eps=1e-05, elementwise_affine=True) (norm2): LayerNorm((320,), eps=1e-05, elementwise_affine=True) (norm3): LayerNorm((320,), eps=1e-05, elementwise_affine=True) ) ) (proj_out): Conv2d(320, 320, kernel_size=(1, 1), stride=(1, 1)) ) ) (6): TimestepEmbedSequential( (0): Downsample( (op): Conv2d(640, 640, kernel_size=(3, 3), stride=(2, 2), padding=(1, 1)) ) )

前向过程: 为h添加emb和交与propmt的交叉注意力,会执行多次

emb_out = self.emb_layers(emb) # (4,1280)卷积为(4,320)h = h + emb_out # (4,320,32,32)+(4,320,1,1)x = self.attn1(self.norm1(x)) + x # 自注意力:x(4,1024,320)映射到qkv,均320维x = self.attn2(self.norm2(x), context=context) + x # 交叉注意力:context(4,77,768)映射到kv的320维x = self.ff(self.norm3(x)) + x

噪音图像h(4,4,32,32)在其中变化为:(4,320,32,32)(4,320,16,16)(4,640,16,16)(4,1280,8,8)(4,1280,4,4)

2、middle_blocksTimestepEmbedSequential( (0): ResBlock( (in_layers): Sequential( (0): GroupNorm32(32, 1280, eps=1e-05, affine=True) (1): SiLU() (2): Conv2d(1280, 1280, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (h_upd): Identity() (x_upd): Identity() (emb_layers): Sequential( (0): SiLU() (1): Linear(in_features=1280, out_features=1280, bias=True) ) (out_layers): Sequential( (0): GroupNorm32(32, 1280, eps=1e-05, affine=True) (1): SiLU() (2): Dropout(p=0, inplace=False) (3): Conv2d(1280, 1280, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (skip_connection): Identity() ) (1): SpatialTransformer( (norm): GroupNorm(32, 1280, eps=1e-06, affine=True) (proj_in): Conv2d(1280, 1280, kernel_size=(1, 1), stride=(1, 1)) (transformer_blocks): ModuleList( (0): BasicTransformerBlock( (attn1): CrossAttention( (to_q): Linear(in_features=1280, out_features=1280, bias=False) (to_k): Linear(in_features=1280, out_features=1280, bias=False) (to_v): Linear(in_features=1280, out_features=1280, bias=False) (to_out): Sequential( (0): Linear(in_features=1280, out_features=1280, bias=True) (1): Dropout(p=0.0, inplace=False) ) ) (ff): FeedForward( (net): Sequential( (0): GEGLU( (proj): Linear(in_features=1280, out_features=10240, bias=True) ) (1): Dropout(p=0.0, inplace=False) (2): Linear(in_features=5120, out_features=1280, bias=True) ) ) (attn2): CrossAttention( (to_q): Linear(in_features=1280, out_features=1280, bias=False) (to_k): Linear(in_features=768, out_features=1280, bias=False) (to_v): Linear(in_features=768, out_features=1280, bias=False) (to_out): Sequential( (0): Linear(in_features=1280, out_features=1280, bias=True) (1): Dropout(p=0.0, inplace=False) ) ) (norm1): LayerNorm((1280,), eps=1e-05, elementwise_affine=True) (norm2): LayerNorm((1280,), eps=1e-05, elementwise_affine=True) (norm3): LayerNorm((1280,), eps=1e-05, elementwise_affine=True) ) ) (proj_out): Conv2d(1280, 1280, kernel_size=(1, 1), stride=(1, 1)) ) (2): ResBlock( (in_layers): Sequential( (0): GroupNorm32(32, 1280, eps=1e-05, affine=True) (1): SiLU() (2): Conv2d(1280, 1280, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (h_upd): Identity() (x_upd): Identity() (emb_layers): Sequential( (0): SiLU() (1): Linear(in_features=1280, out_features=1280, bias=True) ) (out_layers): Sequential( (0): GroupNorm32(32, 1280, eps=1e-05, affine=True) (1): SiLU() (2): Dropout(p=0, inplace=False) (3): Conv2d(1280, 1280, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1)) ) (skip_connection): Identity() )3、self.output_blocks

与输入模块相同,包含12个 TimestepEmbedSequential,顺序相反

总结

整体结构比较简单,先用预训练CLIP将prompt变为token; DDIM模型将噪音与token逆扩散为图像;再采用VAE的decoder将图像复原到正常大小:

本文链接地址:https://www.jiuchutong.com/zhishi/297479.html 转载请保留说明!

上一篇:HTML零基础入门教程完整版(html零基础入门教程)

下一篇:【Ajax】如何通过axios发起Ajax请求(ajax调用)

  • 拉链快速门厂家拉链式快速卷帘门

    拉链快速门厂家拉链式快速卷帘门

  • OPPOwatch2价格及配置全面介绍(oppo watch 2系列)

    OPPOwatch2价格及配置全面介绍(oppo watch 2系列)

  • 华为nova7如何隐藏返回键(华为nova7如何隐藏软件)

    华为nova7如何隐藏返回键(华为nova7如何隐藏软件)

  • 华为荣耀8x手机怎样截屏(华为荣耀8x手机屏幕不受控制乱跳)

    华为荣耀8x手机怎样截屏(华为荣耀8x手机屏幕不受控制乱跳)

  • iphonexr信号不稳定怎么办(iponexr信号不稳定)

    iphonexr信号不稳定怎么办(iponexr信号不稳定)

  • 350w电机最高上多少w控制器(350w电机最大功率是多少)

    350w电机最高上多少w控制器(350w电机最大功率是多少)

  • 腾讯体育会员有什么用(腾讯体育会员有必要开吗)

    腾讯体育会员有什么用(腾讯体育会员有必要开吗)

  • iPhonexr屏幕左上角有个印

    iPhonexr屏幕左上角有个印

  • iphonese2手机壳和8一样吗(iphonese和se2的手机壳)

    iphonese2手机壳和8一样吗(iphonese和se2的手机壳)

  • 手机ip泄露了会怎样(手机ip泄露了会怎么样)

    手机ip泄露了会怎样(手机ip泄露了会怎么样)

  • 爱奇艺显示互动播放是什么意思(爱奇艺显示互动加载失败)

    爱奇艺显示互动播放是什么意思(爱奇艺显示互动加载失败)

  • soul能通过手机号找人吗(soul可以用电话号码查找吗)

    soul能通过手机号找人吗(soul可以用电话号码查找吗)

  • 电脑桌面文件打不开什么原因(电脑桌面文件打开方式选择)

    电脑桌面文件打不开什么原因(电脑桌面文件打开方式选择)

  • 华为设置上滑返回(华为怎么设置往上滑返回键)

    华为设置上滑返回(华为怎么设置往上滑返回键)

  • vivo手机查看本机号码(vivo手机查看本机ip)

    vivo手机查看本机号码(vivo手机查看本机ip)

  • oppo耳机模式怎么关闭(oppo耳机模式怎么取消不了)

    oppo耳机模式怎么关闭(oppo耳机模式怎么取消不了)

  • 华为9x有指纹解锁么(华为9x指纹解锁怎么没有了)

    华为9x有指纹解锁么(华为9x指纹解锁怎么没有了)

  • nemtl00h什么型号(nem tl00h)

    nemtl00h什么型号(nem tl00h)

  • windows10有必要分区吗(win10有没有必要分盘)

    windows10有必要分区吗(win10有没有必要分盘)

  • 微信自动收红包怎么设置(微信自动收红包功能是怎么弄的)

    微信自动收红包怎么设置(微信自动收红包功能是怎么弄的)

  • 迅雷下载到最后就不动了(迅雷下载到最后一点不动了)

    迅雷下载到最后就不动了(迅雷下载到最后一点不动了)

  • 苹果7如何接电话时录音(苹果如何接电话录音)

    苹果7如何接电话时录音(苹果如何接电话录音)

  • 电脑应用程序打不开(电脑应用程序打开没反应)

    电脑应用程序打不开(电脑应用程序打开没反应)

  • 在Linux中使用which和whereis命令来查找和定位文件(在linux中使用什么命令可以动态查看文件内容)

    在Linux中使用which和whereis命令来查找和定位文件(在linux中使用什么命令可以动态查看文件内容)

  • macOS 11 Big Sur 开发者预览版 Beta 7正式推送

    macOS 11 Big Sur 开发者预览版 Beta 7正式推送

  • 使用 Vite 插件开发构建 Tampermonkey 用户脚本(vite 插件开发)

    使用 Vite 插件开发构建 Tampermonkey 用户脚本(vite 插件开发)

  • 增值税的附加税比例
  • 缴纳印花税的会计凭证
  • 小规模纳税人的起征点是多少
  • 兼职劳务税率是多少2020
  • 事业单位缴纳增值税标准
  • 残保基金的计算公式
  • 一般纳税企业委托加工物资支付的增值税
  • 税负率过低进行什么交易
  • 软件开发服务费可以计入无形资产吗
  • 委外的加工费专用发票怎么开?
  • 房地产不可销售的物业有哪些
  • 损益表和利润表的关系
  • 兼职费用计税标准是多少
  • 国家税务局通用定额发票还能用吗
  • 企业支付宝可以转账到对公账户吗
  • 资金占用利息怎么开票
  • 空调作为固定资产吗
  • 苹果mac dns设置
  • xp系统为什么电脑不能用
  • 专项储备通俗理解
  • 商业承兑汇票分为哪两种
  • mac安装双系统教程
  • php如何实现
  • linux中qq怎么添加快捷键启动功能?
  • 免抵退税的账务处理
  • php中字符串函数
  • 国有土地出让收入分析报告
  • vue实现打印
  • 委托境外研发费
  • uniapp传值
  • smiles查询
  • 当月预交的增值税在申报期内可以填报进去抵扣
  • php中的函数
  • 微信php开发教程
  • 第一季度季初资产总额和第一季度季末同一个数吗
  • 前端项目和后端项目
  • 软件成本如何归类管理
  • 增值税专用发票上注明的价款含税吗
  • 归还股东投资款
  • 帝国cms使用手册
  • 国地税合并后工资仍然不一致
  • 软件行业的成本核算
  • 同控下的企业合并分录
  • 给员工发放礼品的祝福
  • 待处理流动资产损失属于什么科目
  • 员工的医药费计入什么科目
  • 税局代开专票对方隔月退回重开如何做账务处理呢?
  • 通讯发票可以税后抵扣吗
  • 工厂投产前的准备工作有哪些
  • 赠送商品给客户怎么写分录
  • 客观原因怎么写
  • 美容行业如何做好管理工作
  • 注册公司的流程及费用标准
  • 税收奖励账务处理
  • 个人生产经营所得税怎么申报
  • 公司转账给其他公司账户
  • 年底结账会计处理
  • 搭赠商品如何开票
  • 广州残保金如何计算
  • mysql使用教程
  • sqlmap 提权
  • win10预览版21301bug
  • win8鼠标右键没反应
  • xp系统如何查询配置
  • ubuntuiso
  • centos6.0安装教程
  • win7误删注册表
  • centos安装vim命令
  • centos7更改默认内核
  • win10安装完后有多大
  • win7关机没有强制关机选项
  • 校园网升级套餐
  • extern定义函数
  • 批处理文件bat
  • node.js 的适用场景?
  • javascript教程 csdn
  • js link global
  • javascript面向对象吗
  • 安阳市灵活就业人员社保补贴
  • 船舶吨税是中央税还是地方税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设