Python-Tensorflow学习笔记

placeholder——占位(2.0以上版本需要加这行)

import tensorflow.compat.v1 as tf
tf.disable_v2_behavior()

tf.softmax函数——使各项相加之和为1
tf.sigmoid函数——二分类
tf.reduce函数——把作为它参数的向量或矩阵中方所有维度值相加求和

random函数——随机生成在[0, 1)之间的数

#产生新的随机数种子
random.seed()
#10倍即产生[0, 10)范围的数,int操作取整,41+60就是取大于[60,101)的整数
print(int(random.random() * 10))
print(int(random.random() * 41 + 60))

np.full函数生成一个形态为(a, b)的数组,其中fill_value=c是用c先预填充这个数组。

例子:
编程解决下述非线性问题:
输入数据:[1, 1, 1],输出目标值:2
输入数据:[1, 0, 1],输出目标值:1
输入数据:[1, 2, 3],输出目标值:3

代码如下:

import numpy as np
import tensorflow.compat.v1 as tf
tf.disable_v2_behavior()


xData = np.array([[1, 1, 1],
                 [1, 0, 1],
                 [1, 2, 3]])
yTrainData = np.array([2, 1, 3])
x = tf.placeholder(shape=[3], dtype=tf.float32)
yTrain = tf.placeholder(dtype=tf.float32)
w = tf.Variable(tf.zeros([3]), dtype=tf.float32)
b = tf.Variable(1, dtype=tf.float32)

n1 = x * w
n2 = tf.reduce_sum(n1) - b
y = n2
loss = tf.abs(y - yTrain)
optimizer = tf.train.RMSPropOptimizer(0.01)
train = optimizer.minimize(loss)
sess = tf.Session()
sess.run(tf.global_variables_initializer())
for i in range(1000):
    for j in range(3):
        result = sess.run([train, x, yTrain, w, b, n2, loss], feed_dict={x: xData[j], yTrain: yTrainData[j]})
        print(result)

运行结果:
在这里插入图片描述
实际上这个问题是个非线性方程组问题,对初学者来说,被书里面二分类非线性问题迷惑了就容易一头扎错了方向。

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值