Julia MethodError:没有与ParsenExpr_运行时匹配的方法(

Julia MethodError:没有与ParsenExpr_运行时匹配的方法(,julia,nonlinear-optimization,economics,julia-jump,Julia,Nonlinear Optimization,Economics,Julia Jump,我试图编写所描述的方法来估计金属制造商的生产函数。我已经在Python和Matlab中完成了这项工作,但我试图学习Julia spain_clean.csv是我正在加载的日志资本(lnk)、日志劳动力(lnl)、日志输出(lnva)和日志材料(lnm)的数据集。滞后变量前面用“l”表示 代码位于底部。我收到一个错误: ERROR: LoadError: MethodError: no method matching parseNLExpr_runtime(::JuMP.Model, ::JuMP

我试图编写所描述的方法来估计金属制造商的生产函数。我已经在Python和Matlab中完成了这项工作,但我试图学习Julia

spain_clean.csv是我正在加载的日志资本(lnk)、日志劳动力(lnl)、日志输出(lnva)和日志材料(lnm)的数据集。滞后变量前面用“l”表示

代码位于底部。我收到一个错误:

ERROR: LoadError: MethodError: no method matching parseNLExpr_runtime(::JuMP.Model, ::JuMP.GenericQuadExpr{Float64,JuMP.Variable}, ::Array{ReverseDiffSparse.NodeData,1}, ::Int32, ::Array{Float64,1})
我认为这与非线性目标中向量和和数组的使用有关,但我对Julia的理解还不足以调试它

using JuMP  # Need to say it whenever we use JuMP

using Clp, Ipopt # Loading the GLPK module for using its solver

using CSV # csv reader


# read data
df = CSV.read("spain_clean.csv")


#MODEL CONSTRUCTION
#--------------------

acf = Model(solver=IpoptSolver())



@variable(acf, -10<= b0  <= 10) # 

@variable(acf, -5 <= bk <= 5 ) # 

@variable(acf, -5 <= bl <= 5 ) #

@variable(acf, -10<= g1 <= 10) # 


const g = sum(df[:phihat]-b0-bk* df[:lnk]-bl* df[:lnl]-g1* (df[:lphihat]-b0-bk* df[:llnk]-bl* df[:llnl]))

const gllnk = sum((df[:phihat]-b0-bk* df[:lnk]-bl* df[:lnl]-g1* (df[:lphihat]-b0-bk* df[:llnk]-bl* df[:llnl])).*df[:llnk])

const gllnl = sum((df[:phihat]-b0-bk* df[:lnk]-bl* df[:lnl]-g1* (df[:lphihat]-b0-bk* df[:llnk]-bl* df[:llnl])).*df[:llnl])

const glphihat = sum((df[:phihat]-b0-bk* df[:lnk]-bl* df[:lnl]-g1* (df[:lphihat]-b0-bk* df[:llnk]-bl* df[:llnl])).*df[:lphihat])



#OBJECTIVE  

@NLobjective(acf, Min, g* g + gllnk* gllnk + gllnl* gllnk + glphihat* glphihat)



#SOLVE IT 
status = solve(acf) # solves the model

println("Objective value: ", getobjectivevalue(acf)) #     getObjectiveValue(model_name) gives the optimum objective value

println("b0 = ", getvalue(b0)) 

println("bk = ", getvalue(bk))

println("bl = ", getvalue(bl))

println("g1 = ", getvalue(g1))
使用跳转#无论何时使用跳转都需要说出来
使用Clp,Ipopt#加载GLPK模块以使用其解算器
使用CSV#CSV阅读器
#读取数据
df=CSV.read(“西班牙_clean.CSV”)
#模型构造
#--------------------
acf=模型(解算器=IpoptSolver())

@variable(acf,-10不是Julia方面的专家,但我认为您的代码有两个方面是错误的。 首先,常数不应该在迭代过程中改变,你要使它们成为控制变量的函数。其次,你想用非线性表达式代替常数。所以你想写的不是常数而是

N = size(df, 1)

@NLexpression(acf, g, sum(df[i, :phihat]-b0-bk* df[i, :lnk]-bl* df[i, :lnl]-g1* (df[i, :lphihat]-b0-bk* df[i, :llnk]-bl* df[i, :llnl]) for i=1:N))

@NLexpression(acf, gllnk, sum((df[i,:phihat]-b0-bk* df[i,:lnk]-bl* df[i,:lnl]-g1* (df[i,:lphihat]-b0-bk* df[i,:llnk]-bl* df[i,:llnl]))*df[i,:llnk] for i=1:N))

@NLexpression(acf,gllnl,sum((df[i,:phihat]-b0-bk* df[i,:lnk]-bl* df[i,:lnl]-g1* (df[i,:lphihat]-b0-bk* df[i,:llnk]-bl* df[i,:llnl]))*df[i,:llnl] for i=1:N))

@NLexpression(acf,glphihat,sum((df[i,:phihat]-b0-bk* df[i,:lnk]-bl* df[i,:lnl]-g1* (df[i,:lphihat]-b0-bk* df[i,:llnk]-bl* df[i,:llnl]))*df[i,:lphihat] for i=1:N))
我测试了这个,它似乎有效