天池雪浪制造AI挑战赛(初赛)

2024-03-08 02:10

本文主要是介绍天池雪浪制造AI挑战赛(初赛),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一次参加比赛,记录一下,我是直接使用迁移学习进行分类 采用vgg16

排名不高仅供参考

import pandas as pd
import torch
import numpy as np
from torch.autograd import Variable
import torchvision
from torchvision import transforms, models
import matplotlib.pyplot as plt
import torch.nn.functional as F 
import os
from sklearn import metrics
import syssystem = sys.platform #判断系统的,两个电脑上 路径不一样
if system == 'win32':os.chdir('input')
mode = 'train'  # train用来训练, test生成csv提交结果
# mode = 'test'print('mode = ' + mode)#这一块是pytorch自带的的载入文件夹图片
transformer = transforms.Compose([transforms.Resize((224, 224)),# transforms.CenterCrop(200),# transforms.RandomVerticalFlip(),# transforms.RandomHorizontalFlip(),transforms.ToTensor(),transforms.Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])train_data = {x: torchvision.datasets.ImageFolder(x, transform=transformer)for x in ['train', 'val']}print(train_data['train'].class_to_idx)
train_loader = {}
train_loader['train'] = torch.utils.data.DataLoader(train_data['train'],batch_size=10,shuffle=True)
train_loader['val'] = torch.utils.data.DataLoader(train_data['val'],batch_size=10,shuffle=True)print('train num is ' + str(len(train_data['train'])))
print('val num is ' + str(len(train_data['val'])))if os.listdir('models'): #恢复模型print('restrore the model')model = torch.load('my_model.pkl')
else:print('use vgg16 model')# model = torch.load('vgg16.pkl') #因为网络不好, 我都是提前下下来保存再载入# model = torch.load('vgg_11_bn.pkl')# models.vgg16_bn(pretrained=True, batch_norm)model.classifier = torch.nn.Sequential(torch.nn.Linear(7*7*512, 2), #vgg提取特征不变  分类层改一下  if torch.cuda.is_available(): #cpu gpu转换model = model.cuda()
print(model)loss_func = torch.nn.CrossEntropyLoss()
lr = 1e-5optimizer = torch.optim.Adam(model.parameters(), lr=lr)## 建立这些列表基本都是用来画图的
epochs = 30 
plot_loss = []
best_auc = 0
auc_list = []
auc_list2 = []
train_acc_list = []
test_acc_list = []
# plt.ion()def valling(dir_name, model):"""得到网络输出   用来metrics0 1标签(用来算正确率)概率(算auc)label"""model.eval()print('valling in ' + str(dir_name))y_pre_all = np.array(())test_y_all = np.array(())all_pro = np.array(())for tep_idx, [test_x, test_y] in enumerate(train_loader[dir_name]):if tep_idx <= 10:test_x, test_y = next(iter(train_loader[dir_name]))if torch.cuda.is_available():test_x, test_y = (test_x.cuda()), (test_y.cuda())y_out_test = model(test_x)all_pro = np.append(all_pro, F.softmax(y_out_test, 0).cpu().data.numpy()[:, 1])# print(y_out_test)y_pre_test = torch.argmax(y_out_test, 1)y_pre_test = y_pre_test.cpu().data.numpy()test_y = test_y.cpu().data.numpy()# print(y_pre_all.shape)# print(y_pre_test.shape)y_pre_all = np.append(y_pre_all, y_pre_test)test_y_all = np.append(test_y_all, test_y)# print(y_pre_all.shape)return y_pre_all, test_y_all, all_prodef my_metrics(pre, label, pro):'''计算auc  acc'''# print('label shape is ' + str(label.shape))# print('pro shape is ' + str(pro.shape))auc = metrics.roc_auc_score(label, pro)bool_arr_test = (pre == label) test_acc = np.sum(bool_arr_test) / pre.sizereturn auc, test_accdef plot_list(list1, list2, dir_, title):'''画图  train 和test的acc  auc'''abs_dir = os.path.abspath(dir_)if not os.path.exists(os.path.dirname(abs_dir)):os.mkdir(os.path.dirname(abs_dir))print('creat dir{}'.format(abs_dir))plt.figure()plt.plot(list1, label='train')plt.plot(list2, label='test')plt.title(title)plt.legend(loc='best')plt.savefig(dir_)plt.close()if mode =='train':best_acc = 0plot_epoch_loss = []# print(model)for epoch in range(epochs):model.train()print('training')batch = 0epoch_loss = 0correct = 0# print(train_loader['train'])for data in train_loader['train']:batch += 1x, y = dataif torch.cuda.is_available():x, y = x.cuda(), y.cuda()x, y = Variable(x), Variable(y)y_out = model(x)optimizer.zero_grad()loss = loss_func(y_out, y)epoch_loss += loss# print(loss.data)# print(loss.data[0])loss.backward()optimizer.step()a_loss = loss.cpu().data.numpy()plot_loss.append(a_loss)plt.cla()plt.plot(plot_loss)print(a_loss)plt.text(0, 0.5, 'loss = %.3f' % a_loss, {'color': 'red', 'size': 15})plt.savefig('loss2.png')plt.close()plt.pause(0.5)y_pre_all, test_y_all, all_pro = valling('val', model)train_y_pre_all, train_test_y_all, train_all_pro = valling('train', model)auc, test_acc = my_metrics(y_pre_all, test_y_all, all_pro)train_auc, train_test_acc = my_metrics(train_y_pre_all, train_test_y_all, train_all_pro)train_acc_list.append(train_test_acc)test_acc_list.append(test_acc)saved_figs_dir = 'vgg11_full_32' plot_list(train_acc_list, test_acc_list, os.path.join('saved_figs', saved_figs_dir, 'acc.png'), 'acc_curve')auc_list.append(auc)auc_list2.append(train_auc)plot_list(auc_list2, auc_list, os.path.join('saved_figs', saved_figs_dir, 'auc.png'), 'auc_curve')best_acc = max(best_acc, test_acc) #保存最好的结果best_auc = max(best_auc, auc)print('test_acc = ' + str(test_acc * 100)[:4] + '%')print('train_acc = ' + str(train_test_acc * 100)[:4] + '%')epoch_loss = epoch_loss.cpu().data.numpy()print('This ' + str(epoch) + 'th epoch', 'epoch average loss = ' + str(epoch_loss/(batch)))plot_epoch_loss.append(epoch_loss / (batch))plt.figure()plt.plot(plot_epoch_loss)plt.title('epoch_loss')plt.savefig(os.path.join('saved_figs', saved_figs_dir, 'epoch_loss.png'))# plt.savefig('saved_figs/2/epoch_loss.png')print('lr = {}'.format(lr))if best_acc <= test_acc: #存正确率最高的模型# if best_auc <= auc:#存auc最高的print('score is better  store model')torch.save(model, 'models/my_model.pkl')else:print("not good don't save")print('-' * 40)    else:#用来生成提交结果test_data = torchvision.datasets.ImageFolder('test', transform=transformer)test_data_loader = torch.utils.data.DataLoader(test_data, batch_size=10,shuffle=False)ret_df = pd.DataFrame(columns=['filename', 'probability'])filenames = []for i in test_data.imgs:filename = os.path.basename(i[0])filenames.append(filename)# print(filenames)ret_df['filename'] = filenamesfor i, [x, y] in enumerate(test_data_loader):if torch.cuda.is_available():x = x.cuda()x = Variable(x)pre_out = model(x)pro = F.softmax(pre_out).cpu().data.numpy()[:, 1]pro = np.clip(pro, 0.000001, 0.999999)print('The ' + str(i*10) + ' th ' + 'row')try:ret_df.iloc[10*i: 10*i+10, 1] = proexcept Exception:ret_df.loc[10*i:, 'probability'] = proret_df = ret_df.round(6)print((ret_df['probability'] <= 0).sum())print((ret_df['probability'] >= 1).sum())ret_df.to_csv('outputs/submission.csv', index=False, encoding='utf-8')

新人学习中

这篇关于天池雪浪制造AI挑战赛(初赛)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/785625

相关文章

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

AI hospital 论文Idea

一、Benchmarking Large Language Models on Communicative Medical Coaching: A Dataset and a Novel System论文地址含代码 大多数现有模型和工具主要迎合以患者为中心的服务。这项工作深入探讨了LLMs在提高医疗专业人员的沟通能力。目标是构建一个模拟实践环境,人类医生(即医学学习者)可以在其中与患者代理进行医学

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

AI Toolkit + H100 GPU,一小时内微调最新热门文生图模型 FLUX

上个月,FLUX 席卷了互联网,这并非没有原因。他们声称优于 DALLE 3、Ideogram 和 Stable Diffusion 3 等模型,而这一点已被证明是有依据的。随着越来越多的流行图像生成工具(如 Stable Diffusion Web UI Forge 和 ComyUI)开始支持这些模型,FLUX 在 Stable Diffusion 领域的扩展将会持续下去。 自 FLU