|
|
@@ -0,0 +1,511 @@ |
|
|
|
{{template "base/head" .}} |
|
|
|
<style> |
|
|
|
|
|
|
|
.unite{ |
|
|
|
font-family: SourceHanSansSC-medium !important; |
|
|
|
color: rgba(16, 16, 16, 100) !important; |
|
|
|
} |
|
|
|
|
|
|
|
.title{ |
|
|
|
font-size: 16px !important; |
|
|
|
padding-left: 3rem !important; |
|
|
|
} |
|
|
|
.min_title{ |
|
|
|
font-size: 14px !important; |
|
|
|
padding-left: 6rem !important; |
|
|
|
margin-bottom: 2rem !important; |
|
|
|
|
|
|
|
} |
|
|
|
.width{ |
|
|
|
width:100% !important; |
|
|
|
} |
|
|
|
.width80{ |
|
|
|
width: 80.7% !important; |
|
|
|
margin-left: 10px; |
|
|
|
} |
|
|
|
.width85{ |
|
|
|
width: 85% !important; |
|
|
|
margin-left: 4.5rem !important; |
|
|
|
} |
|
|
|
.width81{ |
|
|
|
margin-left: 1.5rem; |
|
|
|
width: 81% !important; |
|
|
|
} |
|
|
|
|
|
|
|
.add{font-size: 18px; |
|
|
|
padding: 0.5rem; |
|
|
|
border: 1px solid rgba(187, 187, 187, 100); |
|
|
|
border-radius: 0px 5px 5px 0px; |
|
|
|
line-height: 21px; |
|
|
|
text-align: center; |
|
|
|
color: #C2C7CC; |
|
|
|
} |
|
|
|
.min{ |
|
|
|
font-size: 18px; |
|
|
|
padding: 0.5rem; |
|
|
|
border: 1px solid rgba(187, 187, 187, 100); |
|
|
|
border-radius: 5px 0px 0px 5px; |
|
|
|
line-height: 21px; |
|
|
|
text-align: center; |
|
|
|
color: #C2C7CC; |
|
|
|
} |
|
|
|
|
|
|
|
</style> |
|
|
|
<!-- <div class="ui page dimmer"> |
|
|
|
<div class="ui text loader">{{.i18n.Tr "loading"}}</div> |
|
|
|
</div> --> |
|
|
|
<div id="mask"> |
|
|
|
<div id="loadingPage"> |
|
|
|
<div class="rect1"></div> |
|
|
|
<div class="rect2"></div> |
|
|
|
<div class="rect3"></div> |
|
|
|
<div class="rect4"></div> |
|
|
|
<div class="rect5"></div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="repository"> |
|
|
|
{{template "repo/header" .}} |
|
|
|
<div class="ui container"> |
|
|
|
{{template "base/alert" .}} |
|
|
|
<h4 class="ui top attached header"> |
|
|
|
{{.i18n.Tr "repo.modelarts.train_job.new"}} |
|
|
|
</h4> |
|
|
|
<div class="ui attached segment"> |
|
|
|
<!-- equal width --> |
|
|
|
<form class="ui form" action="{{.Link}}" method="post"> |
|
|
|
{{.CsrfTokenHtml}} |
|
|
|
<input type="hidden" name="action" value="update"> |
|
|
|
<input type="hidden" id="ai_engine_name" name="engine_names" value=""> |
|
|
|
<input type="hidden" id="ai_flaver_name" name="flaver_names" value=""> |
|
|
|
<h4 class="unite title ui header ">{{.i18n.Tr "repo.modelarts.train_job.basic_info"}}:</h4> |
|
|
|
<div class="required unite min_title inline field"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.job_name"}}</label> |
|
|
|
<input style="width: 60%;" name="job_name" id="trainjob_job_name" placeholder={{.i18n.Tr "repo.modelarts.train_job.job_name"}} value="{{.job_name}}" tabindex="3" autofocus required maxlength="254"> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="unite min_title inline field"> |
|
|
|
<label style="font-weight: normal;" for="description">{{.i18n.Tr "repo.modelarts.train_job.description"}} </label> |
|
|
|
<textarea style="width: 80%;" id="description" name="description" rows="3" maxlength="254" placeholder={{.i18n.Tr "repo.modelarts.train_job.new_place"}} onchange="this.value=this.value.substring(0, 255)" onkeydown="this.value=this.value.substring(0, 255)" onkeyup="this.value=this.value.substring(0, 255)"></textarea> |
|
|
|
</div> |
|
|
|
<div class="ui divider"></div> |
|
|
|
|
|
|
|
<h4 class="unite title ui header ">{{.i18n.Tr "repo.modelarts.train_job.parameter_setting"}}:</h4> |
|
|
|
|
|
|
|
|
|
|
|
<div class="required unite min_title inline field"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.code_version"}}</label> |
|
|
|
<select class="ui dropdown width80 left2" id="code_version" name="branch_name"> |
|
|
|
{{if .branch_name}} |
|
|
|
<option name="branch_name" value="{{.branch_name}}">{{.branch_name}}</option> |
|
|
|
{{range $k, $v :=.Branches}} |
|
|
|
{{ if ne $v $.branch_name }} |
|
|
|
<option name="branch_name" value="{{$v}}">{{$v}}</option> |
|
|
|
{{end}} |
|
|
|
{{end}} |
|
|
|
{{else}} |
|
|
|
<option name="branch_name" value="{{.branchName}}">{{.branchName}}</option> |
|
|
|
{{range $k, $v :=.Branches}} |
|
|
|
{{ if ne $v $.branchName }} |
|
|
|
<option name="branch_name" value="{{$v}}">{{$v}}</option> |
|
|
|
{{end}} |
|
|
|
{{end}} |
|
|
|
{{end}} |
|
|
|
|
|
|
|
</select> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<div class="required unite min_title inline fields" style="width: 90%;"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.AI_driver"}} </label> |
|
|
|
<div class="field" style="flex: 1.5;"> |
|
|
|
<select class="ui dropdown width" id="trainjob_engines" > |
|
|
|
{{range .engines}} |
|
|
|
<option value="{{.Value}}">{{.Value}}</option> |
|
|
|
{{end}} |
|
|
|
</select> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="field" style="flex: 2;" id="engine_name"> |
|
|
|
<select class="ui dropdown width" id="trainjob_engine_versions" style='width: 100%;' name="engine_id"> |
|
|
|
{{range .engine_versions}} |
|
|
|
<option name="engine_id" value="{{.ID}}">{{.Value}}</option> |
|
|
|
{{end}} |
|
|
|
</select> |
|
|
|
|
|
|
|
</div> |
|
|
|
|
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="inline unite min_title field required"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.start_file"}}</label> |
|
|
|
{{if .bootFile}} |
|
|
|
<input style="width: 33.5%;" name="boot_file" id="trainjob_boot_file" value="{{.bootFile}}" tabindex="3" autofocus required maxlength="254" > |
|
|
|
{{else}} |
|
|
|
<input style="width: 33.5%;" name="boot_file" id="trainjob_boot_file" value="" tabindex="3" autofocus required maxlength="254" > |
|
|
|
{{end}} |
|
|
|
<span> |
|
|
|
<i class="question circle icon link" data-content={{.i18n.Tr "repo.modelarts.train_job.boot_file_helper"}} data-position="right center" data-variation="mini"></i> |
|
|
|
</span> |
|
|
|
<a href="https://git.openi.org.cn/OpenIOSSG/MINIST_Example" target="_blank">查看样例</a> |
|
|
|
</div> |
|
|
|
<div class="required unite min_title inline field"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.dataset"}}</label> |
|
|
|
<select class="ui dropdown width80" id="trainjob_datasets" name="attachment" placeholder="选择数据集"> |
|
|
|
{{if $.uuid}} |
|
|
|
<option name="attachment" value="{{$.uuid}}">{{$.datasetName}}</option> |
|
|
|
{{end}} |
|
|
|
{{range .attachments}} |
|
|
|
<option value="">选择数据集</option> |
|
|
|
<option name="attachment" value="{{.UUID}}">{{.Attachment.Name}}</option> |
|
|
|
{{end}} |
|
|
|
</select> |
|
|
|
<span class="tooltips">数据集位置存储在环境变量data_url中,训练输出路径存储在环境变量train_url中。</span> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="inline unite min_title field"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.run_parameter"}}</label> |
|
|
|
<span id="add_run_para" style="margin-left: 0.5rem;cursor:pointer;color: rgba(3, 102, 214, 100);font-size: 14px;line-height: 26px;font-family: SourceHanSansSC-medium;"><i class="plus square outline icon"></i>{{.i18n.Tr "repo.modelarts.train_job.add_run_parameter"}}</span> |
|
|
|
<input id="store_run_para" type="hidden" name="run_para_list"> |
|
|
|
<div class="dynamic field" style="margin-top: 1rem;"> |
|
|
|
{{if ne 0 (len .params)}} |
|
|
|
{{range $k ,$v := .params}} |
|
|
|
<div class="two fields width85" id="para{{$k}}"> |
|
|
|
<div class="field"> |
|
|
|
<input type="text" name="shipping_first-name" value={{$v.Label}} required> |
|
|
|
</div> |
|
|
|
<div class="field"> |
|
|
|
<input type="text" name="shipping_last-name" value={{$v.Value}} required> |
|
|
|
</div> |
|
|
|
<span> |
|
|
|
<i class="trash icon"></i> |
|
|
|
</span> |
|
|
|
|
|
|
|
</div> |
|
|
|
{{end}} |
|
|
|
{{end}} |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
<div class="required field " style="display: none;"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.resource_pool"}}</label> |
|
|
|
<select class="ui dropdown" id="trainjob_resource_pool" style='width:385px' name="pool_id"> |
|
|
|
{{range .resource_pools}} |
|
|
|
<option value="{{.ID}}">{{.Value}}</option> |
|
|
|
{{end}} |
|
|
|
</select> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="required grouped fields" style="display: none;"> |
|
|
|
<label style="font-weight: normal;" for="resource_type">{{.i18n.Tr "repo.modelarts.train_job.resource_type"}}</label> |
|
|
|
<div class="field"> |
|
|
|
<div class="ui grid"> |
|
|
|
<div class="column"> |
|
|
|
<div class="ui radio checkbox"> |
|
|
|
<input type="radio" name="resource_type" checked="" tabindex="0"> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="three wide column">train-private-1</div> |
|
|
|
<div class="three wide column">{{svg "octicon-verified" 16}} 运行中</div> |
|
|
|
<div class="three wide column"> CPU:192 核 2048GiB</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="required unite min_title inline field" id="flaver_name"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.standard"}}</label> |
|
|
|
<select class="ui dropdown width81" id="trainjob-flavor" style='width:385px' name="flavor"> |
|
|
|
{{range .flavor_infos}} |
|
|
|
<option name="flavor" value="{{.Code}}">{{.Value}}</option> |
|
|
|
{{end}} |
|
|
|
</select> |
|
|
|
</div> |
|
|
|
<div class="inline required unite min_title field"> |
|
|
|
<label style="font-weight: normal;">{{.i18n.Tr "repo.modelarts.train_job.amount_of_compute_node"}}</label> |
|
|
|
|
|
|
|
<div class="ui labeled input" style="width: 5%;"> |
|
|
|
|
|
|
|
<input style="border-radius: 0;text-align: center;" name="work_server_number" id="trainjob_work_server_num" tabindex="3" autofocus required maxlength="254" value="1" readonly> |
|
|
|
|
|
|
|
|
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
<div class="inline unite min_title field"> |
|
|
|
<button class="ui create_train_job green button"> |
|
|
|
{{.i18n.Tr "repo.cloudbrain.new"}} |
|
|
|
</button> |
|
|
|
<a class="ui button" href="/">{{.i18n.Tr "repo.cloudbrain.cancel"}}</a> |
|
|
|
</div> |
|
|
|
|
|
|
|
<!-- 模态框 --> |
|
|
|
|
|
|
|
</form> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
{{template "base/footer" .}} |
|
|
|
|
|
|
|
<script> |
|
|
|
let url_href = window.location.pathname.split('create')[0] |
|
|
|
$(".ui.button").attr('href',url_href) |
|
|
|
$('select.dropdown') |
|
|
|
.dropdown(); |
|
|
|
|
|
|
|
$('.menu .item') |
|
|
|
.tab(); |
|
|
|
|
|
|
|
let sever_num = $('#trainjob_work_server_num') |
|
|
|
$('.add').click(function(){ |
|
|
|
sever_num.val(parseInt(sever_num.val())+1) |
|
|
|
if(sever_num.val()>=26){ |
|
|
|
sever_num.val(parseInt(sever_num.val())-1) |
|
|
|
} |
|
|
|
}) |
|
|
|
$('.min').click(function(){ |
|
|
|
sever_num.val(parseInt(sever_num.val())-1) |
|
|
|
if(sever_num.val()<=0){ |
|
|
|
sever_num.val(parseInt(sever_num.val())+1) |
|
|
|
} |
|
|
|
}) |
|
|
|
// 参数增加、删除、修改、保存 |
|
|
|
function Add_parameter(i){ |
|
|
|
value = '<div class="two fields width85" id= "para'+ i +'">' + |
|
|
|
'<div class="field">' + |
|
|
|
'<input type="text" name="shipping_first-name" required placeholder={{.i18n.Tr "repo.modelarts.train_job.parameter_name"}}> ' + |
|
|
|
'</div> ' + |
|
|
|
'<div class="field"> ' + |
|
|
|
'<input type="text" name="shipping_last-name" required placeholder={{.i18n.Tr "repo.modelarts.train_job.parameter_value"}}>' + |
|
|
|
'</div>'+ |
|
|
|
'<span>' + |
|
|
|
'<i class="trash icon">' + |
|
|
|
'</i>' + |
|
|
|
'</span>' + |
|
|
|
'</div>' |
|
|
|
$(".dynamic.field").append(value) |
|
|
|
} |
|
|
|
|
|
|
|
$('#add_run_para').click(function(){ |
|
|
|
var len = $(".dynamic.field .two.fields").length |
|
|
|
Add_parameter(len) |
|
|
|
}); |
|
|
|
|
|
|
|
$(".dynamic.field").on("click",".trash.icon", function() { |
|
|
|
var index = $(this).parent().parent().index() |
|
|
|
$(this).parent().parent().remove() |
|
|
|
var len = $(".dynamic.field .two.fields").length |
|
|
|
$(".dynamic.field .two.fields").each(function(){ |
|
|
|
var cur_index = $(this).index() |
|
|
|
$(this).attr('id', 'para' + cur_index) |
|
|
|
}) |
|
|
|
}); |
|
|
|
|
|
|
|
$('.ui.parameter.green.button').click(function(){ |
|
|
|
var parameters = []; |
|
|
|
$('table tr').each(function() { |
|
|
|
$(this).find('td:eq(1)').each(function(){ |
|
|
|
parameters.push($(this).text()); |
|
|
|
}) |
|
|
|
$(this).find('input').each(function(){ |
|
|
|
parameters.push($(this).text()) |
|
|
|
}) |
|
|
|
|
|
|
|
}); |
|
|
|
console.log(parameters) |
|
|
|
$('.ui.parameter.modal') |
|
|
|
.modal('hide'); |
|
|
|
for(var i = 2; i < parameters.length; i++){ |
|
|
|
switch(i) { |
|
|
|
// 数据集uuid待完成 |
|
|
|
// case (2): |
|
|
|
// console.log(1) |
|
|
|
// break; |
|
|
|
// $("#trainjob_datasets").val(parameters[i]); |
|
|
|
// console.log($("#trainjob_datasets").val()) |
|
|
|
case (3): |
|
|
|
$("input[name='boot_file']").val(parameters[i]); |
|
|
|
break; |
|
|
|
case (4): |
|
|
|
var para = parameters[i].split(" ") |
|
|
|
for(var j = 0; j < para.length; j++){ |
|
|
|
var para_name = para[j].split('=')[0] |
|
|
|
var para_value = para[j].split('=')[1] |
|
|
|
var len = $(".dynamic.field .two.fields").length |
|
|
|
Add_parameter(len) |
|
|
|
var pid = 'para' + len |
|
|
|
$(".dynamic.field"+ " #" + pid + "").find("input[name=shipping_first-name]").val(para_name) |
|
|
|
$(".dynamic.field"+ " #" + pid + "").find("input[name=shipping_last-name]").val(para_value) |
|
|
|
} |
|
|
|
break; |
|
|
|
// 数据集pool_id待完成 |
|
|
|
// case (5): |
|
|
|
// $("select[name='pool_id']").val(parameters[i]); |
|
|
|
// break; |
|
|
|
case (6): |
|
|
|
$("input[name='work_server_number']").val(parameters[i]); |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
}) |
|
|
|
|
|
|
|
$('.ui.save.checkbox').click(function(){ |
|
|
|
$(this).checkbox({ |
|
|
|
onChange: function(){ |
|
|
|
if ($('.ui.save.checkbox').checkbox('is checked')){ |
|
|
|
$('#save_para').removeClass("disabled") |
|
|
|
|
|
|
|
}else{ |
|
|
|
$('#save_para').addClass("disabled") |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}) |
|
|
|
|
|
|
|
$('.question.circle.icon').hover(function(){ |
|
|
|
$(this).popup('show') |
|
|
|
}); |
|
|
|
|
|
|
|
$(".item.active.parameter_config").click(function(){ |
|
|
|
$('.ui.parameter.modal') |
|
|
|
.modal('setting', 'closable', false) |
|
|
|
.modal('show'); |
|
|
|
}) |
|
|
|
|
|
|
|
$('.ui.deny.button').click(function(){ |
|
|
|
$('.ui.parameter.modal') |
|
|
|
.modal('hide'); |
|
|
|
}) |
|
|
|
$('select.dropdown') |
|
|
|
.dropdown(); |
|
|
|
|
|
|
|
$('.ui.form') |
|
|
|
.form({ |
|
|
|
on: 'blur', |
|
|
|
inline:true, |
|
|
|
fields: { |
|
|
|
boot_file: { |
|
|
|
identifier : 'boot_file', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'regExp[/.+\.py$/g]', |
|
|
|
prompt : '启动文件必须为.py结尾' |
|
|
|
} |
|
|
|
] |
|
|
|
}, |
|
|
|
job_name:{ |
|
|
|
identifier : 'job_name', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'regExp[/^[a-zA-Z0-9-_]{1,36}$/]', |
|
|
|
prompt : '只包含大小写字母、数字、_和-,最长36个字符。' |
|
|
|
} |
|
|
|
] |
|
|
|
}, |
|
|
|
attachment:{ |
|
|
|
identifier : 'attachment', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'empty', |
|
|
|
prompt : '选择一个数据集' |
|
|
|
} |
|
|
|
] |
|
|
|
|
|
|
|
}, |
|
|
|
work_server_number: { |
|
|
|
identifier : 'work_server_number', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type : 'integer[1..25]', |
|
|
|
prompt : '计算节点需要在1-25之间,请您键入正确的值' |
|
|
|
} |
|
|
|
] |
|
|
|
} |
|
|
|
}, |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function validate(){ |
|
|
|
$('.ui.form') |
|
|
|
.form({ |
|
|
|
on: 'blur', |
|
|
|
inline:true, |
|
|
|
fields: { |
|
|
|
boot_file: { |
|
|
|
identifier : 'boot_file', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'regExp[/.+\.py$/g]', |
|
|
|
prompt : '启动文件必须为.py结尾' |
|
|
|
} |
|
|
|
] |
|
|
|
}, |
|
|
|
job_name:{ |
|
|
|
identifier : 'job_name', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'regExp[/^[a-zA-Z0-9-_]{1,36}$/]', |
|
|
|
prompt : '只包含大小写字母、数字、_和-,最长36个字符。' |
|
|
|
} |
|
|
|
] |
|
|
|
}, |
|
|
|
attachment:{ |
|
|
|
identifier : 'attachment', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type: 'empty', |
|
|
|
prompt : '选择一个数据集' |
|
|
|
} |
|
|
|
] |
|
|
|
|
|
|
|
}, |
|
|
|
work_server_number: { |
|
|
|
identifier : 'work_server_number', |
|
|
|
rules: [ |
|
|
|
{ |
|
|
|
type : 'integer[1..25]', |
|
|
|
prompt : '计算节点需要在1-25之间,请您键入正确的值' |
|
|
|
} |
|
|
|
] |
|
|
|
} |
|
|
|
}, |
|
|
|
onSuccess: function(){ |
|
|
|
// $('.ui.page.dimmer').dimmer('show') |
|
|
|
document.getElementById("mask").style.display = "block" |
|
|
|
}, |
|
|
|
onFailure: function(e){ |
|
|
|
return false; |
|
|
|
} |
|
|
|
}) |
|
|
|
} |
|
|
|
document.onreadystatechange = function() { |
|
|
|
if (document.readyState === "complete") { |
|
|
|
document.getElementById("mask").style.display = "none" |
|
|
|
} |
|
|
|
} |
|
|
|
function send_run_para(){ |
|
|
|
var run_parameters = [] |
|
|
|
var msg = {} |
|
|
|
$(".dynamic.field .two.fields").each(function(){ |
|
|
|
var para_name = $(this).find('input[name=shipping_first-name]').val() |
|
|
|
var para_value = $(this).find('input[name=shipping_last-name]').val() |
|
|
|
run_parameters.push({"label": para_name, "value": para_value}) |
|
|
|
}) |
|
|
|
msg["parameter"] = run_parameters |
|
|
|
msg = JSON.stringify(msg) |
|
|
|
$('#store_run_para').val(msg) |
|
|
|
} |
|
|
|
function get_name(){ |
|
|
|
let name1=$("#engine_name .text").text() |
|
|
|
let name2=$("#flaver_name .text").text() |
|
|
|
$("input#ai_engine_name").val(name1) |
|
|
|
$("input#ai_flaver_name").val(name2) |
|
|
|
|
|
|
|
} |
|
|
|
$('.ui.create_train_job.green.button').click(function(e) { |
|
|
|
get_name() |
|
|
|
send_run_para() |
|
|
|
validate() |
|
|
|
}) |
|
|
|
</script> |