人工智能发展历程和工具搭建学习

目录

人工智能的三次浪潮

开发环境介绍

Anaconda

Anaconda的下载和安装

下载说明

安装指导

模块介绍

使用Anaconda Navigator

Home界面介绍

Environment界面介绍

使用Jupter Notebook

打开Jupter Notebook

 配置默认目录

 新建文件

两种输入模式

Conda 虚拟环境

 添加扩展包

运行终端命令

使用内置命令

Tensorflow

命令行安装Tensorflow

图形化界面安装Tensorflow


        本文章将深入探讨人工智能发展历程,逐步延申到学习路径,再到动手搭建深度学习环境,逐渐进入人工智能的开发者世界.

人工智能的三次浪潮

        

        在计算机出现之前,人们就幻想着制造出一种机器,可以实现人类的思维,帮助人们解决问题,甚至比人类有更高的智力。

        1936年图灵的论文《论可计算数及其在判定性问题上的应用》,奠定了计算机科学理论和实践的基础,也把关于机器智能的哲学思考向前推进了一大步。电子数字计算机的出现,为人工智能提供了媒介和基础,系统论、控制论和信息论的发展,进一步推动了人们探索机器智能的热情。

        1950年,图灵在论文《计算机与智能》中提出了“图灵测试”,成为了判断机器是否具备人类智能的准则。

        1956年,在Dartmonth学院召开的夏季研讨会上,人工智能这个词第一次被提了出来,标志着人工智能作为一门新兴学科正式诞生。由于人工智能研究内容的广泛性,因此对人工智能的定义一直存在争议,目前业界比较认可的定义来自人工智能的经典著作《人工智能——一种现代的方法》,在这本书中,将人工智能定义为是能够感知环境,并未获得最佳结果,采取理性行为的智能体。要注意的是,人工智能并不是要复制人类大脑,而是通过探索人的感觉、思维规律来模拟人的智能活动,从而达到对等的结果,他的目标是希望计算机拥有像人一样的智力能力,可以代替人类实现认知、分类和决策等多种功能。人工智能是一门融合了计算机科学、数学、生物学、脑神经科学、心理学和哲学等多种学科的综合性学科。人工智能的发展历程并非是一帆风顺的,可谓一波三折。在人工智能学科诞生之后,很多科学家对人工智能的预测非常的乐观,甚至认为20年内就会出现完全智能的机器。就这样,人工智能迎来了第一次研究热潮。

        在20世纪50年代到60年代,人们认为,如果能够赋予机器逻辑推理的能力,机器就具有智能。在这个阶段的研究处于推理期,核心是逻辑主义,逻辑主义就是用机器证明的方法去证明和推理一些知识,例如用机器证明一个数学定理,要证明这些问题,就需要把原来的条件和定义变成逻辑表达式的形式,然后用逻辑的方法去证明最后的结论是对的还是错的,定理证明是人工智能的第一波浪潮中实现效果最好的。

        1963年数学家罗素的数学名著《数学原理》的第二章中全部52条数学定理被计算机程序自动的证明出来,人工智能达到了第一次研究浪潮的巅峰,在此期间,还出现了第一个自然语言处理程序、第一个人形机器人等等,但是,由于科学家们一开始的预测过于乐观,后续的研究成果和之前人们对人工智能的期望之间产生了巨大的反差,导致公众的热情和投资消减。

        70年代中期,人工智能步入第一次寒冬。人们逐渐认识到人工智能真正的挑战在于去解决那些对人来说很容易执行,但却很难形式化的描述出来的任务,比如聊天、识别图像等等,这时候,人们又想到,人类之所以能够得到正确的判断和决策,除了具有逻辑推理能力之外,还需要有相关的知识。于是,对人工智能的研究开始进入了知识期,诞生了大量的专家系统,例如医学专家系统、工程专家系统等等。在这些系统中,人们将知识整理为计算机能够识别的规则,作为专家知识输入给计算机,计算机根据这些知识进行判断和决策。然而,随着研究的进展,人们发现人类的知识无穷无尽,而有些知识是很难总结之后再去教给计算机的,对于更宽的问题选择和更难的问题,专家系统的效果都不太理想。于是,一些学者设想,是否能够直接给计算机赋予学习知识的能力。

        20世纪80年代,统计机器学习的方法开始出现,机器学习真正开始成为一个独立的学科领域,专家系统的成果和机器学习的兴起,掀起了人工智能的第二波浪潮。

        1982年,日本启动了第5代计算机计划,希望通过大规模的B型计算来构造通用人工智能平台,人们又一次开始对人工智能充满期待,但是由于计算资源和能力的限制,早期机器学习的效果并不是太理想。同时,日本的第5代计算机计划也研究失败,人工智能再次进入寒冬。在经历第二次低谷之后,科学家们更加理智了,在之后的数十年中,统计机器学习的算法逐步开始成为主流。但是,大家降低了对他的期望,不再叫他人工智能,而是利用这些方法来做一些更加实际的东西,例如计算机视觉,语音处理等等。在此期间,神经网络和深度学习的方法也在默默的积累。

        2006年,辛顿教授在nature上发表了一篇论文,指出深层次的人工神经网络具有优异的学习能力,并提出了训练深层神经网络的算法,被认为是人工智能的第三次浪潮的起点。

        2010年之后,深度学习在语音识别、计算机视觉等各个领域迅速取得了重大进展,彻底引爆了人工智能的第三次浪潮,深度学习成为人工智能领域最重要的技术之一,鉴于人工智能这种曲折的发展历程,有人形容计算机是大儿子,人工智能是二儿子。大儿子和二儿子的特点不一样,大儿子比较稳重,有耐心,不调皮,不捣蛋,一直按照摩尔定律的规律持续发展。而二儿子呢,比较活泼,有创新思想,敢于冒险。结果,几十年的发展历程就像是坐过山车一样跌宕起伏。

开发环境介绍

        深度学习是深层次的神经网络,是机器学习中的一个分支。近年来,深度学习犹如一批黑马横空出世,在计算机视觉、语音识别、自然语言处理和机器人等领域取得了惊人的进展,成为目前计算机领域最具有影响力、最热门的研究方向。在本系列文章中,我们将比较全面的介绍神经网络和深度学习的基础知识、理论和方法,并介绍如何编程序、构建神经网络、开发人工智能应用程序。

        本系列文章中的实例采用Python语言和TensorFlow开发框架,实现开发环境选择Anaconda,Python语言是目前最受欢迎的程序设计语言之一,它结构清晰,非常简单易学,拥有丰富的标准库和第三方生态库系统,非常适合作为机器学习算法的编程语言,但是由于Python是一门通用的解释型语言,在实现复杂算法的时候,效率会受到很大的限制。因此,在实际的机器学习和深度学习的项目中,需要使用更高效的实现方法。

        TensorFlow就是谷歌公司推出的一个高效的人工智能开发框架。自从2015年11月发布以来,已经成为全世界最广泛使用的深度学习库。很多以前难以实现的大规模人工智能的任务,都可以通过它来实现,但是对于初学者而言,TensorFlow不太容易学习和掌握,因此这个强大的工具就只能够掌握在少数专业人员的手里,谷歌公司决定改变这一现状,正式宣布在TensorFlow2.0版本中将易用性作为一个重点关注的目标。

        2019年3月,TensorFlow2.0阿尔法版本发布。一经推出就受到广泛的关注,超过13万学生通过网络选修课程在git hub上也获得了近13万颗星,被fork了超过75000次。

        在2019年6月份,TensorFlow2.0Beta版正式发布,标志着TensorFlow进一步的成熟。2.0版本是对之前版本的彻底的革命性的改造,它非常的简单、清晰、好用,并且易于扩展,极大的降低了深度学习编程的门槛,使得大规模人工智能这个强大的武器不再只是被少数精英掌握。现在,更多的人可以参与进来,亲自体验开发人工智能应用程序的乐趣。

        如果说python语言极大的降低了编程的门槛,使得普通人都可以编写出自己想要的程序,那么现在TensorFlow2.0则是极大的降低了人工智能开发的门槛,使得普通人也能够使用人工智能技术解决任务。如果你是刚刚开始接触人工智能领域的小白,那么现在正是开启学习之路的最佳时机。Python虽然易学易用,但是对于新手来说,尤其是对于习惯于使用Windows的用户,往往会头疼于诸多开源包的管理或者是Python版本的管理。为了解决这些问题,出现了不少发行版的Python,他们是对Python的重新包装,将Python和许多常用的工具打包,以方便用户使用。

        本文章中使用的Anaconda就是一个用于科学计算的Python发行版,它不仅预装好了Python,还提供了NumPy、Matplotlib等很多成熟的开源包和科学计算工具,来扩展用户的应用程序,简化编程。同时它提供了强大的包管理和环境管理的功能,通过包管理可以方便的安装、更新、卸载工具包,而且在安装工具包的时候还能够自动的安装相应的依赖包。通过环境管理的功能,可以在同一台机器上创建几个相互独立的Python开发环境,称之为虚拟环境。例如,可以在Anaconda中建立Python2和Python3两个环境,用来分别运行不同版本的Python代码。或者你现在同时在做两个项目,他们所需要用到的工具包有很大的不同,那么就可以分别创建两个虚拟环境,在每个环境中安装各自需要的工具包和依赖项,这样就可以隔离不同项目所需要的不同版本的工具包。而且在不同的环境之间还可以快速的切换。

        为了便于以后的学习,在文章开始前,我们需要先将Anaconda、TensorFlow和其他的一些常用的软件安装在自己的电脑上,下面我将带领大家一起完成这些软件安装。

Anaconda

Anaconda的下载和安装

下载说明

        在安装TensorFlow之前,我们首先进行Anaconda的下载及安装,Anaconda是一个开源的包管理环境管理器,其中不仅包含了Python科学包及其依赖项,而且还提供了包和环境的管理,它支持Windows Mac OS和Linux操作系统,是使用Python进行深度学习和机器学习最简单的工具。

我们可以通过下面两个链接下载到Anaconda的安装文件。

1. Anaconda的官方下载链接。

Anaconda | The Operating System for AI

2. 第二个是清华大学的Anaconda镜像仓库下载链接。

Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

        一般情况下,国内高校学生使用清华大学镜像仓库下载,速度会更快,现在打开的页面是Anaconda的官方网站。点击Free Download, 跳转到程序的下载页面,在这个页面需要注意的是下载安装程序的时候,要根据系统类型位数和Python的版本号进行下载,以本机为例,我们选择Windows操作系统。

        下载Python版本号为3.8的64位安装程序,打开浏览器的下载页面,下载好的安装程序后点击安装程序进行安装。

安装指导

        这个界面选择单一用户或者所有用户都可以,然后点击next,将修改路径修改至任意位置。

        我们一般将程序安装在C盘或者D盘,然后点击next,接下来这个界面有2个可选项,程序默认第一个选项没有被勾选,它的意思是将Anaconda的可执行文件目录添加到系统的环境变量里。为了方便后续我们使用Conda命令,

        我建议勾选这一选项,第二个选项是将Anaconda的Python程序注册为系统Python,默认选中即可,然后点击安装,安装过程较长。根据大家的系统和电脑环境不同。安装的时间长短不一,我们等待安装完成,安装完成后点击next,然后点击finish完成。

模块介绍

        Anaconda Navigator.是一个图形化的用户管理工具,可以在不使用命令的情况下方便的启动应用程序,用于管理conda环境和Python模块包.

        Anaconda Prompt是Anacoda的命令行终端。

        Jupyter Notebook 是基于网页的用于交互计算的应用程序。

        Spyder是一个集成的Python开发环境。

使用Anaconda Navigator

Home界面介绍

        程序的主界面左侧是菜单栏,第一项是主页,主页中间区域显示的是常用的12种工具软件,分别是:

1)Datalore。是一个面向机器学习的云端开发环境,具有收集和探索数据、创建机器学习和深度学习模型、可视化结果并与其他人共享等功能。

2)JupyterLab。是Jupyter的一个扩展,提供了更好的用户体验。例如可以在同一个浏览器页面打开编辑多个notebook、Console和终端,并且支持预览和编辑多种类的文件。

3)Power prompt。是一个较新的命令行终端。

4)Qt console, 一个可执行的Python,终端图形界面程序,相比Python shell ,Qt console可以直接显示代码生成的图形,实现多行代码输入执行,以及内置许多有用的功能和函数。

5)Glue。是一个用于探索相关数据集内部和之间的关系Python库。

6)Orange。是一个交互式数据可视化软件。

7)Pycharm。是Python语言的一种集成开发环境。

8)R Studio是R语言的集成开发环境。

在页面中间的上方,Applications on下面的下拉框可以选择上述工具的运行环境。

Environment界面介绍

        左侧菜单栏当中的第2项,Environment是环境管理,用来管理独立运行环境和其中安装的Python模块包。

        在中间的窗口中, 显示当前系统已经创建的独立运行环境,最右边的窗口中显示对应环境中已经安装好的Python模块包。

刚刚安装的Anaconda会默认只有一个base斯环境,点击base打开终端。

输入conda inform命令,终端会输出当前conda环境的相关信息。

        Anaconda中比较常用的是JupyterNode和Vs code这两个软件,Jupyter notebook在上面已经介绍过。Vs code是一个轻量级但功能强大的源代码编辑工具,支持Windows Mac OS和Linux操作系统,当前版本的Anaconda已经将Vs code当做外部软件,不在内部提供快捷安装,主页中也就没有显示Vs code的,因此我们需要在Vs code的官方网站自行下载安装,下面是下载链接,现在我们打开Vs code的官方网站,我们可以根据系统类型。

使用Jupter Notebook

        Jupter Notebook它的本质是一个可以通过网页访问的web程序,在网页中编写和执行程序。这种环境不仅方便程序员远程访问,而且屏蔽了不同系统之间的显示差异,有益于代码共享。Jupter Notebook 不仅可以编辑运行程序。

        而且可以将程序和文档组织在一起。它可以将代码、图像、注释、公式、图形甚至运行结果都整合在同一个文档中,编写出漂亮的交互式文档,例如,当需要向同行展示或分析程序时,如果使用word等传统的文本编辑工具,代码复制进去后,关键词配色会丢失。而且代码与文字、公式等混在一起,难以区分。Jupter Notebook可以让代码保持在编辑器里的风格,看起来很清晰,并且代码复制进去后是可以运行的。

打开Jupter Notebook

         下面简要介绍一下如何使用Jupter Notebook来编写和管理Python程序。我们有3种方法来打开Jupter Notebook。

第一种方法是打开anaconda navigator可视化管理软件,选择Jupter Notebook启动。

第二种方法就是在命令行窗口中输入jupter Notebook,进入Jupter Notebook界面。

第三种方法就是在开始菜单栏的ANACONDA3文件夹中直接点击Jupter Notebook。

 配置默认目录

打开Jupter Notebook会自动跳转到浏览器中,并且打开Jupter Notebook默认工作目录,初次安装默认目录会存放在C盘用户文件夹下。这种默认设置使用起来非常不便,所以我建议大家使用Jupter Notebook之前,对Jupter Notebook默认目录进行修改。

#生成配置文件。

jupyter Notebook --generate-config

用记事本打开,使用组合键Ctrl+F查找字符串Notebook_dir,定位到该配置文件的键值,取消前面的注释符号。

将等号后面的值更改为你希望的工作目录,比如E盘目录下的jupyter,然后保存,这里需要注意的是,E盘根目录下必须存在该文件夹,没有的话,应该先创建好该目录再修改。

这样做我们只是修改了从anaconda navigator 启动Jupter Notebook的默认路径,接下来我们打开开始菜单栏,右键点击ANACONDA3文件夹中的Jupyter Notebook,选择更多,打开文件夹位置。在打开的窗口中,右键点击Jupyter Notebook,选择属性,删除目标框中的双引号里边的内容,点击确定。

完成操作后,我们不管以何种方式打开Jupter Notebook创建的文件都会保存到我们配置的目录中。

 新建文件

        在Jupyter Notebook主界面中有3个选项卡,分别是files,running,clusters。

        其中files选项卡将显示工作目录下的记事本文件列表,可以选择已有的记事本文件进行编辑或者运行,同时也可以使用files选项卡右上角的new按钮新建一个记事本文件。我们新建一个记事本文件,此时会重新打开一个标签页,会有一个默认名称,Jupyter Notebook记事本界面主要包括名称、菜单栏、工具栏和编辑区等等。

        在名称处输入项目名称为hello world,可以看到页面的标签栏也随之更改为hello word保存后,会在工作目录下生成一个helloword.ipnb文件,并显示在主页面的文件列表中。

        在Jupyter Notebook记事本文件当中,是以cell为基本运行单位的,可以在cell中输入代码,单击运行按钮,或者使用键盘组合键Ctrl + Enter运行程序,运行的结果会显示在该cell的下方。

        默认生成的cell是一个代码类型的Cell,Cell有几种类型,在添加新的cell时,可以选择代码标记或者标题。它们的好处是,我们可以在编写代码的同时,使用标记去为我们的代码添加一些说明或者是注释。

        现在我们在默认cell前面插入一个新cell并将其类型更改为标记模式,标记模式的cell是使用Markdown语法编写的,编写文本的时候也需要使用运行模式去展示Markdown语法的结果,我们点击运行,就可以看到Markdown语法的展示结果。

两种输入模式

        Jupyter Notebook有两种输入模式,分别是编辑模式和命令模式。编辑模式就是我们刚刚介绍的在单元格cell中的操作,它允许我们将代码或文本输入到一个单元格中,并通过左边绿色的单元格显示。

        

        命令模式将键盘与笔记本的命令绑定在一起,并通过左边蓝色的单元格显示,我们打开刚刚创建的hello word文件。当我点击单元格内,我们可以看到,现在单元格的左边框以绿色显示,表示我们处在编辑模式。

        当我点击单元格外部,单元格的边框以蓝色显示,表示我们正处在命令模式。Jupyter Notebook分别提供了这两种模式下的快捷键,这里展示的是两种模式下常用的一些快捷键。

编辑模式

Tab

代码补全或缩进

Shift+Tab

提示

Shift-Enter

运行本单元,选中下一单元

Ctrl-Enter

运行本单元

Alt-Enter

运行本单元,在下面插入一单元

命令模式(Esc键启动)

Shift+Enter

运行本单元,选中下个单元

Ctrl+Enter

运行本单元

Alt+Enter

运行本单元,在其下插入新单元

Y

单元转入代码状态

M

单元转入Markdown状态

A

在上方插入新单元

B

在下方插入新单元

DD

删除除选中的单元

其它快捷命令(编辑模式)

Ctrl+A

全选

Ctrl+Z

撤销

Ctrl+C

复制

Ctrl+W

粘贴

Ctrl+/

注释或取消注释,选中代码可以添加注释或取消

        如果还想了解更多的快捷键,我们可以打开Jupyter Notebook,点击菜单栏的Help选项,在下拉菜单栏中选择keyboard Shortcuts.即可查看命令模式和编辑模式下的所有快捷键。

在这里,我们还可以点击右上角的编辑快捷键按钮,按照自己的习惯修改快捷键。

Conda 虚拟环境

        Conda虚拟环境是一种用于管理Python环境的工具,它允许用户在同一台机器上创建多个独立的Python环境,每个环境都可以拥有自己的Python版本和安装的软件包,互相之间不会产生冲突。这种环境的管理方式有助于避免不同项目之间的依赖冲突,使得每个项目都能在最适合其需求的环境中运行。Conda虚拟环境的创建、激活和管理可以通过使用conda命令来完成,例如使用conda create命令创建一个新的虚拟环境,并指定所需的Python版本号。此外,用户还可以通过conda activate命令来激活特定的虚拟环境,以及使用conda deactivate命令来退出当前激活的虚拟环境。Conda虚拟环境的优点包括能够轻松创建、保存、加载和切换环境,避免版本冲突,提供跨平台支持(Linux, macOS, Windows),并能够管理不同语言的包(如R, Scala等)的包。

        那么如何在Jupyter Notebook中切换不同环境编写代码呢?下面我们介绍一下Jupyter Notebook为我们提供的关联不同环境和包的功能,首先,我们关闭之前打开的Jupyter Notebook,然后打开命令行窗口。

conda install jupyter notebookconda install ipykernelpython -m ipykernel install --user --name 环境名称 --display-name "Python环境名称"

 添加扩展包

        为了Markdown文档更加醒目易读,Jupyter Notebook为Markdown文档提供了扩展包。

conda install -c conda-forge jupyter_contrib_nbextensions
conda install -c conda-forge jupyter_nbextersions_configurator

        首先,我们关闭之前打开的Jupyter Notebook,打开命令行窗口,在命令行窗口中输入以上提供的2条命令,等待命令执行完成,安装完成后重新打开Jupyter Notebook,我们可以看到,菜单栏增加了Notebook extensions选项,我们取消这个选中,然后勾选table of contents.

        随后就可以在Jupyter Notebook中使用markdown编写文档。我们可以点击Table of contents这个按钮显示生成的目录.生成的目录会按照你标题的级别进行生成。

运行终端命令

        在Jupyter Notebook中还可以运行终端命令,也就是命令行命令。我们有两种方法可以执行终端命令。

        第一种方法就是在单元格内输入终端命令,只需要在这条命令的开头添加英文状态下的"!",这条命令是输出Jupyter Notebook的工作目录下,这个目录中的所有文件。

        第二种方法就是使用Jupyter Notebook提供的终端,在Jupyter Notebook的home页面选择files选项卡,进入菜单界面,然后点击new下拉框,选择terminal打开终端,也可以查看当前目录下所有文件。

 

        如果想要关闭终端,我们可以在Jupyter Notebook界面,选择running,然后找到terminals,点击关闭,然后再关闭这个网页。        

使用内置命令

在主Notebook中,读取已经用别的代码编辑器写好的.py文件。

我们首先打开一个Jupyter Notebook文件,在单元格内输入%load和.py文件位置,在这里我的.py文件存储在E盘Jupyter目录下,然后点击运行。

也可在Jupyter Notebook中加载本地的Python文件,并显示在单元格内,可以查看代码,也可以运行这个代码。

在单元格内输入%run和.py文件位置,然后点击运行。

可以直接运行本地的Python文件并输出结果.不会在单元格内显示文件内的代码。

Jupyter Notebook还有很多功能,大家可以在往后的使用中自行探索学习。

Tensorflow

接下来我们开始安装Tensorflow2.4。

命令行安装Tensorflow

现在我先介绍一下在命令行安装Tensorflow2.4的步骤。

# 1.创建独立环境并激活
conda create -n tensorflow2.4 python==3.8
conda activate tensorflow2.4
# 停用环境
conda deactivate
# 2.安装相关软件包
pip install numpy matplotlib Pillow scikit-learn pandas -i https://pypi.tuna.tsinghua.edu.cn/simple
#3.安装Tensorflow2.5
pip install tensorflow==2.4.0 -i https://pypi.tuna.tsinghua.edu.cn/simple
#4.测试Tensorflow2.4
在命令行中输入Python,打开Python交互模式,输入代码:import tensorflow
#5.虚拟机列表
conda env list
#6.删除虚拟机
conda remove -n tensorflow2.4 --all
#7.手动删除虚拟机相关文件

        第一步,我们需要创建独立的运行环境并激活,首先右键点击桌面左下角的开始按钮,在打开的菜单栏中点击运行,或者使用组合键,Windows+R快捷打开运行窗口,在运行窗口的输入框中输入CMD,点击确定,打开命令行窗口.我们可以使用conda create命令创建环境,并指定环境当中的Python版本号,其中tansorflow2.4是我们将要创建的环境的名称,Python3.8是我们指定的Python版本后,等待环境创建完成,这里表示,独立环境已经创建完成。我们使用conda activity Tensorflow2.4激活独立环境,这里表示我们的独立环境已经激活。

        第二步,安装我们以后要用到的Python模块包。这里介绍两种安装方式。一种是采用conda,一种是采用pip。这里我比较推荐使用pip方法进行安装。使用Conda进行安装的过程当中,会因为版本的依赖问题导致部分包的版本被修改,给后续的安装造成麻烦,复制这里的pip命令到命令行窗口,等待相关软件包安装完成,这里表示相关软件包已经安装完成。

        第三步,安装Tensorflow 2.4。我们使用piip install Tensorflow==2.4.0指定Tensorflow的版本号进行安装。在安装的过程当中,特别要注意版本号不能有误, 有错误会导致安装失败,复制pip这条命令到命令行窗口,等待Tensorflow2.4安装完成,。

 

第四步,我们对tansorflow2.4进行简单的测试,我们打开当前激活环境的命令窗口,输入Python,打开Python的交互模式,然后输入import Tensorflow.,如果没有错误,说明安装成功,输入exit(),退出Python交互模式。 

 以上是在命令行中安装Tensorflow2.4的基本步骤.

图形化界面安装Tensorflow

        如果不习惯在命令行中进行操作,那么也可以使用anaconda navigator所提供的图形化界面,以可视化的形式安装Tensorflow,打开anaconda navigator,切换到环境管理页面。

        在这个页面,您可以看到当前只有一个base环境,这是anaconda默认的环境,我们将在这个管理界面可视化的创建Tensorflow2.4独立的Python环境,在创建环境的过程当中,会涉及到一些Python模块包的下载,所以我们需要对Conda的Python模块包语言进行修改,以便下载的过程当中效率更高,我们打开清华大学镜像仓库anaconda | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror,看到Conda的使用指南,根据网页上的提示,Windows用户无法直接创建conda配置文件,我们需要先执行Conda命令,生成配置文件之后再修改。

conda config --set show_channel_urls yes

复制这条命令到命令行窗口执行,完成以后,我们在命令行窗口显示的路径下面找到该文件

channels:- defaults
show_channel_urls: true
default_channels:- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/r- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/msys2
custom_channels:conda-forge: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudmsys2: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudbioconda: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudmenpo: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudpytorch: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudpytorch-lts: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloudsimpleitk: https://mirrors.tuna.tsinghua.edu.cn/anaconda/clouddeepmodeling: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud/

用记事本打开,将anaconda使用指南给出的参数复制到该文件中保存。

完成操作后,我们回到anaconda navigator环境管理界面。点击环境列表下方的create按钮。创建新的独立运行环境。环境名称为Tensorflow2.4,由于输入框中无法输入点,所以我们用-代替.Python版本选择3.8,

然后点击create

        在屏幕下方的滚动条消失后,在环境列表处,会出现我们刚刚创建的新环境Tensorflow2.4。

        然后我们点击Tensorflow2.42.4环境名称右侧的绿三角

        打开命令行窗口,接下来的操作就和命令行窗口的操作一样了。

        打开命令行窗口以后,我们使用提供的pip命令,安装相应的Python模块包

        安装完成后,我们使用pip命令安装Tensorflow2.4,安装完成以后,我们在命令行窗口中输入Python,进入Python交互模式,输入import tensorflow,如果没有错误,就说明安装成功,到这里我们就完成了Tensorflow2.4的安装。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/26790.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

路虽远,行则将至 - 附暑期实习、秋招历程经验分享

前言 大家好 许久没有时间静下心来打开编辑器写文章了 忙碌暂过,难得一闲时 求学三年,终到离别时 回忆过往,枯燥且多彩 有一点经验,以文字形式分享,希望帮助到大家 可能是这段时间事多且杂,加上很长一…

电脑桌面上用来记事的便签软件

便签软件已成为我们日常生活中不可或缺的记录工具。想象一下,在繁忙的工作中,你突然需要记下一个重要事项或临时想法,这时,一个便捷、高效的便签软件就显得尤为重要。它能帮助我们迅速捕捉信息,轻松管理琐碎事务&#…

通信设备的网卡

一、网卡的作用 将计算机或者路由器连接到传输介质上的接口,传输介质可以是有线也可以是无线的。 (1)计算机的网卡 现在的计算机大多有两个网卡,一个是有线网卡一个无线网卡,比如以我们的台式电脑为例 台式电脑千兆网…

【氵】Archlinux+KDE Plasma 6+Wayland 安装nvidia驱动 / 开启HDR

参考: NVIDIA - Arch Linux 中文维基 (其实就是把 wiki 简化了一下 注:本教程适用 GeForce 930 起、10 系至 20 系、 Quadro / Tesla / Tegra K-系列以及更新的显卡(NV110 以及更新的显卡家族),此处以 RTX3060 为例 …

Pytorch--Convolution Layers

文章目录 1.nn.Conv1d2.torch.nn.Conv2d()3.torch.nn.ConvTranspose1d()3.torch.nn.ConvTranspose2d() 1.nn.Conv1d torch.nn.Conv1d() 是 PyTorch 中用于定义一维卷积层的类。一维卷积层常用于处理时间序列数据或具有一维结构的数据。 构造函数 torch.nn.Conv1d() 的语法如…

vector迭代器失效

1.迭代器失效的根本原因 迭代器就是指针,迭代器失效就是指针失效。 指针失效的有两种情况: 1)野指针 2)访问越界 2.举例阐述 这段代码已经报错了,我给大家调试一下。可以发现:vector的容量变大了&…

C语言之main函数的返回值(在linux中执行shell脚本并且获取返回值)

一:函数为什么要返回值 (1)函数 在设计的时候是设计了参数和返回值,参数是函数的输入,返回值是函数的输出 (2)因为函数需要对外输出数据(实际上是函数运行的一些结果值)…

springbot 界面美观的超市收银管理系统。

springbot 界面美观的超市收银管理系统。 功能:登录,用户管理,权限菜单管理,首页订单,收入,用户统计, 收银台,销售账单,库存管理,商品分类,供应…

30 岁的程序员,要有 “归零“ 心态

大家好,我是码农先森。 古话说的 “三十而立”,正是担重之时,却大部分人在职场中都处于不上不下的尴尬境地。已经没有刚毕业时那股子冲劲,被生活和工作磨平了棱角。 在技术思想方面,似乎已经触及到了天花板&#xff…

嵌入式系统中判断大小端的方法与实现

第一:大小端基本分析 程序判断计算机是大端的还是小端的,判断的思路是确定一个多字节的值(下面使用的是4字节的整数),将其写入内存(即赋值给一个变量),然后用指针取其首地址所对应的字节(即低地址的一个字节),判断该字…

shell循环以及实验

循环是一种重复执行的代码结构,只要满足循环的条件,会一直执行这个代码 循环条件:在一定范围之内,按照指定次数来执行循环。 循环体:在指定的次数内,执行的命令序列,只要条件满足,…

C#知识|模块化分层学习笔记

哈喽,你好,我是雷工! 01 基本分层 典型的两层结构:由UI层 数据访问层 实体类构成。 其中实体类不算一层,本质是一个数据载体。 02 模块化分层 模块概念:在.NET平台中,模块主要是指类库项目。…

Mac下载了docker,在终端使用docker命令时用不了

问题:在mac使用docker的时候,拉取docker镜像失败 原因:docker是需要用app使用的 ,所以在使用的时候必须打开这个桌面端软件才可以在终端上使用docker命令!!!

Spring系统学习 -Spring IOC 的XML管理Bean之P命名空间、实现引入MySQL外部链接属性文件

P命名空间 在Spring框架中&#xff0c;P命名空间是一种用于简化XML配置文件中属性注入的方式。通过引入P命名空间&#xff0c;可以使用更简洁的语法来设置bean的属性值&#xff0c;而无需显式地使用<property>子元素。这使得XML配置文件更加简洁和易于阅读。 要在Sprin…

shell条件测试和if语句

“C:\Users\Jessica\Desktop\6.12.assets\image-20240612094159578.png”# shell条件测试和if语句 一、条件测试 1、$? 返回码 判断命令或者脚本是否执行成功&#xff08;最近的一条&#xff09; 0 true 为真就是成功 成立 非0 false 失败或者异常 2、test命令 可以进行…

「OC」UI练习(二)——照片墙

「OC」UI练习——照片墙 文章目录 「OC」UI练习——照片墙UITapGestureRecognizer介绍照片墙实现 UITapGestureRecognizer介绍 UITapGestureRecognizer是UIKit框架中的一个手势识别器类&#xff0c;用于检测用户在视图上的轻击手势。它是UIGestureRecognizer的一个子类&#x…

ROS2读源码过程中涉及到的核心点梳理解读

流控 watchdog 过滤 如何把writer跟reader匹配 依赖topic&#xff1f;QOS? datashared 如何配置 安全 何时持久化 域隔离&#xff1f; 只有在同一个域内的通信实体才能通信&#xff0c;不同域内的实体间无法进行通信 架构设计细节、扩展性&#xff1f; 代码为什么难读…

源代码防泄密经验分享之安全上网篇

场景描述&#xff1a; 随着信息技术的发展&#xff0c;越来越多的新技术产品进入到政府、军事、科研等涉密单位。这些新技术产品在给工作人员带来便利的同时&#xff0c;也给信息安全保密工作带来了许多新的不容忽视的安全隐患&#xff0c;应引起高度重视。常规的内外网隔离手…

Vue29-自定义指令:函数式

一、定义 内置指令&#xff0c;指令是vue作者定的&#xff0c;背后的操作DOM的逻辑是也是vue作者写的。 自定义指令&#xff0c;指令名自定义&#xff0c;指令背后如何去操作DOM元素&#xff0c;也是自定义。 二、需求1&#xff1a;big指令 2-1、自定义指令directive 1、写法…

美摄科技匿名化处理解决方案,包含模糊、同色、马赛克、效果遮挡等各种形式

信息安全已成为企业发展中不可忽视的重要一环&#xff0c;随着信息安全法规的日益严格和公众对个人隐私保护意识的不断提高&#xff0c;企业如何在保障业务顺畅进行的同时&#xff0c;满足信息安全和隐私保护的要求&#xff0c;成为了亟待解决的问题。美摄科技凭借其强大的技术…