网站建设服务器和空间费做网站的员工怎么设置绩效考核
2026/5/14 0:50:31 网站建设 项目流程
网站建设服务器和空间费,做网站的员工怎么设置绩效考核,深圳自己做网站 服务器,网建工作文章目录0 前言1 课题描述课题意义2 实现效果3 算法实现原理3.1 数据集3.2 深度学习识别算法3.3 特征提取主干网络3.4 总体实现流程4 具体实现4.1 预训练数据格式4.2 部分实现代码0 前言 今天学长向大家介绍一个基于深度学习机器视觉的项目#xff0c;人脸性别年龄识别系统人脸性别年龄识别系统 该项目是非常不错的毕设课题哦选题指导, 项目分享见文末1 课题描述随着大数据与人工智能逐渐走入人们的生活计算机视觉应用越发广泛。如医疗影像识别、无人驾驶车载视觉、通用物体识别、自然场景下的文本识别等根据不同的应用场景人脸研究方向可以分为人脸检测、身份识别、性别识别、年龄预测、种族识别、表情识别等。近年来人脸身份识别技术发展迅猛在生活应用中取得了较好的效果也逐渐趋于成熟而年龄识别与性别预测仍然是生物特征识别研究领域中一项具有挑战性的课题。课题意义相比人脸性别属性而言人脸年龄属性的研究更富有挑战性。主要有两点原因首先每个人的年龄会随着身体健康状况、皮肤保养情况而表现得有所不同即便是在同一年表现年龄会随着个人状态的不同而改变人类识别尚且具有较高难度。其次可用的人脸年龄估计数据集比较少不同年龄的数据标签收集不易现有大多数的年龄数据集都是在不同的复杂环境下的照片、人脸图片存在光照变化较复杂、部分遮挡、图像模糊、姿态旋转角度较大等一系列问题对人脸模型的鲁棒性产生了较大的影响。2 实现效果这里废话不多说先放上大家最关心的实现效果输入图片识别结果或者实时检测3 算法实现原理3.1 数据集学长收集的数据集该人脸数据库的图片来源于互联网的爬取而非研究机构整理一共含有13000多张人脸图像在这个数据集中大约有1860张图片是成对出现的即同一个人的2张不同照片有助于人脸识别算法的研究图像标签中标有人的身份信息人脸坐标关键点信息可用于人脸检测和人脸识别的研究此数据集是对人脸算法效果验证的权威数据集.该数据集包含的人脸范围比较全面欧亚人种都有。3.2 深度学习识别算法卷积神经网络是常见的深度学习架构而在CNN出现之前图像需要处理的数据量过大导致成本很高效率很低图像在数字化的过程中很难保留原有的特征导致图像处理的准确率不高。CNN的出现使得提取特征的能力变得更强为更多优秀网络的研究提供了有力的支撑。CNN的核心思想是利用神经网络模拟人脑视觉神经系统构造多个神经元并建立彼此之间的联系。不同的神经元进行分工浅层神经元处理低纬度图像特征深层神经元处理图像高级特征、语义信息等CNN的网络结构主要由卷积层、BN层、激活层、池化层、全连接层、损失函数层构成多个层协同工作实现了特征提取的功能并通过特有的网络结构降低参数的数量级防止过拟合最终得到输出结果.CNN传承了多层感知机的思想并受到了生物神经科学的启发通过卷积的运算模拟人类视觉皮层的“感受野”。不同于传统的前馈神经网络卷积运算对图像的区域值进行加权求和最终以神经元的形式进行输出。前馈神经网络对每一个输入的信号进行加权求和a图是前馈神经网络的连接方式b图是CNN的连接方式。cnn框架如下3.3 特征提取主干网络在深度学习算法研究中通用主干特征提取网络结合特定任务网络已经成为一种标准的设计模式。特征提取对于分类、识别、分割等任务都是至关重要的部分。下面介绍本文研究中用到的主干神经网络。ResNet网络ResNet是ILSVRC-2015的图像分类任务冠军也是CVPR2016的最佳论文目前应用十分广泛ResNet的重要性在于将网络的训练深度延伸到了数百层而且取得了非常好的效果。在ResNet出现之前网络结构一般在20层左右对于一般情况网络结构越深模型效果就会越好但是研究人员发现加深网络反而会使结果变差。人脸特征提取我这里选用ResNet网络结构如下3.4 总体实现流程4 具体实现4.1 预训练数据格式4.2 部分实现代码训练部分代码from__future__importabsolute_importfrom__future__importdivisionfrom__future__importprint_functionfromsix.movesimportxrangefromdatetimeimportdatetimeimporttimeimportosimportnumpyasnpimporttensorflowastffromdataimportdistorted_inputsfrommodelimportselect_modelimportjsonimportre LAMBDA0.01MOM0.9tf.app.flags.DEFINE_string(pre_checkpoint_path,,If specified, restore this pretrained model before beginning any training.)tf.app.flags.DEFINE_string(train_dir,/home/dpressel/dev/work/AgeGenderDeepLearning/Folds/tf/test_fold_is_0,Training directory)tf.app.flags.DEFINE_boolean(log_device_placement,False,Whether to log device placement.)tf.app.flags.DEFINE_integer(num_preprocess_threads,4,Number of preprocessing threads)tf.app.flags.DEFINE_string(optim,Momentum,Optimizer)tf.app.flags.DEFINE_integer(image_size,227,Image size)tf.app.flags.DEFINE_float(eta,0.01,Learning rate)tf.app.flags.DEFINE_float(pdrop,0.,Dropout probability)tf.app.flags.DEFINE_integer(max_steps,40000,Number of iterations)tf.app.flags.DEFINE_integer(steps_per_decay,10000,Number of steps before learning rate decay)tf.app.flags.DEFINE_float(eta_decay_rate,0.1,Learning rate decay)tf.app.flags.DEFINE_integer(epochs,-1,Number of epochs)tf.app.flags.DEFINE_integer(batch_size,128,Batch size)tf.app.flags.DEFINE_string(checkpoint,checkpoint,Checkpoint name)tf.app.flags.DEFINE_string(model_type,default,Type of convnet)tf.app.flags.DEFINE_string(pre_model,,#./inception_v3.ckpt,checkpoint file)FLAGStf.app.flags.FLAGS# Every 5k steps cut learning rate in halfdefexponential_staircase_decay(at_step10000,decay_rate0.1):print(decay [%f] every [%d] steps%(decay_rate,at_step))def_decay(lr,global_step):returntf.train.exponential_decay(lr,global_step,at_step,decay_rate,staircaseTrue)return_decaydefoptimizer(optim,eta,loss_fn,at_step,decay_rate):global_steptf.Variable(0,trainableFalse)optzoptimifoptimAdadelta:optzlambdalr:tf.train.AdadeltaOptimizer(lr,0.95,1e-6)lr_decay_fnNoneelifoptimMomentum:optzlambdalr:tf.train.MomentumOptimizer(lr,MOM)lr_decay_fnexponential_staircase_decay(at_step,decay_rate)returntf.contrib.layers.optimize_loss(loss_fn,global_step,eta,optz,clip_gradients4.,learning_rate_decay_fnlr_decay_fn)defloss(logits,labels):labelstf.cast(labels,tf.int32)cross_entropytf.nn.sparse_softmax_cross_entropy_with_logits(logitslogits,labelslabels,namecross_entropy_per_example)cross_entropy_meantf.reduce_mean(cross_entropy,namecross_entropy)tf.add_to_collection(losses,cross_entropy_mean)lossestf.get_collection(losses)regularization_lossestf.get_collection(tf.GraphKeys.REGULARIZATION_LOSSES)total_losscross_entropy_meanLAMBDA*sum(regularization_losses)tf.summary.scalar(tl (raw),total_loss)#total_loss tf.add_n(losses regularization_losses, nametotal_loss)loss_averagestf.train.ExponentialMovingAverage(0.9,nameavg)loss_averages_oploss_averages.apply(losses[total_loss])forlinlosses[total_loss]:tf.summary.scalar(l.op.name (raw),l)tf.summary.scalar(l.op.name,loss_averages.average(l))withtf.control_dependencies([loss_averages_op]):total_losstf.identity(total_loss)returntotal_lossdefmain(argvNone):withtf.Graph().as_default():model_fnselect_model(FLAGS.model_type)# Open the metadata file and figure out nlabels, and size of epochinput_fileos.path.join(FLAGS.train_dir,md.json)print(input_file)withopen(input_file,r)asf:mdjson.load(f)images,labels,_distorted_inputs(FLAGS.train_dir,FLAGS.batch_size,FLAGS.image_size,FLAGS.num_preprocess_threads)logitsmodel_fn(md[nlabels],images,1-FLAGS.pdrop,True)total_lossloss(logits,labels)train_opoptimizer(FLAGS.optim,FLAGS.eta,total_loss,FLAGS.steps_per_decay,FLAGS.eta_decay_rate)savertf.train.Saver(tf.global_variables())summary_optf.summary.merge_all()sesstf.Session(configtf.ConfigProto(log_device_placementFLAGS.log_device_placement))tf.global_variables_initializer().run(sessionsess)# This is total hackland, it only works to fine-tune iv3ifFLAGS.pre_model:inception_variablestf.get_collection(tf.GraphKeys.VARIABLES,scopeInceptionV3)restorertf.train.Saver(inception_variables)restorer.restore(sess,FLAGS.pre_model)ifFLAGS.pre_checkpoint_path:iftf.gfile.Exists(FLAGS.pre_checkpoint_path)isTrue:print(Trying to restore checkpoint from %s%FLAGS.pre_checkpoint_path)restorertf.train.Saver()tf.train.latest_checkpoint(FLAGS.pre_checkpoint_path)print(%s: Pre-trained model restored from %s%(datetime.now(),FLAGS.pre_checkpoint_path))run_dir%s/run-%d%(FLAGS.train_dir,os.getpid())checkpoint_path%s/%s%(run_dir,FLAGS.checkpoint)iftf.gfile.Exists(run_dir)isFalse:print(Creating %s%run_dir)tf.gfile.MakeDirs(run_dir)tf.train.write_graph(sess.graph_def,run_dir,model.pb,as_textTrue)tf.train.start_queue_runners(sesssess)summary_writertf.summary.FileWriter(run_dir,sess.graph)steps_per_train_epochint(md[train_counts]/FLAGS.batch_size)num_stepsFLAGS.max_stepsifFLAGS.epochs1elseFLAGS.epochs*steps_per_train_epochprint(Requested number of steps [%d]%num_steps)forstepinxrange(num_steps):start_timetime.time()_,loss_valuesess.run([train_op,total_loss])durationtime.time()-start_timeassertnotnp.isnan(loss_value),Model diverged with loss NaNifstep%100:num_examples_per_stepFLAGS.batch_size examples_per_secnum_examples_per_step/duration sec_per_batchfloat(duration)format_str(%s: step %d, loss %.3f (%.1f examples/sec; %.3f sec/batch))print(format_str%(datetime.now(),step,loss_value,examples_per_sec,sec_per_batch))# Loss only actually evaluated every 100 steps?ifstep%1000:summary_strsess.run(summary_op)summary_writer.add_summary(summary_str,step)ifstep%10000or(step1)num_steps:saver.save(sess,checkpoint_path,global_stepstep)if__name____main__:tf.app.run() 项目分享:大家可自取用于参考学习获取方式见文末!

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询