• Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
MagicMirror Forum
  • Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
A New Chapter for MagicMirror: The Community Takes the Lead
Read the statement by Michael Teeuw here.

MMM-AssistantMk2

Scheduled Pinned Locked Moved System
421 Posts 61 Posters 453.9k Views 57 Watching
Loading More Posts
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • B Offline
    bachoo786 @Davido
    last edited by Mar 11, 2019, 9:11 PM

    @Davido I am using raspberry pi 3b+

    D 1 Reply Last reply Mar 12, 2019, 6:04 PM Reply Quote 0
    • D Offline
      Davido @bachoo786
      last edited by Mar 12, 2019, 6:04 PM

      @bachoo786 :

      i am using a normal rPi 3B without + and the answering time is really fast … maybe some other Module which is interacting?

      B 2 Replies Last reply Mar 12, 2019, 7:12 PM Reply Quote 0
      • B Offline
        bachoo786 @Davido
        last edited by Mar 12, 2019, 7:12 PM

        @Davido nope nothing is interacting with my assistantmk2 module.

        1 Reply Last reply Reply Quote 0
        • B Offline
          bachoo786 @Davido
          last edited by Mar 14, 2019, 9:59 PM

          @Davido can you share your config for both mmm-assistant and mmm-hotword please?

          D 1 Reply Last reply Mar 15, 2019, 12:37 PM Reply Quote 0
          • D Offline
            Davido @bachoo786
            last edited by Mar 15, 2019, 12:37 PM

            @bachoo786

            I hope this will help

            {
              module: "MMM-AssistantMk2",
              position: "top_right",
              config: {
            
                // --- ESSENTIALS / modifying for your environment might be needed.
            
            
                deviceLocation: {
                  coordinates: { // set the latitude and longitude of the device to get localized information like weather or time. (ref. mygeoposition.com)
                    latitude: 47.809490, // -90.0 - +90.0
                    longitude: 13.055010, // -180.0 - +180.0
                  },
                },
            
                defaultProfile: "default", // If you have several profiles and want to set one of them as default profile, describe here.
            
                profiles: {
                  "default" : { // profile name.
                    profileFile: "default.json", // profile file name.
                    lang: "de-DE"
                    //currently available (estimation, not all tested):
                    //  de-DE, en-AU, en-CA, en-GB, en-US, en-IN
                    // fr-CA, fr-FR, it-IT, ja-JP, es-ES, es-MX, ko-KR, pt-BR
                    // https://developers.google.com/assistant/sdk/reference/rpc/languages
                  },
                  /* Add your other profiles here, if exists.
                  "other_profile" : {
                    profileFile: "other.json",
                    lang: "de-DE"
                  }
                  */
                },
            
                record: { // Full values are in `FOR EXPERTS` section.
                  recordProgram: "arecord",  // Defaults to "arecord" - also supports "rec" and "sox"
                  device: null        // recording device (e.g.: "plughw:1")
                },
            
                play: { // Full values are in `FOR EXPERTS` section.
                  playProgram: "mpg321", // recommended.
                },
            
            
                // --- OPTIONAL / not important but customizable for your usage
            
            
                responseVoice: true, // If available, Assistant will response with her voice.
                responseScreen: true, // If available, Assistant will response with some rendered HTML
                responseAlert: true, // If available, Assistant will response with Alert module of MM
                // Sometimes, any response might not be returned. responseAlert is useful for displaying error.
            
                screenZoom: "80%", // Adjust responseScreen to your mirror size.
                screenDuration: 2000, // milliseconds. How long responseScreen will be shown after speech.
                //If you set 0, Screen Output will be closed after Response speech finishes ASAP.
            
                youtubeAutoplay: true, //If set as true, found Youtube video will be played automatically.
                pauseOnYoutube:true, //If set as true, You cannot activate Assistant during youtube playing. Recommended for the performance (Because permanent hotword detecting might make performance lower)
            
                useWelcomeMessage: "", //Try "brief today" as this value. You can use this value to check module working when MM is starting.
            
                onIdle: {
                  timer: 1000*60*30, // if you don't want to use this feature, just set timer as `0` or command as ""
                  command: "HIDEMODULES"
                },
            
                onActivate: {
                  timer: 0,
                  command: "SHOWMODULES"
                },
            
            
                // --- FOR EXPERTS / For development, debug or more
            
            
                verbose:false, // You can get error or some logs when this value is set as true.
            
                startChime: "connection.mp3", // you can use `mp3` to play chime when your mic is ready. It should be playable with your `play.playProgram`
                noChimeOnSay: false, // When using the `ASSISTANT_SAY` trigger, you can prevent the chime from being played before your words
            
                auth: { // I believe you don't need to change this.
                  keyFilePath: "./credentials.json"
                },
            
                record:  { // Full version
                  sampleRate    : 16000,      // audio sample rate
                  threshold     : 0.5,        // silence threshold (rec only)
                  thresholdStart: null,       // silence threshold to start recording, overrides threshold (rec only)
                  thresholdEnd  : null,       // silence threshold to end recording, overrides threshold (rec only)
                  silence       : 1.0,        // seconds of silence before ending
                  verbose       : false,      // log info to the console
                  recordProgram : "arecord",  // Defaults to "arecord" - also supports "rec" and "sox"
                  device        : null        // recording device (e.g.: "plughw:1")
                },
            
                play: { // Full version
                  encodingOut: "MP3", //'MP3' or 'WAV' is available, but you might not need to modify this.
                  sampleRateOut: 24000,
                  playProgram: "mpg321", //Your prefer sound play program. By example, if you are running this on OSX, `afplay` could be available.
                  playOption: [],
                  // If you need additional options to use playProgram, describe here. (except filename)
                  // e.g: ["-d", "", "-t", "100"]
                },
            
                useGactionCLI: false, // If set as true, you can update your gAction when MM is rebooted.
                projectId: "", // Google Assistant ProjectId (Required only when you use gAction.)
                deviceModelId: "", // It should be described in your config.json. In most of case, you don't need to this.
                deviceInstanceId: "", // It should be described in your config.json. In most of case, you don't need to this.
            
                action:{}, // You can catch your gAction command.
            
                transcriptionHook: {}, // You can catch transcription hook and be able to make your own `COMMAND` with this.
                //See the `transcriptionHook` section.
            
                command: {}, // You can make your own MM command for gAction and transcriptionHook
                //See the `command` section.
                record: {
                    recordProgram : "arecord",  
                    device        : "plughw:1",
                  },
            
                  notifications: {
                    ASSISTANT_ACTIVATED: "HOTWORD_PAUSE",
                    ASSISTANT_DEACTIVATED: "HOTWORD_RESUME",
                  },
            	
                notifications: { // You can redefine these notifications to communicate with specific modules.
                  ASSISTANT_ACTIVATE: "ASSISTANT_ACTIVATE",
                  ASSISTANT_DEACTIVATE: "ASSISTANT_CLEAR",
                  ASSISTANT_ACTIVATED: "ASSISTANT_ACTIVATED",
                  ASSISTANT_DEACTIVATED: "ASSISTANT_DEACTIVATED",
                  ASSISTANT_ACTION: "ASSISTANT_ACTION",
                  ASSISTANT_ACTIVATED: "HOTWORD_PAUSE",     
                  ASSISTANT_DEACTIVATED: "HOTWORD_RESUME",      
                  DEFAULT_HOOK_NOTIFICATION: "ASSISTANT_HOOK",
                  TEXT_QUERY: "ASSISTANT_QUERY",
                  SAY_TEXT: "ASSISTANT_SAY",
                }
              }
            },
             {
                module: "MMM-Hotword",
                config: {
                  snowboy: [
              {
                hotwords: "smartmirror", //this will be sent to other module for distinguishing which hotword is detected.
                file: "resources/models/smart_mirror.umdl",
                sensitivity: '0.5',
              },
              {
                hotwords: "snowboy",
                file: "resources/models/snowboy.umdl",
                sensitivity: '0.5',
              },
              {
                file: 'resources/models/jarvis.umdl',
                sensitivity: '0.8,0.80',
                hotwords: ['jarvis','jarvis'] //Kitt.ai changed their Jarvis UMDL, it has 2 models in one file. So weird.
                //anyway, you can give different name for each. ['jarvis_1', 'jarvis_2']. Even though I think this is useless.
              }
                ],
                record: {
                  sampleRate    : 16000,      // audio sample rate
                  threshold     : 0.5,        // silence threshold (rec only)
                  thresholdStart: null,       // silence threshold to start recording, overrides threshold (rec only)
                  thresholdEnd  : null,       // silence threshold to end recording, overrides threshold (rec only)
                  silence       : 1.0,        // seconds of silence before ending
                  verbose       : false,      // log info to the console. Use this when you want to check mic working or not.
                  recordProgram : 'arecord',  // Defaults to 'arecord' - also supports 'rec' and 'sox'
                  device        : null        // recording device (e.g.: 'plughw:1')
                },
                autostart: true,              // if 'false', this module will wait for 'HOTWORD_RESUME' notification to start hotwords detection at the beginning.
                autorestart: false,          // You can set this 'true' when you want this module to go back to listening mode automatically again after hotword is detected. But use this carefully when your other modules are using microphone or speaker.
            
                // customizable notification trigger
                notifications: {
                  PAUSE: "HOTWORD_PAUSE",
                  RESUME: "HOTWORD_RESUME",
                  LISTENING : "HOTWORD_LISTENING",
                  SLEEPING : "HOTWORD_SLEEPING",
                  ERROR : "HOTWORD_ERROR",
                },
                onDetected: {
                  notification: (payload) => {
                    return "HOTWORD_DETECTED"
                  },
                  payload: (payload) => {
                    return payload
                  }
                },
            	  record: {
                    recordProgram : "arecord",  
                    device        : "plughw:1",
                  },
                  autostart:true,
                  onDetected: {
                    notification: function (payload) {
                      return "ASSISTANT_ACTIVATE"
                    },
                    payload: function (payload){
                      return {
                        profile: payload.hotword
                      }
                    }
                  },
                },
              },
            	
            
            B 1 Reply Last reply Mar 15, 2019, 2:52 PM Reply Quote 0
            • B Offline
              bachoo786 @Davido
              last edited by Mar 15, 2019, 2:52 PM

              @Davido thank you

              1 Reply Last reply Reply Quote 0
              • ? Offline
                A Former User
                last edited by A Former User Mar 26, 2019, 10:18 AM Mar 26, 2019, 10:15 AM

                UPDATED

                [2.1.4] - 2019.03.26

                • Added : Now you can use recipes. https://github.com/eouia/MMM-AssistantMk2/wiki/Usage#recipes

                  recipe is an external js file containing definitions of command, transcriptionHook and action. Your configuration could be more shorter.

                recipes:["hide_and_show_all_modules.js", "reboot.js", "screen_onoff.js", "shutdown.js"],
                

                Feel free to request PR to share your recipes to others.

                • Changed : onIdle, onDetected features are disabled by default.
                1 Reply Last reply Reply Quote 2
                • B Offline
                  bryan_1
                  last edited by Apr 1, 2019, 11:04 AM

                  @Sean
                  sorry for my bad English. I use the default recipes and set the language to German for all pattern (“spiegel reboot”, “monitor aus”, etc). Every thing works fine, only the “SHOWMODULES” doesn’t work. Although the hotword is correctly detected, but nothing happens. I set the pattern for SHOWMODULE to pattern: “alle module”,

                  This is also the same case if I use the OnIdle and OnActivate:
                  onIdle: {
                  timer: 10006020,
                  command: “HIDEMODULES”,
                  },
                  onActivate: {
                  timer: 0,
                  command: “SHOWMODULES”,
                  },

                  I can hide the modules, but after the hotword for SHOWMODULES being recognized the modules aren’t shown again. What do I wrong? Many thanks in advance.

                  ? 1 Reply Last reply Apr 1, 2019, 11:22 AM Reply Quote 0
                  • ? Offline
                    A Former User @bryan_1
                    last edited by Apr 1, 2019, 11:22 AM

                    @bryan_1
                    Can you show me the recipe(command and transcriptionHook or gAction) about SHOWMODULES?

                    B 1 Reply Last reply Apr 1, 2019, 11:40 AM Reply Quote 0
                    • B Offline
                      bryan_1 @Guest
                      last edited by Apr 1, 2019, 11:40 AM

                      @Sean
                      thank you sean for your quick response. Actually I use the default hide_and_show_all_modules.js and change the pattern to german:
                      var recipe = {
                      transcriptionHook: {
                      “HIDE_ALL_MODULES”: {
                      pattern: “alle verstecken”,
                      command: “HIDEMODULES”
                      },
                      “SHOW_ALL_MODULES”: {
                      pattern: “alle module”,
                      command: “SHOWMODULES”
                      },
                      },
                      command: {
                      “HIDEMODULES”: {
                      moduleExec: {
                      module:()=>{
                      return []
                      },
                      exec: (module, params, key) => {
                      module.hide(1000, null, {lockString:“AMK2”})
                      }
                      }
                      },
                      “SHOWMODULES”: {
                      moduleExec: {
                      module:[],
                      exec: (module, params, key) => {
                      module.show(1000, null, {lockString:“AMK2”})
                      }
                      }
                      },
                      },
                      }

                      exports.recipe = recipe

                      ? 1 Reply Last reply Apr 1, 2019, 11:50 AM Reply Quote 0
                      • 1
                      • 2
                      • 24
                      • 25
                      • 26
                      • 27
                      • 28
                      • 42
                      • 43
                      • 26 / 43
                      • First post
                        Last post
                      Enjoying MagicMirror? Please consider a donation!
                      MagicMirror created by Michael Teeuw.
                      Forum managed by Sam, technical setup by Karsten.
                      This forum is using NodeBB as its core | Contributors
                      Contact | Privacy Policy