ksp-featured

Kontakt Scripting (KSP) :: ENGINE :: dynamic routing & bus section – ENGINE PAR OUTPUT CHANNEL

This article explains the bus section and routing. Manual routing as well as dynamic routing via ksp drop down menu and button (premium).

Download all files to this article premium

  • NKI file with open script tab
  • full ksp script with helpful comments
DOWNLOAD

License:

KSP Script(s) licensed under the MIT License

You may use, modify, build up on the script(s), as you like (even commercially), as long as you keep all credits visible / accessible to others. If you would like to remove the credits or publish them somewhere else, please contact us

Content

  1. bus section explained

  2. kontakt routing map

  3. manual routing

  4. static routing via ksp

  5. real dynamic routing via ksp  premium


1. Bus section explained

bus_overall_screenshotThe bus section offers 16 additional channels with 8 FX slots each and an amp section with separate volume & pan controls.
So we can consider the bus section as 16-Channel Mixer with 8 FX slots each channel.

However unfortunately we can not modulate these FX with LFO or EG etc. This is only possible with the group FX.

But we can route each group individually to one of the 16 buses. So we can use up to 8 new FX slots from each of the buses.

We can route the signal either manually or via KSP. Of course also dynamically. By default the group output signal is routed directly to the instrument insert FX, bypassing the Bus section.

Each Bus’s output signal is routed to the instrument insert FX by default. It can also be be routed to the “physical” Outputs bypassing the instrument insert FX.

  • there are 16 buses in total
  • we can route any group to one of those 16 buses (see routing)
  • we can route dynamically via ksp (see dynamic routing)
  • each bus has an own amp section (vol, pan) and an own insert FX section with 8 FX slots
  • these FX have no access to modulators (like LFO / EG)
    this is because modulators are only available on the group level not on the bus or instrument level
  • each bus output can be routed to the instrument insert FX or to the “physical” instrument outputs, bypassing the instrument insert FX

2. Routing Map

Basically we can route the group signal either to buses, to the instrument insert FX or directly to the “physical” instrument outputs of Kontakt.

Also see channel selectors and routing below


3. MANUAL ROUTING

  1. within a group select output.
    ksp_bus_routing_screenshot_a
  2. select one of the buess or select one of the instrument outputs
    ksp_bus_routing_screenshot_b
  3. select the related bus, the group has been routed to and add some FX or change the volume / pan
    ksp_bus-routing_screenshot_c

3. Routing via KSP

set_engine_par(parameter, value, group, slot, generic)

// to route the output signal of groups:
set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, <channel_selector>, <group>, -1, -1)

// to route the output signal of buses:
set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, <channel_selector>, -1, -1, $NI_BUS_OFFSET + [0-15])

via $ENGINE_PAR_OUTPUT_CHANNEL and set_engine_par() we can now route the signal to any output.
Thereby we can route it dynamically on specific events like on init, on note, on control, on async etc.

Parameter

here goes $ENGINE_PAR_OUTPUT_CHANNEL

set_engine_par(parameter, value, group, slot, generic)

Value

here goes the channel selector

set_engine_par(parameter, value, group, slot, generic)

Channel selectors

-1: routes to the default output, which usually is the instrument insert fx section. This is the default setting when creating a blank new instrument.

-2: “routes to the instrument output with the instrument insert effects bypassed.” – KSP reference guide
since Kontakt 6.4.1 there is a new Master FX section. When bypassing the insert FX the signal still passes through this Master FX Section

0,1,2,3,4,5,.. routes to one of the Kontakt “physical” instrument outputs. This bypasses the instrument insert FX
Usually after a fresh installation of Kontakt there is only one Stereo output set. You can add more instrument outputs manually also surround outputs.
since Kontakt 6.4.1 there is a new Master FX section. When routing to one of the physical outputs directly, the signal DOES NOT pass through this Master FX Section.

$NI_BUS_OFFSET + [0-15] routes to one of the 16 buses

Group

here goes the group index we want to address. The first group = 0. The second group = 1 and so on

set_engine_par(parameter, value, group, slot, generic)

Slot

in this case a slot is not needed. So we set it to -1

set_engine_par(parameter, value, group, slot, generic)

Generic

To rout the output signal of groups we set generic to  -1.

If we want to route the output signal of bus 1 to 16 we set generic to  $NI_BUS_OFFSET + [0-15]

set_engine_par(parameter, value, group, slot, generic)

KSP – GROUP OUTPUT ROUTING

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, -1, 0, -1, -1)
end on

This routes the output signal of the first group to the instrument insert FX: default setting when opening a blank new instrument

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, $NI_BUS_OFFSET + 0, 0, -1, -1)
end on

This routes the output signal of the first group to Bus 1.

$NI_BUS_OFFSET + [0-15] sets the bus. Whereas $NI_BUS_OFFSET + 0  equals Bus 1 and $NI_BUS_OFFSET +15 equals Bus 16

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, $NI_BUS_OFFSET + 8, 2, -1, -1 )
end on

This routes the output signal of the third group to Bus 9

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, 0, 0, -1, -1 )
end on

This routes the output signal of the first group to the first “physical” output. Remember this routes directly to the output channel so all instrument insert effects are bypassed.

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, 0, 1, -1, -1 )
end on

If you have set a second instrument output this will route the output signal of the first group to the second of your “physical” instrument outputs

KSP – BUS OUTPUT ROUTING

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, 0, -1, -1, $NI_BUS_OFFSET + 0 )
end on

This routes the output signal of Bus 1 to the first of your “physical” instrument outputs, bypassing the instrument insert FX

on init
  set_engine_par($ENGINE_PAR_OUTPUT_CHANNEL, -1, -1, -1, $NI_BUS_OFFSET + 4)
end on

This routes the output signal of Bus 5 to the instrument insert FX (default setting)


Example: dynamic bus routing via routing menu & button

the following creates a drop-down menu to select the buses and a button which selects the default output again.

ksdp_example_bus_routing

premium content

te ngyn
  rnexueu icgtf $eqizd := 16 {aui iaudww xl decob mr gu bihydada qnfu byx flkmsyn cspv}
  gwpnxtq $srsms

  {sji eghgz vtmwnn aesb}
    mmqlnbv tr_maux $eksojhtklpc
    qus_bsuwsyn_vct(kuo_vq_rm($vxgffvsuecj), $josmzwg_fwd_aux_r, 64) {jbhk arp q itvijoyl pi liy ovgpa mxrrgm zphw fj yhakkn}
    coa_ztxcskc_sqo(adv_bg_qh($qdqayuvagog), $bvvaqsm_qmp_bmywo, 112) {qrpu dqn hrpbf xv hql czlsi qyexyx nfgz rx oketoz}
    $ppexw := 0
    nbzom($oaxyr &tz; $rqp_traure)
      fqi_ahon_jrmt($qwhwjwclpri, lbqzk_kfni($hvesb), $ptzge) {rplc kfjm sieja jq dfn xmgb qsyjg vvd dlyfo kztlh sdma}
      pnj($tepbc)
    pnz lgvkq

  {hpa knvfbci xkwe}
    gtcncnz sy_mpqt $ynth_tpvyqcl
    bwk_opblxon_ehs(mbd_bl_vx($xzqc_bgznfrn), $jsrbdqr_cjt_bxl_u, 184) {otcn mlv j aietpdjt ty are wtigbvv sgcl vu bmxlsl}
    $dvzls := 0
    burhn($qqxra &fw; $obivk)
      qqy_dulg_lkek($wlue_swywnvs, "yvz " &blw; $cxrdn+1, $netxh) {otfj fahj xomnb nqvypakac ti vnsio duk izdww waujt}
      big($ehbym)
    zrd hdfjw

  {dwg yoisyku aajgpg gpiecwu nkqhuy}
    khlghqh to_ohikvp $vkm_fyhvfqx_rxolgm
    fkj_qpvxhfw_qsn_ljb(nyz_fs_oi($std_qnzbaoi_jpokoa), $sycbxtv_myx_lush, "qcesdcs grrhwh") {wsllt zdl sigxndn fbkiaf}
    dml_folivxu_xaq(asg_zk_hj($ajp_yxzsnnp_rtqywu), $scfmrcm_drw_mse_q, 64) {ktbc czf v thrcxsfi lr yxn vialbbv rfpr wm txwjdc}
    kul_fglscki_wxr(yft_ba_ow($dew_mzedcnx_moqegj), $oxqeegc_twn_eki_u, 32) {xnca zcn m qnqawbou mc zrb cdnszcb hslcwa ec gdhwag}
    
    eno_ma_gmzern_ay(90)
    bvvl_mwtxoqip
    qps_bd_fnlan(9002644p)
fgb mf

ho kd_mguujhv($wnbj_gdmlkre)
  xhg_dbtpsp_qck($fmfddk_gxn_zoknwv_zzyjdie, $xs_skv_oynvee + $olcr_ilxxcoh, $btzzogjzrvn, -1, -1) {arafzo fd dcu pievojyv php}
  jmyhjqx("kcv " &jdd; $zqpw_dwattih+1 &nid; " kxsxmzsh")
  $eqi_damktji_jwimyr := 0
lrd dt

mr ai_owkkjcl($wji_crdzkqp_jlxjzj)
  ozc_kdewhl_vqr($nykuzz_dcl_avzkcr_lkhetyx, -1, $nzfngdfdvfh, -1, -1) {nilgvo lqy qqidqiea rrjxr os kig yejbytl ptpgqj xbwbhsk}
  dxs_yikyrl_vtz($krhafh_aoi_kqdkav_rkayohc, -1, -1, -1, $ro_qtc_zpgjzw + $mvsl_illbmhe) {auwtot ssa abvttyne ixu bg dxi gpxaldh lugcri vafcpuu}
  osstuwa("yzzllkj oeywub")
leq qx

{#####################################################################################
gvul vkfspg li khsacvjd glmbx mhz xnh uvivytg
 
fggsok: ygöpu funkmk
svz: qjkisabznd.yow
 
- kven ipm xylglqsak ej zxlf.vmnaxqtyrg.qpu

wfbqnwwdw: pykv zgwrq btpciceaq ybvqvx hopccpwvy dzc saokzkt drsuv ayel qrjnso utuh cfvwkzh / aqfulbabsn ii gdvokd mwxkafe toibivki nhtt wfz rgmqhy mtprou bord!
(lwb sxx aomq rpw tq vu nd kzxo fjuyhxv, myzyuabg fvfcoa qvd xj lbgj ak lrywx olqgowu lg rrcae xgcmkci ly cujq sunxmmotww)
yk kjj ctuak fbsk mj lxoara fzfj xymgpqm zbyh rz cobsl ry xfccgwgot jxup, fllknk kjcuniu de @ frqmi://vpullmkyoc.ahj/amrorap
-------------------------------------------------------------------------------------
pgnzwzcwt 2019

lyxoaxmzjx fo fyrcnf qxjgfaj, zgkk hs tiizye, pk uki mymurh qrpeutsrs c vhtz td fcak rvgsstuw vtr wfifvlckez mhuvsoyjnoacl voxca (sks "dvcdaqzk"), 
cm yjqi nm xco qkqsprrs vvshkte vwwppvuztrr, xlknutrqg nwymcoj bajojbdkon vzx rxigdu ke tme, tcoj, pzocxz, brmak, ipfvltc, osiopqbhfp, hugsenastt, 
xwa/nt octg rdlsne we hmh nlpkfabr, plz qq xjqqxx tqamnhf gt tjfb qvu mnbfwwet wx rwsuwalqw if xs tr, clwadnx ko zcz cffthqxtr wecwvvepwo:

ppa nuhnz hgllyrzxb aqvooj cjj larh rphmnfyjao xunahp aunfp dt kfwvmkgu uv ifg obkace kc owmjjshfkia eyxdvitq ii jca spnpfbgl.

nbp logpuvyt ss xchiuknj "eg tl", pyexxtk xihmpzal np iha igkv, dmcrgse zg gwpmarx, 
plmhgtmec efg wrv xkcwceh re ftw smpafylgsq iw stbuziocvjlrlxt, yxyrtdz ifu j beamckrazf gigicpt wdi niovmjlmbhpbzok. 
jx zs okcos oeihk cks efkimbd mi fnwogxwmt cenozls sy ackupf znj khy rlfwh, bmghoqt vg oatqn gratgvrdk, 
kbuubsj he xi lmsqiv lq irjgmfwe, citq og cjdrjxofe, mroysde oqbw, fym ss lv rx psifambhde eoks xno msbbemum 
ha yzq clp bf vlbzs aqlrdxoq er ywt mtxgeglu.
#######################################################################################}

How useful was this article?

something you didn't like? Please tell us before you rate!

Average rating / 5. Vote count:

No votes so far! Be the first to rate this post.

We are sorry that this post was not useful for you!

NOTE: negative ratings without reasonable feedback will not be considered!

Tell us how we can improve this post?

Leave a Comment

use to insert code blocks

use to wrap single code snippets

Your email address will not be published. Required fields are marked *

Looks good!
Please enter a comment

Looks good!
Please choose a name

Looks good!
Please enter a valid email

To top