我试图在TensorFlow中创建一个简单的神经网络.唯一棘手的部分是我有一个我实现的自定义操作py_func.当我将输出传递py_func给Dense图层时,TensorFlow会抱怨应该知道等级.具体错误是:
ValueError: Inputs to `Dense` should have known rank.
Run Code Online (Sandbox Code Playgroud)
当我通过它时,我不知道如何保留我的数据的形状py_func.我的问题是如何获得正确的形状?我在下面有一个简单的例子来说明问题.
def my_func(x):
return np.sinh(x).astype('float32')
inp = tf.convert_to_tensor(np.arange(5))
y = tf.py_func(my_func, [inp], tf.float32, False)
with tf.Session() as sess:
with sess.as_default():
print(inp.shape)
print(inp.eval())
print(y.shape)
print(y.eval())
Run Code Online (Sandbox Code Playgroud)
此代码段的输出是:
(5,)
[0 1 2 3 4]
<unknown>
[ 0.
1.17520118 3.62686038 10.01787472 27.28991699]
Run Code Online (Sandbox Code Playgroud)
为什么y.shape <unknown>?我希望形状与之(5,)相同inp.谢谢!
IPython 中的制表符补全实际上无法使用,因为文本很难阅读。
这是我尝试过的:
ipython profile create。ipython_config.py我设定中c.InteractiveShell.colors = 'NoColors'。这使我的所有文本变成白色,但完成文本没有改变。我正在使用以下软件:
我有一个使用基本身份验证进行身份验证的 Flask-SocketIO 应用程序。我试图确保我的所有套接字通信也受到保护,至少达到与基本身份验证相同的程度。
\n\n来自 Flask-SocketIO 有关身份验证的文档:
\n\n\n\n\n然而,大多数情况下,在建立 SocketIO 连接之前执行传统的身份验证过程更为方便。然后可以将 user\xe2\x80\x99s 身份记录在用户会话或 cookie 中,稍后当建立 SocketIO 连接时,SocketIO 事件处理程序将可以访问该信息。
\n
因此,我试图弄清楚如何通过用户会话来安全地存储某些内容。假设我执行以下操作,首先登录,我签署了哈希用户名和密码:
\n\nfrom flask import session\nfrom itsdangerous import Signer\n\nsigner = Signer(\'super secret key\')\ndef login(username: str, password: str):\n if (username, password) in credentials:\n hashed = hash(username + password)\n session[\'user\'] = s.sign(hashed)\nRun Code Online (Sandbox Code Playgroud)\n\n然后我可以为我的 socketio 侦听器创建一个装饰器,它只需检查会话中的签名值是否有效:
\n\ndef authenticated_only(f):\n @functools.wraps(f)\n def wrapped(*args, **kwargs):\n try:\n signer.unsign(session[\'user\'])\n return f(*args, **kwargs)\n except BadSignature:\n disconnect()\n return wrapped\n\n@socketio.on(\'my event\')\n@authenticated_only\ndef handle_my_custom_event(data):\n pass\nRun Code Online (Sandbox Code Playgroud)\n\n这是一个合理的做法吗?有我遗漏的陷阱吗?这是没有意义的,因为我正在使用基本身份验证?
\n