变量

变量是VQNet中的一种数据类型,用于存储特定混合量子经典网络的变量。 通常任务是优化变量以最小化成本函数。 变量可以是标量,矢量或矩阵。

变量具有树形结构,它可以包含孩子节点或父节点。 如果变量没有子节点,那么我们称之为叶子节点。 我们可以将变量设置为特定值,另一方面,如果变量的所有叶子节点都已设置了值,我们也可以获得该变量的值。

接口介绍

class var
var(std::shared_ptr<impl> data)
功能

构造函数。通过数据的指针进行构造。

参数
  • data 数据指针

var(double data)
功能

构造函数。通过浮点型的数据构造一个标量变量。

参数
  • data 标量数据

var(const MatrixXd &data)
功能

构造函数。通过 Eigen 库中的 MatrixXd 类型数据的构造一个矢量或矩阵变量。

参数
  • data 矢量或矩阵数据

var(double data, bool isDifferentiable)
功能

构造函数。构造一个是否可微分的变量,如果isDifferentiable为false,则该变量作用类似placeholder。

参数
  • data 标量数据

  • isDifferentiable 是否可以微分

var(const MatrixXd &data, bool isDifferentiable)
功能

构造函数。构造一个是否可微分的变量,如果isDifferentiable为false,则该变量作用类似placeholder。

参数
  • data 矢量或矩阵数据

  • isDifferentiable 是否可以微分

var(op_type op, const std::vector<var> &children)
功能

构造函数。通过操作及其孩子变量进行构造。例如:c = a + b,c是a和b的父变量,a和b是c的孩子变量。

参数
  • op 操作符类型

  • childen 操作符的孩子变量

var clone()
功能

克隆。

参数

返回值

当前变量的副本。

virtual size_t getNumOpArgs()
功能

获取当前操作的参数个数。

参数

返回值

操作的参数个数。

MatrixXd getValue() const
功能

获取变量的值。

参数

返回值

变量的值。

void setValue(const MatrixXd &data)
功能

设置变量的值。

参数
  • data 矩阵类型的数据

返回值

op_type getOp() const
功能

获取变量对应的操作类型。

参数

返回值

操作类型。

void setOp(op_type op)
功能

设置变量的操作类型。

参数
  • op 操作类型

返回值

std::vector<var> &getChildren() const
功能

获取当前变量的孩子变量。

参数

返回值

当前变量的孩子变量。

std::vector<var> getParents() const
功能

获取当前变量的父亲变量。

参数

返回值

当前变量的父亲变量。

long getUseCount() const
功能

获取变量被引用的次数。

参数

返回值

引用次数。

bool getValueType() const
功能

获取变量被引用的次数。

参数

返回值

引用次数。

MatrixXd _eval()
功能

根据孩子变量的数值以及当前的操作计算当前变量的值。

参数

返回值

MatrixXd 类型的值,如果是标量,返回的是1x1的矩阵。

MatrixXd _back_single(const MatrixXd &dx, size_t op_idx)
功能

求当前变量对索引值为op_idx孩子节点的偏导值。

参数
  • dx 链式法则中上一层函数(外层函数)的偏导值

  • op_idx 孩子结点的索引

返回值

当前变量对索引值为op_idx孩子节点的偏导值。

std::vector<MatrixXd> _back(const MatrixXd &dx, const std::unordered_set<var> &nonconsts)
功能

求当前变量对非常量孩子节点的偏导值。

参数
  • dx 链式法则中上一层函数(外层函数)的偏导值

  • nonconsts 非常量孩子节点

返回值

当前变量非常量孩子节点的偏导值。

std::vector<MatrixXd> _back(const MatrixXd &dx)
功能

求当前变量对所有孩子节点的偏导值。

参数
  • dx 链式法则中上一层函数(外层函数)的偏导值

返回值

当前变量对所有孩子节点的偏导值。

const var operator[](int subscript)
功能

创建一个下标操作的变量。

参数
  • subscript 下标

返回值

新的变量。

实例

#include "Variational/var.h"

int main()
{
    using namespace QPanda::Variational;

    var const_var(1);

    MatrixXd m1(2, 2);
    m1 << 1, 2, 3, 4;

    MatrixXd m2(2, 2);
    m2 << 5, 6, 7, 8;

    var var1(m1);
    var var2(m2);

    var sum = var1 + var2;
    var minus(op_type::minus, {var2, var1});
    var multiply = var1 * var2;

    MatrixXd dx = MatrixXd::Ones(2, 2);

    std::cout << "const_var: " << std::endl << const_var.getValue() << std::endl;
    std::cout << "var1: " << std::endl << var1.getValue() << std::endl;
    std::cout << "var2: " << std::endl << var2.getValue() << std::endl;
    std::cout << "sum: "  << std::endl << sum._eval() << std::endl;
    std::cout << "    op_type: " << int(sum.getOp()) << std::endl;
    std::cout << "    NumOpArgs: " << int(sum.getNumOpArgs()) << std::endl;
    std::cout << "minus: "  << std::endl << minus._eval() << std::endl;
    std::cout << "    op_type: " << int(minus.getOp()) << std::endl;
    std::cout << "    NumOpArgs: " << int(minus.getNumOpArgs()) << std::endl;
    std::cout << "multiply: "  << std::endl << multiply._eval() << std::endl;
    std::cout << "    op_type: " << int(multiply.getOp()) << std::endl;
    std::cout << "    NumOpArgs: " << int(multiply.getNumOpArgs()) << std::endl;
    std::cout << "Derivative multipy to var1:" <<std::endl<< multiply._back_single(dx, 0)<<std::endl;
    std::cout << "Derivative multipy to var2:" <<std::endl<< multiply._back_single(dx, 1)<<std::endl;


    MatrixXd m3(2, 2);
    m3 << 4, 3, 2, 1;
    var1.setValue(m3);

    std::cout << "sum: "  << std::endl << sum._eval() << std::endl;
    std::cout << "minus: "  << std::endl << minus._eval() << std::endl;
    std::cout << "multiply: "  << std::endl << multiply._eval() << std::endl;
    std::cout << "matrix_var1 UseCount: " << var1.getUseCount() << std::endl;

    return 0;
}
15.VQNET/images/VarExample.png